企业钉钉用户及事件订阅通知

v0.1.2 版本
2024-01-08 版本更新时间
193 安装
2 star

Webman Dingtalk

封装钉钉接口,处理钉钉事件订阅,触发事件

安装

composer require srako/wenman-dingtalk
composer require playcat/queue

配置

  1. 添加 .env 环境变量
DING_CORP_ID=dingxxxxxxx
DING_AGENT_ID=xxxxxxxx
DING_CLIENT_ID=xxxxxxxx
DING_CLIENT_SECRET=xxxxxxxx
DING_AES_KEY=xxxxxxxx
DING_TOKEN=xxxxxxxx

使用

  • 添加钉钉事件订阅队列
<?php

namespace app\queue\cat;

use Playcat\Queue\Protocols\ConsumerData;
use Playcat\Queue\Protocols\ConsumerInterface;
use support\Log;

class DingMessage implements ConsumerInterface
{
    public string $queue = 'ding-message';

    public function consume(ConsumerData $data): void
    {
        $message = $data->getQueueData();
        Log::info('钉钉事件通知', $message);
    }
}

添加的命令

  1. 刷新部门和用户(触发变更事件)
php webman dingtalk:RefreshDepartmentsAndUsers

钉钉接口调用示例

发送工作通知消息

请求方式:POST(HTTPS)
请求地址:https://oapi.dingtalk.com/topapi/message/corpconversation/asyncsend_v2?access_token=ACCESS_TOKEN
$params = [
    'agent_id' => env('DINGTALK_AGENTID'),
    'userid_list' => '0841582759859766',
    'msg' => [
        'msgtype' => 'text',
        'text' => [
            'content' => '当前时间:'.date('Y-m-d H:i:s'),
        ],
    ],
];

$ret = DingTalk::post('/topapi/message/corpconversation/asyncsend_v2', $params);

效果图(可选)