api.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. <?php
  2. use Illuminate\Http\Request;
  3. use Illuminate\Support\Facades\Route;
  4. use App\Http\Controllers\API;
  5. /*
  6. |--------------------------------------------------------------------------
  7. | API Routes
  8. |--------------------------------------------------------------------------
  9. |
  10. | Here is where you can register API routes for your application. These
  11. | routes are loaded by the RouteServiceProvider and all of them will
  12. | be assigned to the "api" middleware group. Make something great!
  13. |
  14. */
  15. Route::post("/login", [API\AuthController::class, "login"]);
  16. Route::post("/send-forget-password-email", [API\AuthController::class, "sendForgetPasswordEmail"]);
  17. Route::post("/reset-password", [API\AuthController::class, "resetPassword"]);
  18. //Route::post("register/company-user", [API\UserController::class, "registerCompanyUser"]);
  19. Route::post("register/company", [API\CompanyController::class, "registerCompany"]);
  20. Route::post("company-file-upload", [API\FileController::class, "companyUpload"]);
  21. //暂时为免登录
  22. Route::get("file/download/{uuid}/share-file", [API\FileController::class, "downloadShareFile"])
  23. ->name("file.download-share-file");
  24. Route::middleware(['auth:sanctum','account.limit'])->group(function () {
  25. //公共权限
  26. Route::post("/logout", [API\AuthController::class, "logout"]);
  27. Route::get("user/details", [API\UserController::class, 'details']);
  28. Route::get("user-items", [API\UserController::class, 'publicSearch']);
  29. Route::get("asset-tree",[API\AssetController::class, 'tree']);
  30. Route::get("asset/{asset_id}/report",[API\AssetController::class, 'report']);
  31. Route::get("asset-items",[API\AssetController::class, "publicSearch"]);
  32. Route::get("asset-group-items",[API\AssetGroupController::class, "publicSearch"]);
  33. Route::get("requirement-group-items",[API\RequirementGroupController::class, "publicSearch"]);
  34. Route::get("requirement-items",[API\RequirementController::class, "publicSearch"]);
  35. Route::get("role-items",[API\RoleController::class, "publicSearch"]);
  36. Route::get("project-by-asset",[API\ProjectController::class, "byAsset"]);
  37. Route::get("project-items",[API\ProjectController::class, "publicSearch"]);
  38. Route::get("project-tree",[API\ProjectController::class, 'tree']);
  39. Route::get("plan-by-assets", [API\PlanController::class, "byAssets"]);
  40. Route::get("notification", [API\NotificationController::class, "index"]);
  41. Route::get("notification/unread", [API\NotificationController::class, "unread"]);
  42. Route::post("notification/mark-as-read", [API\NotificationController::class, "markAsRead"]);
  43. Route::get("naming-rule-enabled", [API\NameRuleController::class, "enabled"]);
  44. Route::get("container-report", [API\ContainerController::class, "containerReport"]);
  45. Route::get("library", [API\LibraryController::class, "index"]);
  46. Route::get('container', [API\ContainerController::class, "index"]);
  47. Route::get("action/{object_type}/history/{object_id}", [API\ActionController::class, "history"]);
  48. Route::get("company-items", [API\CompanyController::class, "publicSearch"]);
  49. Route::get("department-items", [API\DepartmentController::class, "publicSearch"]);
  50. Route::get("container-linkage/{library_id}", [API\ContainerController::class, "linkage"]);
  51. Route::get("folder-open", [API\FolderController::class, "open"]);
  52. Route::get("folder-tree/{object_type}/{object_id}", [API\FolderController::class, "tree"]);
  53. Route::get("file/{object_type}/{object_id}", [API\FileController::class, "byObject"]);
  54. Route::get("folder/file-version-tree/{object_type}/{object_id}", [API\FolderController::class, "versionFileTreeByObject"]);
  55. Route::get("project-asset-tree/{project_id}", [API\ProjectController::class, "projectAssetTree"]);
  56. Route::get("project-requirementGroups-tree/{asset_id}", [API\ProjectController::class, "projectRequirementGroupsTree"]);
  57. Route::get("project/{project}/not-link-asset-requirement", [API\ProjectController::class, "notLinkAssetRequirement"]);
  58. Route::get("library-linkage/{type}", [API\LibraryController::class, "linkage"]);
  59. Route::get("project/{project}/latest-dynamic", [API\ProjectController::class, "latestDynamic"]);
  60. // Allow access only to admin role
  61. Route::middleware(['permission', 'role.super-admin', 'system.operation-log'])->group(function () {
  62. Route::apiResource("company", API\CompanyController::class)->only([
  63. 'store','destroy','show'
  64. ]);
  65. // Route::patch("user/userInfo/{user_id}",[API\UserController::class, 'updateUserInfo'])->name('user.updateUserInfo');
  66. Route::post("company/action",[API\CompanyController::class,"action"])->name("company.action");
  67. Route::get('system-operation-log', [API\SystemOperationLogController::class, 'index'])->name("system-operation-log.index");
  68. });
  69. Route::middleware(['permission', 'system.operation-log'])->group(function() {
  70. Route::apiResources([
  71. 'asset-group' => API\AssetGroupController::class,
  72. 'asset' => API\AssetController::class,
  73. 'requirement-group' => API\RequirementGroupController::class,
  74. 'requirement' => API\RequirementController::class,
  75. 'project' => API\ProjectController::class,
  76. 'plan' => API\PlanController::class,
  77. 'roles' => API\RoleController::class,
  78. 'custom-field' => API\CustomFieldController::class,
  79. 'naming-rule' => API\NameRuleController::class,
  80. 'task' => API\TaskController::class,
  81. // 'library' => API\LibraryController::class,
  82. 'department' => API\DepartmentController::class,
  83. 'user' => API\UserController::class,
  84. // 'container' => API\ContainerController::class,
  85. 'approval-flow' => API\ApprovalFlowController::class,
  86. 'approval' => API\ApprovalController::class,
  87. ]);
  88. Route::apiResource("company", API\CompanyController::class)->only([
  89. 'index', 'show', 'update'
  90. ]);
  91. Route::apiResource("library", API\LibraryController::class)->only([
  92. 'store','update','destroy','show'
  93. ]);
  94. Route::apiResource("container", API\ContainerController::class)->only([
  95. 'store','update','destroy','show'
  96. ]);
  97. Route::get("config", [API\ConfigController::class, "index"])->name("config.index");
  98. Route::post("config-setting", [API\ConfigController::class, "setting"])->name("config.setting");
  99. Route::get("config/message-notification-setting", [API\ConfigController::class, "messageNotificationSetting"])
  100. ->name("config.message-notification-setting");
  101. Route::post("config/message-notification-setting", [API\ConfigController::class, "storeMessageNotificationSetting"])
  102. ->name("config.store-message-notification-setting");
  103. Route::get("permission", [API\PermissionController::class, 'groupPermissions'])->name("permission.group-permission");
  104. Route::get("permission/menu", [API\PermissionController::class, 'menuPermissions'])->name("permission.menu");
  105. Route::get("role/{role}/permission", [API\RoleController::class, "permissions"])->name("role.permissions");
  106. Route::put("role/{role}/assign-permission", [API\RoleController::class, "assignPermissions"])->name("role.assign-permissions");
  107. Route::put("role/{role}/assign-menus-permission", [API\RoleController::class, "assignMenusPermissions"])->name("role.assign-menus-permissions");
  108. Route::put("user/{user}/assign-role", [API\UserController::class, "assignRole"])->name("user.assign-role");
  109. Route::get("role/{role}/menus", [API\RoleController::class, "menus"])->name("role.menus");
  110. Route::post("approval/{approval}/action", [API\ApprovalController::class, 'action'])->name("approval.action");
  111. Route::patch("approval-cancel", [API\ApprovalController::class, 'cancel'])->name("approval.cancel");
  112. Route::get("asset/{asset}/dynamic", [API\AssetController::class, "dynamic"])->name("asset.dynamic");
  113. Route::patch("requirement/{requirement_id}/close",[API\RequirementController::class, 'close'])->name('requirement.close');
  114. Route::patch("requirement/{requirement_id}/start",[API\RequirementController::class, 'start'])->name('requirement.start');
  115. //Route::get("requirement/{asset_id}/asset", [API\RequirementController::class, "byAsset"])->name("requirement.byAsset");
  116. Route::patch("requirement/{plan_id}/plan", [API\RequirementController::class, "linkPlan"])->name("requirement.linkPlan");
  117. Route::patch("requirement/plan/unlink", [API\RequirementController::class, "unlinkPlan"])->name("requirement.unlinkPlan");
  118. Route::get("requirement-export", [API\RequirementController::class, "export"])->name("requirement.export");
  119. Route::post("requirement-import", [API\RequirementController::class, "import"])->name("requirement.import");
  120. Route::get("project/{project}/dynamic", [API\ProjectController::class, "dynamic"])->name("project.dynamic");
  121. Route::get("project/{project}/kanban", [API\ProjectController::class, "kanban"])->name("project.kanban");
  122. Route::get("project/{project}/group-view", [API\ProjectController::class, "groupView"])->name("project.group-view");
  123. Route::get("project/{project}/gantt", [API\ProjectController::class, "gantt"])->name("project.gantt");
  124. Route::get("project/{project}/print-kanban", [API\ProjectController::class, "printKanban"])->name("project.print-kanban");
  125. Route::patch("project/{project}/closed", [API\ProjectController::class, "closed"])->name("project.closed");
  126. Route::patch("project/{project}/start", [API\ProjectController::class, "start"])->name("project.start");
  127. Route::patch("project/{project}/pause", [API\ProjectController::class, "pause"])->name("project.pause");
  128. Route::patch("project/{project}/postpone", [API\ProjectController::class, "postpone"])
  129. ->name("project.postpone");
  130. Route::patch("project/{project}/link-requirement", [API\ProjectController::class, "linkRequirement"])
  131. ->name("project.link-requirement");
  132. Route::patch("project/{project}/unlink-requirement", [API\ProjectController::class, "unlinkRequirement"])
  133. ->name("project.unlink-requirement");
  134. Route::patch("project/{project}/link-requirement-by-plan", [API\ProjectController::class, "linkRequirementByPlan"])
  135. ->name("project.link-requirement-by-plan");
  136. Route::patch("project/{project_id}/update-link-assets", [API\ProjectController::class, "updateLinkAssets"])
  137. ->name("project.update-link-assets");
  138. Route::get("project/{project}/plan", [API\ProjectController::class, "plan"])
  139. ->name("project.plan"); //项目关联计划
  140. Route::get("project/{project}/requirement", [API\ProjectController::class, "requirement"])
  141. ->name("project.requirement"); //项目需求
  142. // Route::get("project/{project}/not-link-asset-requirement", [API\ProjectController::class, "notLinkAssetRequirement"])
  143. // ->name("project.not-link-asset-requirement"); //项目未关联的资产需求
  144. Route::patch("task/{task}/closed", [API\TaskController::class, "closed"])->name("task.closed");
  145. Route::patch("task/{task}/start", [API\TaskController::class, "start"])->name("task.start");
  146. Route::patch("task/{task}/pause", [API\TaskController::class, "pause"])->name("task.pause");
  147. Route::patch("task/{task}/done", [API\TaskController::class, "done"])->name("task.done");
  148. Route::patch("task/{task}/cancel", [API\TaskController::class, "cancel"])->name("task.cancel");
  149. Route::patch("task/{task}/wait", [API\TaskController::class, "wait"])->name("task.wait");
  150. Route::post("task-batch-create", [API\TaskController::class, "batchStore"])->name("task.batch-store");
  151. Route::patch("task/{task}/assign", [API\TaskController::class, "assign"])->name("task.assign");
  152. Route::post("task/{task}/container", [API\TaskController::class, "linkContainer"])->name("task.link-container");
  153. Route::delete("task-container/{task_container}", [API\TaskController::class, "unlinkContainer"])->name("task.unlink-container");
  154. Route::get("task/{task}/container-to-be-linked", [API\TaskController::class, "containerToBeLinked"])->name("task.container-to-be-linked");
  155. Route::get("task-export", [API\TaskController::class, "export"])->name("task.export");
  156. Route::post("task-import", [API\TaskController::class, "import"])->name("task.import");
  157. Route::post("user/user-batch-create", [API\UserController::class, "batchStore"])->name("user.batch-create");
  158. Route::put("user/status/{status}", [API\UserController::class, "status"])->name("user.status");
  159. //Route::patch("user/update-info", [API\UserController::class, "updateInfo"])->name("user.updateInfo");
  160. Route::get("custom-field-group", [API\CustomFieldController::class, "groups"])->name("custom-field.groups");
  161. Route::get("custom-field-group/naming-rule", [API\CustomFieldController::class, "nameRuleGroups"])->name("custom-field.nameRuleGroups");
  162. Route::post("naming-rule/{naming_rule}/combination", [API\NameRuleController::class, "combinationSetting"])
  163. ->name("naming-rule.combination-setting");
  164. Route::get("naming-rule/{naming_rule}/combination/show", [API\NameRuleController::class, "combinationShow"])
  165. ->name("naming-rule.combination-show");
  166. Route::post("naming-rule/{name_rule}/autoname", [API\NameRuleController::class, "autoname"])
  167. ->name("name-rule.autoname");
  168. Route::get("team-member/{project}", [API\TeamMemberController::class, "members"])->name("team-member.list");
  169. Route::delete("team-member/{team_member}", [API\TeamMemberController::class, "destroy"])->name("team-member.destroy");
  170. Route::post("team-member/{project}/manage", [API\TeamMemberController::class, "manageMembers"])->name("team-member.manage-members");
  171. Route::post("folder", [API\FolderController::class, "store"])->name("folder.store");
  172. Route::get("folder/{folder}", [API\FolderController::class, "show"])->name("folder.show");
  173. Route::patch("folder/{folder}", [API\FolderController::class, "update"])->name("folder.update");
  174. Route::delete("folder/{folder}", [API\FolderController::class, "destroy"])->name("folder.destroy");
  175. // Route::get("folder-open", [API\FolderController::class, "open"])->name("folder.open");
  176. // Route::get("folder/file-version-tree/{object_type}/{object_id}", [API\FolderController::class, "versionFileTreeByObject"])
  177. // ->name("folder.file-version-tree-by-object");
  178. Route::patch("folder/{folder}/change-name", [API\FolderController::class, "changeName"])->name("folder.change-name");
  179. Route::get("folder/search/folder-file", [API\FolderController::class, "search"])->name("folder.search-folder-file");
  180. Route::post("requirement/batch", [API\RequirementController::class, "batchStore"])->name("requirement.batchStore");
  181. //Route::get("requirement-by-assets", [API\RequirementController::class, "byAssets"])->name("requirement.by-assets");
  182. //Route::get("project-tree/{project_id}", [API\ProjectController::class, "treeIndex"])->name("project.project-tree");
  183. // Route::get("project-asset-tree/{project_id}", [API\ProjectController::class, "projectAssetTree"])->name("project.project-asset-tree");
  184. // Route::get("project-requirementGroups-tree/{asset_id}", [API\ProjectController::class, "projectRequirementGroupsTree"])->name("project.project-requirementGroups-tree");
  185. Route::get("project-link-requirements-group/{project_id}",[API\ProjectController::class, "requirementsLinkGroup"])->name("project.link-requirements-group");
  186. Route::post("action/{object_type}/comment/{object_id}", [API\ActionController::class, "comment"])->name("action.comment");
  187. Route::patch("action/{action}/comment", [API\ActionController::class, "updateComment"])->name("action.update-comment");
  188. Route::post("file-upload", [API\FileController::class, "upload"])->name("file.upload");
  189. // Route::get("file/{object_type}/{object_id}", [API\FileController::class, "byObject"])->name("file.by-object");
  190. Route::post("file/{file}/download", [API\FileController::class, "download"])->name("file.download");
  191. Route::post("file/download-zip", [API\FileController::class, "downloadZip"])->name("file.download-zip");
  192. Route::get("file/download-all-latest/{object_type}/{object_id}", [API\FileController::class, "downloadAllLatest"])
  193. ->name("file.download-all-latest");
  194. Route::patch("file/{file}/change-name", [API\FileController::class, "changeName"])->name("file.change-name");
  195. Route::delete("file/{file}/destroy", [API\FileController::class, "destroy"])->name("file.destroy");
  196. Route::post("file/keep-directory-upload", [API\FileController::class, "keepDirectoryUpload"])->name("file.keep-directory-upload");
  197. Route::delete("file/{file}/hide", [API\FileController::class, "hide"])->name("file.hide");
  198. Route::get("file-bim-view/{file}", [API\FileController::class, "bimView"])->name("file.bim-view");
  199. Route::get("container-attachments", [API\ContainerController::class, "attachments"])->name("container.attachments");
  200. Route::post("share-file", [API\ShareFileController::class, "store"])->name("share-file.store");
  201. Route::delete("share-file/{share_file}", [API\ShareFileController::class, "destroy"])
  202. ->name("share-file.destroy");
  203. Route::get("share-file/{object_type}/{object_id}", [API\ShareFileController::class, "byObject"])
  204. ->name("share-file.by-object");
  205. Route::get("department-user-index",[API\DepartmentController::class,"departmentUserIndex"])->name("department.user-index");
  206. });
  207. });