api.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  1. <?php
  2. use Illuminate\Support\Facades\Route;
  3. use App\Http\Controllers\EnumController;
  4. use App\Http\Controllers\ScribeController;
  5. use App\Http\Controllers\UploadController;
  6. use App\Http\Controllers\Client\UserController;
  7. use App\Http\Controllers\Client\CoachController;
  8. use App\Http\Controllers\Client\OrderController;
  9. use App\Http\Controllers\Client\WalletController;
  10. use App\Http\Controllers\Client\WechatController;
  11. use App\Http\Controllers\Client\AccountController;
  12. use App\Http\Controllers\Client\CommentController;
  13. use App\Http\Controllers\Client\ProjectController;
  14. use App\Http\Controllers\Client\UserAddressController;
  15. use App\Http\Controllers\Client\CoachLocationController;
  16. use App\Http\Controllers\Client\MarketDistTeamController;
  17. use App\Http\Controllers\Coach\OrderController as CoachOrderController;
  18. use App\Http\Controllers\Coach\WalletController as CoachWalletController;
  19. use App\Http\Controllers\Coach\ProjectController as CoachProjectController;
  20. // API文档相关
  21. Route::get('scribe/update-token/{mobile}', [ScribeController::class, 'updateAuthToken']);
  22. Route::get('/enums', [EnumController::class, 'getEnumData']);
  23. // 客户端路由组
  24. Route::prefix('client')->group(function () {
  25. // 无需认证的路由
  26. Route::prefix('account')->group(function () {
  27. // 发验证码
  28. Route::post('send-code', [AccountController::class, 'sendVerifyCode']);
  29. // 手机号登录
  30. Route::post('login', [AccountController::class, 'login'])->name('login');
  31. // 微信登录
  32. Route::post('wx-login', [AccountController::class, 'wxLogin']);
  33. });
  34. // 微信相关路由(无需认证)
  35. Route::prefix('wechat')->group(function () {
  36. Route::get('auth-url', [WechatController::class, 'getAuthUrl']);
  37. Route::post('callback', [WechatController::class, 'handleCallback']);
  38. Route::get('js-config', [WechatController::class, 'getJsConfig']);
  39. // 微信支付参数
  40. Route::post('pay/config', [App\Http\Controllers\Client\PaymentController::class, 'getConfig'])
  41. ->middleware('auth:sanctum')
  42. ->name('wechat.pay.config');
  43. // 微信支付回调
  44. Route::any('pay/notify', [App\Http\Controllers\Client\PaymentController::class, 'notify']);
  45. // 微信退款回调
  46. Route::post('refund/notify', [App\Http\Controllers\Client\PaymentController::class, 'refundNotify']);
  47. });
  48. // 需要认证的路由组
  49. Route::middleware('auth:sanctum')->group(function () {
  50. // 账号相关
  51. Route::prefix('account')->group(function () {
  52. // 退出登录
  53. Route::post('logout', [AccountController::class, 'logout']);
  54. // 注销账号
  55. Route::delete('/', [AccountController::class, 'destroy']);
  56. // 绑定手机号
  57. Route::post('bind-mobile', [AccountController::class, 'bindMobile'])
  58. ->middleware(['throttle:6,1']); // 添加频率限制;
  59. });
  60. // 用户相关
  61. Route::prefix('user')->group(function () {
  62. // 获取用户信息
  63. Route::get('/', [UserController::class, 'show']);
  64. // 用户注册
  65. Route::post('/', [UserController::class, 'register']);
  66. // 更新用户信息
  67. Route::put('/', [UserController::class, 'update']);
  68. // 提现
  69. Route::post('withdraw', [UserController::class, 'withdraw']);
  70. // 户反馈
  71. // Route::post('/feedback', [UserController::class, 'feedback']);
  72. // 申请成为技师
  73. Route::post('/apply-coach', [UserController::class, 'applyCoach']);
  74. // 生成邀请码
  75. Route::get('/invite-code', [UserController::class, 'generateInviteCode']);
  76. // 获取技师申请记录
  77. Route::get('coach/application', [UserController::class, 'getCoachApplication']);
  78. });
  79. // 项目相关
  80. Route::prefix('project')->group(function () {
  81. Route::get('/', [ProjectController::class, 'index']); // 获取项目列表
  82. Route::get('/detail', [ProjectController::class, 'detail']); // 获取项目详情
  83. Route::get('/coach-list', [ProjectController::class, 'coachProjectList']); // 获取技师开通的项目列表
  84. });
  85. // 技师相关
  86. Route::prefix('coach')->group(function () {
  87. Route::prefix('location')->group(function () {
  88. Route::get('/', [CoachLocationController::class, 'index']); // 获取所有技师定位
  89. Route::post('/', [CoachLocationController::class, 'store']); // 创建新的技师定位
  90. Route::delete('/{id}', [CoachLocationController::class, 'destroy']); // 删除技师定位
  91. });
  92. // 获取可预约时间段
  93. Route::get('schedule', [CoachController::class, 'getSchedule']);
  94. // 获取技师已开通项目
  95. Route::get('/enabled-projects', [CoachController::class, 'enabledProjects']);
  96. // 获取技师订单评价列表
  97. Route::get('/comments', [CoachController::class, 'comments']);
  98. Route::get('/{id}', [CoachController::class, 'detail']); // 获取技师详情
  99. Route::get('/', [CoachController::class, 'list']); // 获取技师列表
  100. });
  101. // 用户地址相关
  102. Route::prefix('address')->group(function () {
  103. Route::get('default', [UserAddressController::class, 'getDefault']);
  104. Route::get('/{id}', [UserAddressController::class, 'detail']);
  105. Route::put('/{id}', [UserAddressController::class, 'update']);
  106. Route::delete('/{id}', [UserAddressController::class, 'destroy']);
  107. Route::put('/{id}/default', [UserAddressController::class, 'setDefault']);
  108. Route::get('/', [UserAddressController::class, 'list']);
  109. Route::post('/', [UserAddressController::class, 'store']);
  110. });
  111. // 订单相关
  112. Route::prefix('orders')->group(function () {
  113. Route::post('initialize', [OrderController::class, 'initialize']);
  114. Route::post('create', [OrderController::class, 'create']);
  115. Route::post('cancel', [OrderController::class, 'cancel']);
  116. Route::post('finish', [OrderController::class, 'finish']);
  117. Route::post('confirm-leave', [OrderController::class, 'confirmLeave']);
  118. Route::get('list', [OrderController::class, 'list']);
  119. Route::get('detail/{id}', [OrderController::class, 'detail']);
  120. Route::post('add-time', [OrderController::class, 'addTime']);
  121. Route::post('calculate-order-amount', [OrderController::class, 'calculateOrderAmount']);
  122. Route::get('grab-list', [OrderController::class, 'getOrderGrabList']);
  123. // 指派技师
  124. Route::post('assign-coach', [App\Http\Controllers\Client\OrderController::class, 'assignCoach'])
  125. ->name('assign-coach');
  126. // 生成订单核销码
  127. Route::get('{id}/code', [OrderController::class, 'generateCode']);
  128. // 评价
  129. Route::post('rate', [OrderController::class, 'rate'])->name('client.order.rate');
  130. // 用户删除订单
  131. Route::delete('{id}', [OrderController::class, 'delete'])->name('client.order.delete');
  132. Route::get('comment-tags', [OrderController::class, 'commentTags']);
  133. });
  134. // 团队管理路由
  135. Route::prefix('team')->group(function () {
  136. Route::get('list', [MarketDistTeamController::class, 'index'])->name('team.list');
  137. });
  138. // 评价管理
  139. Route::post('comments', [CommentController::class, 'store'])->name('client.comments.store');
  140. Route::get('comments', [CommentController::class, 'index'])->name('client.comments.index');
  141. // 技师分组
  142. Route::get('coach-groups', [App\Http\Controllers\Client\CoachGroupController::class, 'index']);
  143. // 钱包相关
  144. Route::prefix('wallet')->group(function () {
  145. Route::get('records', [WalletController::class, 'records']);
  146. // 取钱包信息
  147. Route::get('wallet', [WalletController::class, 'wallet']);
  148. // 提现
  149. Route::post('withdraw', [WalletController::class, 'withdraw']);
  150. });
  151. });
  152. });
  153. // 技师端路由组
  154. Route::middleware(['auth:sanctum', 'coach'])->prefix('coach')->group(function () {
  155. // 认证相关路由
  156. Route::prefix('auth')->group(function () {
  157. Route::post('basic-info', [\App\Http\Controllers\Coach\AuthController::class, 'submitBasicInfo']);
  158. Route::post('real-auth', [\App\Http\Controllers\Coach\AuthController::class, 'submitRealAuth']);
  159. Route::post('qual-auth', [\App\Http\Controllers\Coach\AuthController::class, 'submitQualAuth']);
  160. Route::get('status', [\App\Http\Controllers\Coach\AuthController::class, 'getAuthStatus']);
  161. });
  162. // 账户相关路由组
  163. Route::prefix('account')->group(function () {
  164. Route::post('base-info', [App\Http\Controllers\Coach\AccountController::class, 'submitBaseInfo'])
  165. ->middleware(['throttle:6,1'])
  166. ->name('coach.account.base-info');
  167. Route::post('qualification', [App\Http\Controllers\Coach\AccountController::class, 'submitQualification']);
  168. Route::post('real-name', [App\Http\Controllers\Coach\AccountController::class, 'submitRealName'])
  169. ->middleware('throttle:3,1'); // 实名认证限制更严格
  170. // 获取技师认证详情
  171. Route::get('info', [App\Http\Controllers\Coach\AccountController::class, 'info']);
  172. // 设置位置信息
  173. Route::post('location', [App\Http\Controllers\Coach\AccountController::class, 'setLocation'])
  174. ->name('coach.account.location');
  175. // 获取技师位置信息
  176. Route::get('location', [\App\Http\Controllers\Coach\AccountController::class, 'getLocation']);
  177. // 排班管理
  178. Route::post('schedule', [\App\Http\Controllers\Coach\AccountController::class, 'setSchedule']);
  179. // 更新技师工作状态
  180. Route::post('work-status', [App\Http\Controllers\Coach\AccountController::class, 'updateWorkStatus']);
  181. // 获取技师工作状态
  182. Route::get('work-status', [App\Http\Controllers\Coach\AccountController::class, 'getWorkStatus']);
  183. // 获取技师排班信息
  184. Route::get('schedule', [App\Http\Controllers\Coach\AccountController::class, 'getSchedule']);
  185. // 获取技师详情
  186. Route::get('detail', [App\Http\Controllers\Coach\AccountController::class, 'detail'])->name('coach.detail');
  187. // 更新基础信息
  188. Route::post('update-basic-info', [App\Http\Controllers\Coach\AccountController::class, 'updateBasicInfo'])
  189. ->middleware(['throttle:6,1']) // 添加频率限制,每分钟最多6次
  190. ->name('coach.account.update-basic-info');
  191. // 发送验证码
  192. Route::post('send-code', [App\Http\Controllers\Coach\AccountController::class, 'sendVerifyCode'])
  193. ->middleware(['throttle:3,1']) // 限制每分钟最多发送3次
  194. ->name('coach.account.send-code');
  195. // 获取已开通项目
  196. Route::get('enabled-projects', [App\Http\Controllers\Coach\AccountController::class, 'enabledProjects'])
  197. ->name('coach.account.enabled-projects');
  198. });
  199. // 订单相关路由
  200. Route::prefix('orders')->group(function () {
  201. // 获取技师订单列表
  202. Route::get('/', [CoachOrderController::class, 'getOrderList']);
  203. // 获取可抢单列表
  204. Route::get('/grab', [CoachOrderController::class, 'getGrabList']);
  205. // 抢单
  206. Route::post('/grab/{order_id}', [CoachOrderController::class, 'grabOrder']);
  207. // 接受订单
  208. Route::post('/accept/{order_id}', [CoachOrderController::class, 'acceptOrder']);
  209. // 拒绝订单
  210. Route::post('/reject/{order_id}', [CoachOrderController::class, 'rejectOrder'])
  211. ->middleware(['throttle:6,1']); // 限制拒单频率
  212. // 技师出发
  213. Route::post('/depart/{order_id}', [CoachOrderController::class, 'depart']);
  214. // 技师到达
  215. Route::post('/arrive/{order_id}', [CoachOrderController::class, 'arrive']);
  216. // 技师开始服务
  217. Route::post('/start-service', [CoachOrderController::class, 'startService']);
  218. // 技师撤离
  219. Route::post('/{order_id}/leave', [CoachOrderController::class, 'leave']);
  220. Route::post('settings', [CoachOrderController::class, 'setOrder'])->name('coach.orders.settings'); // 订单设置
  221. // 获取订单设置
  222. Route::get('settings', [CoachOrderController::class, 'getOrderSettings'])->name('coach.orders.get-settings');
  223. // 技师删除订单
  224. Route::delete('/{order_id}', [CoachOrderController::class, 'delete'])->name('coach.orders.delete');
  225. });
  226. // 项目相关路由
  227. Route::prefix('projects')->group(function () {
  228. Route::get('/available', [CoachProjectController::class, 'getAvailableProjects']);
  229. Route::post('/open', [CoachProjectController::class, 'openProject']);
  230. Route::post('/set', [CoachProjectController::class, 'setProject']);
  231. // 获取项目设置
  232. Route::get('/set', [CoachProjectController::class, 'getProjectSettings']);
  233. });
  234. // 钱包相关路由
  235. Route::prefix('wallet')->group(function () {
  236. Route::get('/', [CoachWalletController::class, 'getWallet']);
  237. Route::get('/records', [CoachWalletController::class, 'getWalletRecords']);
  238. Route::post('/withdraw', [CoachWalletController::class, 'withdraw'])
  239. ->middleware(['throttle:10,1']); // 限制提现频率
  240. });
  241. // 投流订单
  242. Route::post('flow/create-order', [\App\Http\Controllers\Coach\CoachFlowController::class, 'createOrder']);
  243. });
  244. // 大观支付回调
  245. Route::post('dgpay/notify', [App\Http\Controllers\Api\DgPayController::class, 'notify'])->name('dgpay.notify');
  246. Route::get('dgpay/return', [App\Http\Controllers\Api\DgPayController::class, 'return'])->name('dgpay.return');
  247. Route::post('/upload', [UploadController::class, 'upload']);
  248. Route::get('/download', [UploadController::class, 'download']);
  249. Route::get('/view', [UploadController::class, 'view']);