api.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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::middleware(['auth:sanctum'])->group(function () {
  17. Route::post("/logout", [API\AuthController::class, "logout"]);
  18. Route::get("user/info", [API\UserController::class, 'info'])->name("user.info");
  19. Route::get("user/index",[API\UserController::class, 'index'])->name("user.index");
  20. Route::middleware(['permission'])->group(function() {
  21. Route::apiResources([
  22. 'asset-group' => API\AssetGroupController::class,
  23. 'asset' => API\AssetController::class,
  24. 'requirement-group' => API\RequirementGroupController::class,
  25. 'requirement' => API\RequirementController::class,
  26. 'project' => API\ProjectController::class,
  27. 'plan' => API\PlanController::class,
  28. 'role' => API\RoleController::class,
  29. 'custom-field' => API\CustomFieldController::class,
  30. 'naming-rule' => API\NameRuleController::class,
  31. 'task' => API\TaskController::class,
  32. 'library' => API\LibraryController::class,
  33. 'department' => API\DepartmentController::class,
  34. ]);
  35. Route::get("asset/{asset_id}/report",[API\AssetController::class, 'report'])->name('asset.report');
  36. Route::patch("requirement/{requirement_id}/close",[API\RequirementController::class, 'close'])->name('requirement.close');
  37. Route::get("requirement/{asset_id}/asset", [API\RequirementController::class, "byAsset"])->name("requirement.byAsset");
  38. Route::patch("requirement/{plan_id}/plan", [API\RequirementController::class, "linkPlan"])->name("requirement.linkPlan");
  39. Route::patch("requirement/plan/unlink", [API\RequirementController::class, "unlinkPlan"])->name("requirement.unlinkPlan");
  40. Route::patch("project/{project}/closed", [API\ProjectController::class, "closed"])->name("project.closed");
  41. Route::patch("project/{project}/start", [API\ProjectController::class, "start"])->name("project.start");
  42. Route::patch("project/{project}/pause", [API\ProjectController::class, "pause"])->name("project.pause");
  43. Route::patch("project/{project}/postpone", [API\ProjectController::class, "postpone"])
  44. ->name("project.postpone");
  45. Route::patch("project/{project}/link-requirement", [API\ProjectController::class, "linkRequirement"])
  46. ->name("project.link-requirement");
  47. Route::patch("project/{project}/unlink-requirement", [API\ProjectController::class, "unlinkRequirement"])
  48. ->name("project.unlink-requirement");
  49. Route::patch("project/{project}/link-requirement-by-plan", [API\ProjectController::class, "linkRequirementByPlan"])
  50. ->name("project.link-requirement-by-plan");
  51. Route::get("project/{project}/plan", [API\ProjectController::class, "plan"])
  52. ->name("project.plan"); //项目关联计划
  53. Route::get("project/{project}/requirement", [API\ProjectController::class, "requirement"])
  54. ->name("project.requirement"); //项目需求
  55. Route::get("project/{project}/not-link-asset-requirement", [API\ProjectController::class, "notLinkAssetRequirement"])
  56. ->name("project.not-link-asset-requirement"); //项目未关联的资产需求
  57. Route::get("permission", [API\PermissionController::class, 'groupPermissions'])->name("permission.group-permission");
  58. Route::get("role/{role}/permission", [API\RoleController::class, "permissions"])->name("role.permissions");
  59. Route::put("role/{role}/assign-permission", [API\RoleController::class, "assignPermissions"])->name("role.assign-permissions");
  60. Route::put("user/{user}/assign-role", [API\UserController::class, "assignRole"])->name("user.assign-role");
  61. Route::get("custom-field-group", [API\CustomFieldController::class, "groups"])->name("custom-field.groups");
  62. Route::get("naming-rule-enabled", [API\NameRuleController::class, "enabled"])->name("naming-rule.enabled");
  63. Route::get("team-member/{project}", [API\TeamMemberController::class, "members"])->name("team-member.list");
  64. Route::delete("team-member/{team_member}", [API\TeamMemberController::class, "destroy"])->name("team-member.destroy");
  65. Route::post("team-member/{project}/manage", [API\TeamMemberController::class, "manageMembers"])->name("team-member.manage-members");
  66. Route::get("library/{library}/folder", [API\FolderController::class, "library"])->name("folder.library");
  67. Route::post("folder", [API\FolderController::class, "store"])->name("folder.store");
  68. Route::get("folder/{folder}", [API\FolderController::class, "show"])->name("folder.show");
  69. Route::patch("folder/{folder}", [API\FolderController::class, "update"])->name("folder.update");
  70. Route::delete("folder/{folder}", [API\FolderController::class, "destroy"])->name("folder.destroy");
  71. Route::post("requirement/batch", [API\RequirementController::class, "batchStore"])->name("requirement.batchStore");
  72. Route::get("config", [API\ConfigController::class, "index"])->name("config.index");
  73. Route::post("config-setting", [API\ConfigController::class, "setting"])->name("config.setting");
  74. Route::get("plan-by-assets", [API\PlanController::class, "byAssets"])->name("plan.by-assets");
  75. Route::post("upload", [API\FileController::class, "upload"])->name("fileUpload");
  76. Route::post("download", [API\FileController::class, "download"])->name("fileDownload");
  77. });
  78. });