123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- <?php
- namespace App\Http\Controllers\Api;
- use App\Service\DingCallbackCrypto;
- use App\Service\DingTalkCrypto;
- use App\Service\DrbService;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\Http;
- use Illuminate\Support\Facades\Log;
- class DingTalkController extends BaseController
- {
- public function getAccessToken(Request $request)
- {
- $service = new DrbService();
- list($status,$data) = $service->getAccessToken();
- if($status){
- return $this->json_return(200,'',$data);
- }else{
- return $this->json_return(201,$data);
- }
- }
- public function getUserByCode(Request $request)
- {
- $service = new DrbService();
- list($status,$data) = $service->getUserByCode($request->all());
- if($status){
- return $this->json_return(200,'',$data);
- }else{
- return $this->json_return(201,$data);
- }
- }
- public function createProcessInstance(Request $request)
- {
- $service = new DrbService();
- $userData = $request->userData;
- list($status,$data) = $service->createProcessInstance($request->all(), $userData);
- if($status){
- return $this->json_return(200,'',$data);
- }else{
- return $this->json_return(201,$data);
- }
- }
- public function getTemplateFields(Request $request)
- {
- $service = new DrbService();
- list($status,$data) = $service->getTemplateFields($request->all());
- if($status){
- return $this->json_return(200,'',$data);
- }else{
- return $this->json_return(201,$data);
- }
- }
- /**
- * 钉钉事件回调
- */
- public function dinCallback(Request $request)
- {
- $token = config('dingtalk.token'); // 钉钉事件订阅 token
- $aesKey = config('dingtalk.aes_key'); // 钉钉事件订阅 aes_key
- $corpid = config('dingtalk.app_key'); // 钉钉事件订阅 corpid
- $crypt = new DingCallbackCrypto($token, $aesKey, $corpid);
- try {
- $encrypt = $request->input('encrypt');
- $msgSignature = $request->get('msg_signature');
- $timeStamp = $request->get('timestamp');
- $nonce = $request->get('nonce');
- // 1️⃣ 解密
- $event = $crypt->getDecryptMsg($msgSignature, $timeStamp, $nonce, $encrypt);
- $event = json_decode($event, true);
- Log::info('钉钉回调解密后的数据', $event);
- // 2️⃣ 处理事件
- if (isset($event['EventType'])) {
- switch ($event['EventType']) {
- case 'bpms_instance_change':
- $processInstanceId = $event['processInstanceId'] ?? null;
- $result = $event['result'] ?? null;
- Log::info('审批实例变更', compact('processInstanceId','result'));
- break;
- case 'bpms_task_change':
- $processInstanceId = $event['processInstanceId'] ?? null;
- $taskId = $event['taskId'] ?? null;
- $result = $event['result'] ?? null;
- Log::info('审批任务变更', compact('processInstanceId','taskId','result'));
- break;
- }
- }
- // 3️⃣ 返回加密 success
- $res = $crypt->getEncryptedMap('success');
- return response($res, 200)->header('Content-Type', 'application/json');
- } catch (\Exception $e) {
- Log::error('钉钉回调解密异常', ['msg' => $e->getMessage()]);
- return response()->json(['errcode'=>1, 'errmsg'=>'解密失败']);
- }
- return;
- $crypt = new DingTalkCrypto($token, $aesKey);
- // 1. 获取钉钉传来的参数
- $msgSignature = $request->get('msg_signature'); // 注意
- $signature = $request->get('signature');
- $timestamp = $request->get('timestamp');
- $nonce = $request->get('nonce');
- $encrypt = $request->input('encrypt');
- // 2. 解密
- $event = $crypt->decryptMsg($msgSignature, $timestamp, $nonce, $encrypt);
- if ($event === false) {
- Log::error('钉钉解密失败', compact('msgSignature','timestamp','nonce','encrypt'));
- return response()->json([
- 'errcode' => 40001,
- 'errmsg' => 'decrypt fail'
- ]);
- }
- Log::info('钉钉解密后的事件数据', $event);
- // 3. 验证 challenge
- if (isset($event['EventType']) && $event['EventType'] === 'check_url') {
- $encryptMsg = $crypt->encryptMsg($event['Random'], $timestamp, $nonce);
- return response()->json([
- "msg_signature" => $encryptMsg['msg_signature'],
- "timeStamp" => $timestamp,
- "nonce" => $nonce,
- "encrypt" => $encryptMsg['encrypt']
- ]);
- }
- // 4. 处理事件
- if (isset($event['EventType'])) {
- switch ($event['EventType']) {
- case 'bpms_instance_change': // 审批实例变更
- $processInstanceId = $event['processInstanceId'] ?? null;
- $result = $event['result'] ?? null; // agree / oppose / terminate
- Log::info("审批实例变更事件", compact('processInstanceId', 'result'));
- // TODO: 在这里执行你的业务逻辑,例如更新数据库状态
- break;
- case 'bpms_task_change': // 审批任务变更
- $processInstanceId = $event['processInstanceId'] ?? null;
- $taskId = $event['taskId'] ?? null;
- $result = $event['result'] ?? null; // agree / oppose
- Log::info("审批任务变更事件", compact('processInstanceId', 'taskId', 'result'));
- // TODO: 在这里执行你的业务逻辑,例如记录审批人操作
- break;
- default:
- Log::warning("未处理的事件类型", ['EventType' => $event['EventType']]);
- }
- }
- // 5. 返回 success(加密)
- $resEncrypt = $crypt->encryptMsg('success', $timestamp, $nonce);
- return response()->json([
- "msg_signature" => $resEncrypt['msg_signature'],
- "timeStamp" => $timestamp,
- "nonce" => $nonce,
- "encrypt" => $resEncrypt['encrypt']
- ]);
- }
- }
|