da48a3652d
後端: - Migration:diving_offers 新增 provider_id(nullable FK) - Migration:users.role ENUM 加入 provider 值 - Migration:diving_offers.spot 改為 nullable - AuthController:registerProvider business_name 改為選填 - AuthController:updateProviderProfile 補上 certifications / dive_sites / services / facilities / website / social_media - ProviderOfferController:教練課程 CRUD(index/show/store/update/destroy),實作 provider_id 所有權不變式(404 → 403 兩步驟) 前端(frontend/): - coachAuth store、coachAxios(獨立於 member auth) - /coach/* 路由群組 + beforeEach guard - CoachNavBar、CoachLayout(教練頁隱藏會員 NavBar) - LoginView、RegisterView、DashboardView(表格 + 刪除確認) - OfferFormView(新增/編輯共用)、ProfileView OpenSpec: - openspec/config.yaml 補入專案 context 與 rules - 新增 specs:coach-offers-api / coach-portal-ui / provider-auth - 更新 spec:diving-offers-api 加入 provider_id - 歸檔:openspec/changes/archive/2026-05-10-coach-portal Co-Authored-By: Claude Sonnet 4.6 (1M context) <noreply@anthropic.com>
95 lines
4.1 KiB
PHP
95 lines
4.1 KiB
PHP
<?php
|
||
|
||
use Illuminate\Support\Facades\Route;
|
||
use App\Http\Controllers\API\AuthController;
|
||
use App\Http\Controllers\API\DivingOfferController;
|
||
use App\Http\Controllers\API\ProviderOfferController;
|
||
|
||
// 這裡可以定義 API 路由,例如:
|
||
Route::get('/ping', function () {
|
||
return response()->json(['message' => 'pong']);
|
||
});
|
||
|
||
// 潛水課程(公開)
|
||
Route::get('/diving-offers', [DivingOfferController::class, 'index']);
|
||
Route::get('/diving-offers/{id}', [DivingOfferController::class, 'show']);
|
||
|
||
// 你可以在這裡繼續新增 API 路由
|
||
Route::post('/testpost', function () {
|
||
$data = request()->all(); // 取得所有POST資料(array)
|
||
return response()->json([
|
||
'data' => $data,
|
||
]);
|
||
});
|
||
|
||
// 會員註冊/登入
|
||
Route::post('/member/register', [AuthController::class, 'registerMember']);
|
||
Route::post('/member/login', [AuthController::class, 'loginMember']);
|
||
|
||
// Google 第三方登入(僅會員)
|
||
Route::get('/auth/google/redirect', [\App\Http\Controllers\API\SocialAuthController::class, 'redirectToGoogle']);
|
||
Route::get('/auth/google/callback', [\App\Http\Controllers\API\SocialAuthController::class, 'handleGoogleCallback']);
|
||
|
||
// 會員專屬 API(需登入)
|
||
Route::middleware(['auth:sanctum'])->prefix('member')->group(function () {
|
||
// 會員登出
|
||
Route::post('/logout', [AuthController::class, 'logoutMember']);
|
||
// 取得會員個人資料
|
||
Route::get('/profile', [AuthController::class, 'memberProfile']);
|
||
// 更新會員個人資料
|
||
Route::put('/profile', [AuthController::class, 'updateMemberProfile']);
|
||
// 修改密碼
|
||
Route::put('/change-password', [AuthController::class, 'changeMemberPassword']);
|
||
// 你可以再加上訂單、收藏、通知等API
|
||
// Route::get('/orders', [OrderController::class, 'memberOrders']);
|
||
// Route::get('/favorites', [FavoriteController::class, 'memberFavorites']);
|
||
});
|
||
|
||
// 服務提供者註冊/登入
|
||
Route::post('/provider/register', [AuthController::class, 'registerProvider']);
|
||
Route::post('/provider/login', [AuthController::class, 'loginProvider']);
|
||
|
||
// 服務提供者專屬 API(需登入)
|
||
Route::middleware(['auth:sanctum'])->prefix('provider')->group(function () {
|
||
// 服務提供者登出
|
||
Route::post('/logout', [AuthController::class, 'logoutProvider']);
|
||
// 取得服務提供者資料
|
||
Route::get('/profile', [AuthController::class, 'providerProfile']);
|
||
// 更新服務提供者資料
|
||
Route::put('/profile', [AuthController::class, 'updateProviderProfile']);
|
||
// 修改密碼
|
||
Route::put('/change-password', [AuthController::class, 'changeProviderPassword']);
|
||
// 教練課程管理
|
||
Route::get('/offers', [ProviderOfferController::class, 'index']);
|
||
Route::post('/offers', [ProviderOfferController::class, 'store']);
|
||
Route::get('/offers/{id}', [ProviderOfferController::class, 'show']);
|
||
Route::put('/offers/{id}', [ProviderOfferController::class, 'update']);
|
||
Route::delete('/offers/{id}', [ProviderOfferController::class, 'destroy']);
|
||
});
|
||
|
||
// 管理員註冊/登入
|
||
Route::post('/admin/register', [AuthController::class, 'registerAdmin']);
|
||
Route::post('/admin/login', [AuthController::class, 'loginAdmin']);
|
||
|
||
// 管理員專屬 API(需登入)
|
||
Route::middleware(['auth:sanctum'])->prefix('admin')->group(function () {
|
||
// 管理員登出
|
||
Route::post('/logout', [AuthController::class, 'logoutAdmin']);
|
||
// 取得管理員個人資料
|
||
Route::get('/profile', [AuthController::class, 'adminProfile']);
|
||
// 更新管理員個人資料
|
||
Route::put('/profile', [AuthController::class, 'updateAdminProfile']);
|
||
// 修改密碼
|
||
Route::put('/change-password', [AuthController::class, 'changeAdminPassword']);
|
||
// 查詢會員資料
|
||
Route::get('/check-member/{id}', [AuthController::class, 'checkMember']);
|
||
// 查詢服務提供者資料
|
||
Route::get('/check-provider/{id}', [AuthController::class, 'checkProvider']);
|
||
// 其他管理員專屬 API
|
||
});
|
||
|
||
// 需要認證的通用路由
|
||
Route::middleware('auth:sanctum')->group(function () {
|
||
Route::post('/logout', [AuthController::class, 'logout']);
|
||
Route::get('/user', [AuthController::class, 'user']);
|
||
}); |