我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python如何实现公司内项目对接钉钉审批流程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python如何实现公司内项目对接钉钉审批流程

这篇文章给大家分享的是有关python如何实现公司内项目对接钉钉审批流程的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

上代码:

import requestsimport jsonimport timefrom dingtalk.crypto import DingTalkCryptofrom django.conf import settings# settings.BASE_DIRclass Crypto(object):    def __init__(self, token):        # 随便填的字符串        self.token = token        # 自己生成的43位随机字符串        self.aes_key = settings.DINGDING.get("DINGTALK_AES_TOKEN")        # 钉钉企业ID        self.corp_id = settings.DINGDING.get("CorpId") #        print("corp_id:", self.corp_id)        self.nonce = settings.DINGDING.get("nonce")        self.crypto = DingTalkCrypto(            token=self.nonce,            encoding_aes_key=self.aes_key,            corpid_or_suitekey=self.corp_id        )    def encrypt_success(self):        # 返回加密success        result = self.crypto.encrypt_message(            msg="success",            nonce=self.nonce,            timestamp=int(time.time()*1000)        )        return resultclass DING(object):    def __init__(self, approve_process):        self.AgentId = settings.DINGDING.get("AgentId")        self.AppKey = settings.DINGDING.get("AppKey")        self.AppSecret = settings.DINGDING.get("AppSecret")        self.dingding_url = settings.DINGDING.get("URL")        self.process_code = settings.DINGDING.get("APPROVE_PROCESS").get(approve_process)['process_code']        self.aes_key = settings.DINGDING.get("DINGTALK_AES_TOKEN")        self.nonce = settings.DINGDING.get("nonce")    def get_token(self):        '''        获取钉钉的token        :return: 钉钉token        '''        url = self.dingding_url + '/gettoken?appkey={}&appsecret={}'.format(self.AppKey, self.AppSecret)        req = requests.get(url)        req = json.loads(req.text)        return req['access_token']# def createCallbackDd():#     '''#     注册钉钉回调函数#     :return:#     '''#     url = 'https://oapi.dingtalk.com/call_back/register_call_back?access_token=' + self.getToken()#     data = {#         "call_back_tag": ["bpms_task_change", "bpms_instance_change"],  #这两个回调种类是审批的#         "token": TOKEN,  #自定义的字符串#         "aes_key": AES_KEY, #自定义的43位字符串,密钥#         "url": URL  #回调地址#     }#     requests.post(url, data=json.dumps(data))#     return ('OK')    def create_process(self, originator_user_id, dept_id, form_component_value_vo, approvers, cc_list, has_cc=0):        '''        创建钉钉审批        approvers为list 元素为钉钉userid   cc_list同理        '''        url = self.dingding_url + '/topapi/processinstance/create?access_token=' + self.get_token()        print("form_component_value_vo:", form_component_value_vo)        if has_cc == 0:            data = {                'agent_id': self.AgentId,                'process_code': self.process_code,  #工单id                'originator_user_id': originator_user_id,                'dept_id': dept_id,  #创建人的钉钉部门id                'form_component_values': str(form_component_value_vo), #钉钉后台配置的需要填写的字段,                'approvers': approvers,                'cc_list': cc_list,                'cc_position': 'START_FINISH'  # 发起和完成时与抄送            }        else:            data = {                'agent_id': self.AgentId,                'process_code': self.process_code,  #工单id                'originator_user_id': originator_user_id, #创建人的钉钉userid                'dept_id': dept_id,  #创建人的钉钉部门id                'form_component_values': str(form_component_value_vo), #钉钉后台配置的需要填写的字段,                'approvers': approvers,            }        print("dingding_utils:", data)        response = requests.post(url, data=data)        return response.json()    def get_status(self, process_instance_id):        url = self.dingding_url + '/topapi/processinstance/get?access_token=' + self.get_token()        data = {            "process_instance_id": process_instance_id        }        response = requests.post(url, data=data)        return response.json()    def register_callback(self, call_back_url):        # 注册回调        url = self.dingding_url + '/call_back/register_call_back?access_token=' + self.get_token()        print("self.get_token():", self.get_token())        data = {            "call_back_tag": ['bpms_task_change', 'bpms_instance_change'],            "token": self.nonce,            "aes_key": self.aes_key,            "url": call_back_url,        }        response = requests.post(url, data=json.dumps(data))        return response.json()    def get_callback(self):        url = self.dingding_url + '/call_back/get_call_back?access_token=' + self.get_token()        req = requests.get(url)        req = json.loads(req.text)        return req    def create_process_approver_v2(self, originator_user_id, dept_id, form_component_value_vo, approvers, cc_list):        '''        创建钉钉审批        '''        url = self.dingding_url + '/topapi/processinstance/create?access_token=' + self.get_token()        data = {            'agent_id': self.AgentId,            'process_code': self.process_code,            'originator_user_id': originator_user_id,            'dept_id': dept_id,            'form_component_values': str(form_component_value_vo),            'approvers_v2': json.dumps(approvers)        }        if cc_list:            data['cc_list'] = cc_list            data['cc_position'] = 'FINISH'        response = requests.post(url, data=data)        return response.json()    def create_process_approver_v2_test(self, originator_user_id, dept_id, form_component_value_vo):        '''        创建钉钉审批        '''        url = self.dingding_url + '/topapi/processinstance/create?access_token=' + self.get_token()        data = {            'agent_id': self.AgentId,            'process_code': self.process_code,            'originator_user_id': originator_user_id,            'dept_id': dept_id,            'form_component_values': str(form_component_value_vo),            'approvers_v2': json.dumps([                {                    "task_action_type": "NONE",                    "user_ids": ["dingding_id"],   # 单独审批人                },                {                    "task_action_type": "OR",                    "user_ids": ["dingding_id1", "dingding_id2"],   # 或签                },                {                    "task_action_type": "AND",                    "user_ids": ["dingding_id1", "dingding_id2"],  # 会签                }            ])        }        response = requests.post(url, data=data)        return response.json()if __name__ == "__main__":    import django, os, sys    sys.path.append('xxxxxx')   # 项目路径    os.environ['DJANGO_SETTINGS_MODULE'] = 'xx.settings'    # print("settings.DINGDING", settings.DINGDING)    ding = DING("create_xx")    # print(ding.get_token())    # info = [{'name': '单行输入框','value': 'testixxxxxxxx'}]    # # print(ding.create_process('11', 11, info))    a = [        {'name': "输入框1", 'value': "value1"},        {'name': "输入框2", 'value': "value2"},    ]    # print(ding.create_process_test('11', 11, a))    # print(ding.create_process_approver_v2_test('11', 11, a))    # print(ding.create_process_test2())    # print(ding.get_status('xxx'))    print(ding.get_status('xx'))    # # 验证  回调    # a = ding.get_token()    # print(a)    # c = Crypto(a)    # print(c.encrypt_success())    # 注册回调    # print(ding.register_callback("http://xxxx.vaiwan.com/xxx"))    # print(ding.get_callback())

说明:

  1 Crypto类用于对接钉钉回调用的。一个公司只有一个corpId,并且一个corpid只能注册一个回调地址。我司有公共组注册好了回调。只要接入公司内的回调即可。所以我实际没有使用到Crypto。

  2  在钉钉管理后台中创建应用后会有这三个东西:AgentId、AppKey,AppSecret  。在创建钉钉审批流程,可以从审批流程浏览器中获取到APPROVE_PROCESS。别忘啦给这个流程审批接口权限。这些官方文档有说。

  3  配置setting变量:

DINGDING = {    "AgentId": 123,    "AppKey": "xx",    "AppSecret": "xx",    "URL": "https://oapi.dingtalk.com",    "APPROVE_PROCESS": { # process_code        "create_xx": {            "process_code": "abc", # 审批流程的id    },    "DINGTALK_AES_TOKEN": "abc",    "nonce": "abc",    "CorpId": "abc",}

 4 接口形式创建的审批流程,与钉钉管理后台创建的流程有一些不同:

    1 不能在不同的审批环节设置不同的抄送人

    2 不能审批流程前后有相同的人,不能自动显示成 “自动同意”(管理后台设置成去重后,但是接口指定审批人场景,不支持)

 5 其他如:审批内容、或签,会签代码里都有示例。

感谢各位的阅读!关于“python如何实现公司内项目对接钉钉审批流程”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python如何实现公司内项目对接钉钉审批流程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python如何实现公司内项目对接钉钉审批流程

这篇文章给大家分享的是有关python如何实现公司内项目对接钉钉审批流程的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。上代码:import requestsimport jsonimport timefrom d
2023-06-20

python公司内项目对接钉钉审批流程的实现

最近把组内的一个项目对接钉钉审批接口,通过python3.6。 钉钉官方文档 废话不多说了,上代码:import requests import json import time from dingtalk.crypto import D
2022-06-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录