ApprovalController.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\Approval\ActionRequest;
  5. use App\Http\Requests\API\Approval\CopyContainerFileRequest;
  6. use App\Http\Requests\API\Approval\CreateOrUpdateRequest;
  7. use App\Http\Resources\API\ActionByApprovalLogResource;
  8. use App\Http\Resources\API\ApprovalCollection;
  9. use App\Http\Resources\API\ApprovalFlowDetailResource;
  10. use App\Http\Resources\API\FileDownloadResource;
  11. use App\Http\Resources\API\FileSimpleResource;
  12. use App\Http\Resources\API\UserProfileResource;
  13. use App\Models\Action;
  14. use App\Models\Approval;
  15. use App\Models\ApprovalFlow;
  16. use App\Models\Container;
  17. use App\Models\Enums\ApprovalFlowObjectType;
  18. use App\Models\Enums\ApprovalFlowType;
  19. use App\Models\Enums\ApprovalObjectType;
  20. use App\Models\Enums\FileObjectType;
  21. use App\Models\Enums\FolderObjectType;
  22. use App\Models\Enums\ObjectAction;
  23. use App\Models\Enums\ObjectApprovalStatus;
  24. use App\Models\File;
  25. use App\Models\Folder;
  26. use App\Repositories\ActionRepository;
  27. use App\Services\Approval\ActionService;
  28. use App\Services\Approval\StoreService;
  29. use Illuminate\Database\Eloquent\Builder;
  30. use Illuminate\Http\Request;
  31. use Illuminate\Support\Facades\Auth;
  32. class ApprovalController extends Controller
  33. {
  34. /**
  35. * Display a listing of the resource.
  36. */
  37. public function index(Request $request)
  38. {
  39. $pageSize=$request->get('page_size') ?? 10;
  40. $query = Approval::with(['createdBy']);
  41. match ($request->get("tab")) {
  42. 'wait_for_me' => $query->allowed(),
  43. 'pr' => $query->where("created_by", Auth::id()),
  44. 'my_approval' => $query->where("action_users", 'like', '%,'.Auth::id().',%'),
  45. default => $query->allowed(true),
  46. };
  47. $approvals = $query->filter($request->all())->orderByDesc("created_at")->paginate($pageSize);
  48. make_display_id($approvals,$pageSize);
  49. return new ApprovalCollection($approvals);
  50. }
  51. public function publicSearch(Request $request){
  52. $pageSize=$request->get('page_size') ?? 10;
  53. $approvals= Approval::filter($request->all())->allowed(true)->orderByDesc("created_at")->paginate($pageSize);
  54. make_display_id($approvals,$pageSize);
  55. return new ApprovalCollection($approvals);
  56. }
  57. /**
  58. * Store a newly created resource in storage.
  59. */
  60. public function store(CreateOrUpdateRequest $request, StoreService $service)
  61. {
  62. $service->store();
  63. return $this->created();
  64. }
  65. /**
  66. * Display the specified resource.
  67. */
  68. public function show(string $id)
  69. {
  70. $approval = Approval::query()
  71. ->where("id", $id)
  72. ->allowed(true)
  73. ->firstOrFail();
  74. $approvalObjectType = ApprovalObjectType::from($approval->object_type);
  75. $object = $approvalObjectType
  76. ->modelBuilder()
  77. ->find($approval->object_id);
  78. $actions = Action::with(['createdBy', 'file'])->where([
  79. 'object_type' => $approvalObjectType->actionObjectType(),
  80. 'object_id' => $object->id,
  81. 'additional_id' => $approval->id,
  82. ])->orderByDesc("created_at")->get();
  83. $subObjects = [];
  84. if ($approvalObjectType == ApprovalObjectType::CONTAINER_FILE && $approval->sub_object_ids) {
  85. $containerFiles = File::query()->whereIn("id", $approval->sub_object_ids)->get();
  86. $subObjects = FileDownloadResource::collection($containerFiles);
  87. }
  88. return $this->success([
  89. 'data' => [
  90. 'id' => $approval->id,
  91. 'status' => $approval->status,
  92. 'object_type' => $approval->object_type,
  93. 'object_id' => $approval->object_id,
  94. 'object' => [
  95. 'id' => $object->id,
  96. 'name' => $object[$approvalObjectType->nameField()],
  97. ],
  98. 'remark' => $approval->remark,
  99. 'node_level' => $approval->node_level,
  100. 'created_by' => new UserProfileResource($approval->createdBy),
  101. 'approval_flow' => new ApprovalFlowDetailResource($approval->approvalFlow),
  102. 'approval_logs' => ActionByApprovalLogResource::collection($actions),
  103. 'sub_objects' => $subObjects,
  104. 'file_copied' => $approval->file_copied,
  105. 'copy_file_permission' => $approvalObjectType == ApprovalObjectType::CONTAINER_FILE
  106. && $approval->last_action_user_id == Auth::id()
  107. && $approval->status == ObjectApprovalStatus::APPROVED->value,
  108. ]
  109. ]);
  110. }
  111. public function action(ActionRequest $request, string $id, ActionService $actionService)
  112. {
  113. $approval = Approval::query()
  114. ->allowed()
  115. ->whereIn("status", [
  116. ObjectApprovalStatus::DOING->value,
  117. ])
  118. ->find($id);
  119. throw_validation_if(! $approval, "No authority for approval");
  120. $actionService->action($approval, $request->status, $request->get("comment"), $request->file("signature_file"));
  121. return $this->noContent();
  122. }
  123. /**
  124. * Update the specified resource in storage.
  125. */
  126. public function update(CreateOrUpdateRequest $request, string $id)
  127. {
  128. $approval = Approval::query()->findOrFail($id);
  129. ApprovalObjectType::from($approval->object_type)
  130. ->modelBuilderAllowed($approval->object_id)
  131. ->findOrFail($approval->object_id);
  132. $approval->remark = $request->remark;
  133. $approval->save();
  134. return $this->noContent();
  135. }
  136. /**
  137. * Remove the specified resource from storage.
  138. */
  139. public function cancel(Request $request)
  140. {
  141. $mode = $request->get("mode", "approval");
  142. throw_validation_if(!$request->get("id"), "ID cannot be empty");
  143. $where = match ($mode) {
  144. "approval" => ["id" => $request->id],
  145. "object_type" => ["object_type" => $request->object_type, "object_id" => $request->id],
  146. default => [],
  147. };
  148. throw_validation_if(! $where, "Please enter valid parameters.");
  149. $approval = Approval::query()
  150. ->whereIn("status", [
  151. ObjectApprovalStatus::DOING->value,
  152. ])
  153. ->where($where)
  154. ->first();
  155. throw_validation_if(! $approval, "The data does not exist or the operation is denied permission.");
  156. $approvalObjectType = ApprovalObjectType::from($approval->object_type);
  157. $object = $approvalObjectType->modelBuilderAllowed($approval->object_id)->findOrFail($approval->object_id);
  158. $approval->status = ObjectApprovalStatus::CANCELED;
  159. $approval->save();
  160. ActionRepository::createByApproval($approval, ObjectAction::APPROVED_CANCELED);
  161. if ($approvalObjectType == ApprovalObjectType::CONTAINER_FILE) {
  162. File::query()->whereIn("id", $approval->sub_object_ids)->update([
  163. 'approval_status' => ObjectApprovalStatus::WAIT
  164. ]);
  165. } else {
  166. $object->approval_status = ObjectApprovalStatus::CANCELED;
  167. $object->save();
  168. }
  169. return $this->noContent();
  170. }
  171. /**
  172. * @param CopyContainerFileRequest $request
  173. * @param string $id
  174. * @return \Illuminate\Http\Response
  175. */
  176. public function copyContainerFile(CopyContainerFileRequest $request, string $id)
  177. {
  178. $approval = Approval::query()
  179. ->where("status", ObjectApprovalStatus::APPROVED->value)
  180. ->where("last_action_user_id", Auth::id())
  181. ->where("object_type", ApprovalObjectType::CONTAINER_FILE)
  182. ->find($id);
  183. throw_validation_if(! $approval, "No authority for approval");
  184. $targetFolder = Folder::query()
  185. ->where("object_type", FolderObjectType::CONTAINER)
  186. ->where("object_id", $approval->object_id)
  187. ->find($request->get("target_folder_id"));
  188. throw_validation_if(! $targetFolder, "Target folder does not exist.");
  189. $files = File::query()->whereIn("id", $approval->sub_object_ids)->get();
  190. foreach ($files as $file) {
  191. $fileBuilder = File::query()
  192. ->where('object_type', FileObjectType::CONTAINER)
  193. ->where('object_id', $file->object_id)
  194. ->where("title", $file->title)
  195. ->where("source", 1)
  196. ->where("folder_id", $targetFolder->id);
  197. $version = (clone $fileBuilder)->count();
  198. (clone $fileBuilder)->update(['is_latest_version' => 0]);
  199. $file->replicate()->fill([
  200. 'source_file_id' => $file->id,
  201. 'folder_id' => $targetFolder->id,
  202. 'version' => $version + 1,
  203. 'is_latest_version' => 1,
  204. ])->save();
  205. }
  206. $approval->file_copied = true;
  207. $approval->save();
  208. return $this->noContent();
  209. }
  210. }