| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 |
- <?php
- namespace App\Http\Controllers\Api;
- use App\Jobs\ProcessDataJob;
- use App\Model\DDEmployee;
- use App\Model\Record;
- use App\Model\U8State;
- use App\Service\DingCallbackCrypto;
- use App\Service\DingService;
- 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 DingService();
- 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 DingService();
- $LoginType = $request->header('LoginType') ?? null;
- list($status,$data) = $service->getUserByCode($request->all(), $LoginType);
- if($status){
- return $this->json_return(200,'',$data);
- }else{
- return $this->json_return(201,$data);
- }
- }
- public function createProcessInstance(Request $request)
- {
- $service = new DingService();
- $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 getTodoProcessList(Request $request)
- {
- $service = new DingService();
- $userData = $request->userData;
- list($status,$data) = $service->getTodoProcessList($request->all(), $userData);
- if($status){
- return $this->json_return(200,'',$data);
- }else{
- return $this->json_return(201,$data);
- }
- }
- public function executeProcess(Request $request)
- {
- $service = new DingService();
- $userData = $request->userData;
- list($status,$data) = $service->executeProcess($request->all(), $userData);
- if($status){
- return $this->json_return(200,'',$data);
- }else{
- return $this->json_return(201,$data);
- }
- }
- public function executeApproval(Request $request)
- {
- $service = new DingService();
- $userData = $request->userData;
- list($status,$data) = $service->executeApproval($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 DingService();
- 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)
- {
- $type = DDEmployee::type_one;
- $token = config("dingtalk.{$type}.token"); // 钉钉事件订阅 token
- $aesKey = config("dingtalk.{$type}.aes_key"); // 钉钉事件订阅 aes_key
- $corpid = config("dingtalk.{$type}.app_key");
- $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;
- $type = $event['type'] ?? null; // start/finish/terminate/delete
- $staffId = $event['staffId'] ?? "";
- // 动作导致流程成功 或 流程终止
- $this->settleData($type, $result, $processInstanceId, $staffId);
- // Log::info('审批实例变更', compact('processInstanceId','result'));
- // Log::info("最后一个节点审核通过,审批完成", compact('processInstanceId'));
- // Log::info("审批流程被驳回或终止", compact('processInstanceId','result'));
- break;
- case 'bpms_task_change':
- $processInstanceId = $event['processInstanceId'] ?? null;
- $taskId = $event['taskId'] ?? null;
- $result = $event['result'] ?? null;
- $approverUserId = $event['staffId'] ?? null;
- // 捕获节点被驳回
- if ($result === 'refuse') {
- // Log::info("节点被驳回", compact('processInstanceId','taskId','approverUserId'));
- }
- break;
- }
- }
- // 3️⃣ 返回加密 success
- $res = $crypt->getEncryptedMap('success');
- return response($res, 200)->header('Content-Type', 'application/json');
- } catch (\Exception $e) {
- Log::channel('apiLog')->info('钉钉回调解密异常', ['msg' => $e->getMessage()]);
- return response()->json(['errcode'=>1, 'errmsg'=>'解密失败']);
- }
- }
- private function settleData($type, $result, $processInstanceId, $staffId){
- try {
- $record = Record::where("del_time",0)
- ->where('login_type', DDEmployee::type_one)
- ->where('process_instance_id', $processInstanceId)
- ->first();
- if(empty($record)) return;
- $record->userid = $staffId;
- switch ($type) {
- case 'finish': // 审批正常结束(同意 / 拒绝)
- if ($result === 'agree') {
- $record->del_time = 2; // 成功
- } elseif ($result === 'refuse') {
- $record->del_time = 1; // 驳回
- }
- break;
- case 'terminate': // 审批终止(发起人撤销)
- $record->del_time = 1; // 终止
- break;
- case 'delete': // 审批实例删除
- $record->del_time = 1; // 删除
- break;
- }
- $record->save();
- $record_array = $record->toArray();
- if($record_array['del_time'] == 2) {
- //通过后 =》 逻辑
- ProcessDataJob::dispatch($record_array)->onQueue(Record::$job);
- }elseif ($record_array['del_time'] == 1){
- //其他环节 =》 更新表状态为中
- U8State::updateOrCreate(
- ['order_number' => $record_array['order_number'], 'login_type' => $record_array['login_type'], 'type' => $record_array['type']],
- ['state' => U8State::state_two]
- );
- }
- } catch (\Throwable $exception) {
- Log::channel('apiLog')->info('钉钉回调处理数据保存异常', ['msg' => $exception->getMessage()]);
- }
- }
- /**
- * 杭州 钉钉事件回调
- */
- public function dinCallbackH(Request $request)
- {
- $type = DDEmployee::type_two;
- $token = config("dingtalk.{$type}.token"); // 钉钉事件订阅 token
- $aesKey = config("dingtalk.{$type}.aes_key"); // 钉钉事件订阅 aes_key
- $corpid = config("dingtalk.{$type}.app_key");
- $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;
- $type = $event['type'] ?? null; // start/finish/terminate/delete
- $staffId = $event['staffId'] ?? "";
- // 动作导致流程成功 或 流程终止
- $this->settleDataH($type, $result, $processInstanceId, $staffId);
- // Log::info('审批实例变更', compact('processInstanceId','result'));
- // Log::info("最后一个节点审核通过,审批完成", compact('processInstanceId'));
- // Log::info("审批流程被驳回或终止", compact('processInstanceId','result'));
- break;
- case 'bpms_task_change':
- $processInstanceId = $event['processInstanceId'] ?? null;
- $taskId = $event['taskId'] ?? null;
- $result = $event['result'] ?? null;
- $approverUserId = $event['staffId'] ?? null;
- // 捕获节点被驳回
- if ($result === 'refuse') {
- // Log::info("节点被驳回", compact('processInstanceId','taskId','approverUserId'));
- }
- break;
- }
- }
- // 3️⃣ 返回加密 success
- $res = $crypt->getEncryptedMap('success');
- return response($res, 200)->header('Content-Type', 'application/json');
- } catch (\Exception $e) {
- Log::channel('apiLog')->info('钉钉回调解密异常', ['msg' => $e->getMessage()]);
- return response()->json(['errcode'=>1, 'errmsg'=>'解密失败']);
- }
- }
- private function settleDataH($type, $result, $processInstanceId, $staffId){
- try {
- $record = Record::where("del_time",0)
- ->where('login_type', DDEmployee::type_two)
- ->where('process_instance_id', $processInstanceId)
- ->first();
- if(empty($record)) return;
- $record->userid = $staffId;
- switch ($type) {
- case 'finish': // 审批正常结束(同意 / 拒绝)
- if ($result === 'agree') {
- $record->del_time = 2; // 成功
- } elseif ($result === 'refuse') {
- $record->del_time = 1; // 驳回
- }
- break;
- case 'terminate': // 审批终止(发起人撤销)
- $record->del_time = 1; // 终止
- break;
- case 'delete': // 审批实例删除
- $record->del_time = 1; // 删除
- break;
- }
- $record->save();
- $record_array = $record->toArray();
- if($record_array['del_time'] == 2) {
- //通过后 =》 逻辑
- ProcessDataJob::dispatch($record_array)->onQueue(Record::$job);
- }elseif ($record_array['del_time'] == 1){
- //其他环节 =》 更新表状态为中
- U8State::updateOrCreate(
- ['order_number' => $record_array['order_number'], 'login_type' => $record_array['login_type'], 'type' => $record_array['type']],
- ['state' => U8State::state_two]
- );
- }
- } catch (\Throwable $exception) {
- Log::channel('apiLog')->info('钉钉回调处理数据保存异常', ['msg' => $exception->getMessage()]);
- }
- }
- }
|