api.php 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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::get("asset-group/find", [API\AssetGroupController::class, "find"])->name("asset-group.find");
  22. Route::apiResources([
  23. 'asset-group' => API\AssetGroupController::class,
  24. 'asset' => API\AssetController::class,
  25. 'requirement-group' => API\RequirementGroupController::class,
  26. 'requirement' => API\RequirementController::class,
  27. 'project' => API\ProjectController::class,
  28. 'plan' => API\PlanController::class,
  29. 'role' => API\RoleController::class,
  30. 'custom-field' => API\CustomFieldController::class,
  31. ]);
  32. Route::get("requirement/{asset_id}/asset", [API\RequirementController::class, "byAsset"])->name("requirement.byAsset");
  33. Route::patch("requirement/{plan_id}/plan", [API\RequirementController::class, "linkPlan"])->name("requirement.linkPlan");
  34. Route::patch("project/{project}/closed", [API\ProjectController::class, "closed"])->name("project.closed");
  35. Route::patch("project/{project}/start", [API\ProjectController::class, "start"])->name("project.start");
  36. Route::patch("project/{project}/pause", [API\ProjectController::class, "pause"])->name("project.pause");
  37. Route::patch("project/{project}/postpone", [API\ProjectController::class, "postpone"])
  38. ->name("project.postpone");
  39. Route::patch("project/{project}/link-requirement", [API\ProjectController::class, "linkRequirement"])
  40. ->name("project.link-requirement");
  41. Route::patch("project/{project}/unlink-requirement", [API\ProjectController::class, "unlinkRequirement"])
  42. ->name("project.unlink-requirement");
  43. Route::patch("project/{project}/link-requirement-by-plan", [API\ProjectController::class, "linkRequirementByPlan"])
  44. ->name("project.link-requirement-by-plan");
  45. Route::get("project/{project}/plan", [API\ProjectController::class, "plan"])
  46. ->name("project.plan"); //项目关联计划
  47. Route::get("project/{project}/requirement", [API\ProjectController::class, "requirement"])
  48. ->name("project.requirement"); //项目需求
  49. Route::get("project/{project}/not-link-asset-requirement", [API\ProjectController::class, "notLinkAssetRequirement"])
  50. ->name("project.not-link-asset-requirement"); //项目未关联的资产需求
  51. Route::get("permission", [API\PermissionController::class, 'groupPermissions'])->name("permission.group-permission");
  52. Route::get("role/{role}/permission", [API\RoleController::class, "permissions"])->name("role.permissions");
  53. Route::put("role/{role}/assign-permission", [API\RoleController::class, "assignPermissions"])->name("role.assign-permissions");
  54. Route::put("user/{user}/assign-role", [API\UserController::class, "assignRole"])->name("user.assign-role");
  55. Route::get("custom-field-group", [API\CustomFieldController::class, "groups"])->name("custom-field.groups");
  56. });
  57. });