飞书长连接_事件订阅(接收消息,审批任务状态变更)

python 复制代码
import lark_oapi as lark
from lark_oapi.ws import Client
import json
import requests
import time

# 你的凭证
APP_ID = "XXX"
APP_SECRET = "XXX"

# 缓存 tenant_access_token
tenant_access_token = None
token_expire_time = 0

# 获取 tenant_access_token
def get_tenant_access_token():
    global tenant_access_token, token_expire_time
    
    if tenant_access_token and time.time() < token_expire_time:
        return tenant_access_token
    
    url = "https://open.feishu.cn/open-apis/auth/v3/tenant_access_token/internal"
    headers = {"Content-Type": "application/json"}
    data = {"app_id": APP_ID, "app_secret": APP_SECRET}
    
    try:
        response = requests.post(url, headers=headers, json=data)
        result = response.json()
        
        if result.get("code") == 0:
            tenant_access_token = result.get("tenant_access_token")
            token_expire_time = time.time() + result.get("expire", 7200) - 100
            return tenant_access_token
        else:
            print(f"获取token失败: {result}")
            return None
    except Exception as e:
        print(f"获取token异常: {e}")
        return None

# 处理普通消息
def on_recv_msg(event):
    print("=" * 50)
    print("【收到飞书消息】")
    
    event_data = event.event
    sender = event_data.sender
    message = event_data.message
    
    print("发送人 ID:", sender.sender_id.open_id)
    print("消息 ID:", message.message_id)
    
    content = json.loads(message.content)
    print("消息内容:", content.get("text", ""))
    print("=" * 50)

# 获取审批实例详情
def get_approval_instance(instance_code):
    token = get_tenant_access_token()
    if not token:
        print("获取token失败,无法获取审批详情")
        return None
    
    url = f"https://open.feishu.cn/open-apis/approval/v4/instances/{instance_code}"
    headers = {"Authorization": f"Bearer {token}"}
    
    try:
        response = requests.get(url, headers=headers)
        result = response.json()
        
        if result.get("code") == 0:
            return result.get("data")
        else:
            print(f"获取审批详情失败: {result}")
            return None
    except Exception as e:
        print(f"获取审批详情异常: {e}")
        return None

# 解析表单内容
def parse_form_content(form_str):
    try:
        form_data = json.loads(form_str)
        print("\n【表单内容】")
        for field in form_data:
            field_name = field.get('name', '未知字段')
            field_value = field.get('value', '')
            field_type = field.get('type', '')
            
            # 处理特殊类型的字段值
            if isinstance(field_value, dict):
                field_value = json.dumps(field_value, ensure_ascii=False)
            elif isinstance(field_value, list):
                field_value = ', '.join(str(v) for v in field_value)
            
            print(f"  {field_name} ({field_type}): {field_value}")
    except json.JSONDecodeError as e:
        print(f"  表单解析失败: {e}")

# 处理审批状态变更
def on_approval_change(event):
    print("=" * 50)
    print("【收到审批任务事件】")
    
    event_dict = json.loads(lark.JSON.marshal(event))
    event_info = event_dict.get('event', {})
    
    print("审批定义Code:", event_info.get('approval_code', 'N/A'))
    print("审批实例Code:", event_info.get('instance_code', 'N/A'))
    print("审批状态:", event_info.get('status', 'N/A'))
    print("用户ID:", event_info.get('user_id', 'N/A'))
    
    instance_code = event_info.get('instance_code')
    if instance_code:
        print("\n【正在获取审批表单详情...】")
        instance_data = get_approval_instance(instance_code)
        if instance_data:
            print("审批名称:", instance_data.get('approval_name', 'N/A'))
            print("审批单号:", instance_data.get('serial_number', 'N/A'))
            print("创建时间:", instance_data.get('start_time', 'N/A'))
            print("结束时间:", instance_data.get('end_time', 'N/A'))
            print("发起部门:", instance_data.get('department_id', 'N/A'))
            
            # 解析表单内容
            form_str = instance_data.get('form', '')
            if form_str:
                parse_form_content(form_str)
            else:
                print("\n【表单内容】")
                print("  未获取到表单数据")
    
    print("=" * 50)

# 初始化事件处理器
handler = (
    lark.EventDispatcherHandler.builder("", "")
    .register_p2_im_message_receive_v1(on_recv_msg)
    .register_p1_customized_event("approval_task", on_approval_change)
    .build()
)

# 建立长连接
client = Client(APP_ID, APP_SECRET, event_handler=handler)
print("正在连接飞书...")
client.start()
相关推荐
vx_biyesheji00041 小时前
计算机毕业设计:Python医疗数据分析平台 Flask框架 数据分析 可视化 医疗大数据 用户画像(建议收藏)✅
大数据·python·深度学习·数据分析·django·flask·课程设计
木易 士心1 小时前
Java 跳出多层循环
java·开发语言·后端
乐观勇敢坚强的老彭1 小时前
day515C++信奥循环嵌套强化03
开发语言·c++
杜子不疼.1 小时前
【C++ AI 大模型接入 SDK】 - 环境搭建
开发语言·数据库·c++
怀旧,1 小时前
【C++项目】负载均衡式在线OJ
开发语言·c++·负载均衡
m0_702036531 小时前
CSS如何兼容新旧方案结合响应式容器查询
jvm·数据库·python
yujunl1 小时前
U9系统admin用户账号密码生成Do方法
开发语言
ZHW_AI课题组1 小时前
基于ElasticNet网格搜索的汽车燃油效率预测
python·机器学习·回归算法
MaikieMaiky1 小时前
C++ STL 系列(一):string 容器详解与示例
开发语言·c++