2025-11-20 16:24:40 +09:00
|
|
|
<?php
|
|
|
|
|
|
2025-11-26 22:23:37 +09:00
|
|
|
use App\Http\Controllers\ArchivedRecordController;
|
2025-11-20 16:24:40 +09:00
|
|
|
use App\Http\Controllers\Auth\LoginController;
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
use App\Http\Controllers\BoardController;
|
2025-12-01 23:44:56 +09:00
|
|
|
use App\Http\Controllers\DailyLogController;
|
2025-11-24 16:52:23 +09:00
|
|
|
use App\Http\Controllers\DepartmentController;
|
2025-11-27 19:02:18 +09:00
|
|
|
use App\Http\Controllers\DevTools\FlowTesterController;
|
2025-11-24 22:02:09 +09:00
|
|
|
use App\Http\Controllers\MenuController;
|
2025-11-25 11:05:57 +09:00
|
|
|
use App\Http\Controllers\PermissionController;
|
2025-12-01 23:44:56 +09:00
|
|
|
use App\Http\Controllers\PostController;
|
|
|
|
|
use App\Http\Controllers\ProfileController;
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
use App\Http\Controllers\ProjectManagementController;
|
feat(quote-formulas): 견적수식 관리 기능 구현
## 구현 내용
### 모델 (5개)
- QuoteFormulaCategory: 수식 카테고리
- QuoteFormula: 수식 정의 (input/calculation/range/mapping)
- QuoteFormulaRange: 범위별 값 정의
- QuoteFormulaMapping: 매핑 테이블
- QuoteFormulaItem: 수식-품목 연결
### 서비스 (3개)
- QuoteFormulaCategoryService: 카테고리 CRUD
- QuoteFormulaService: 수식 CRUD, 복제, 재정렬
- FormulaEvaluatorService: 수식 계산 엔진
- 지원 함수: SUM, ROUND, CEIL, FLOOR, ABS, MIN, MAX, IF, AND, OR, NOT
### API Controller (2개)
- QuoteFormulaCategoryController: 카테고리 API (11개 엔드포인트)
- QuoteFormulaController: 수식 API (16개 엔드포인트)
### FormRequest (4개)
- Store/Update QuoteFormulaCategoryRequest
- Store/Update QuoteFormulaRequest
### Blade Views (8개)
- 수식 목록/추가/수정/시뮬레이터
- 카테고리 목록/추가/수정
- HTMX 테이블 partial
### 라우트
- API: 27개 엔드포인트
- Web: 7개 라우트
2025-12-04 14:00:24 +09:00
|
|
|
use App\Http\Controllers\QuoteFormulaController;
|
2025-11-24 16:36:02 +09:00
|
|
|
use App\Http\Controllers\RoleController;
|
2025-11-25 15:21:48 +09:00
|
|
|
use App\Http\Controllers\RolePermissionController;
|
2025-11-21 09:18:19 +09:00
|
|
|
use App\Http\Controllers\TenantController;
|
2025-12-09 23:13:27 +09:00
|
|
|
use App\Http\Controllers\ItemFieldController;
|
2025-12-13 23:41:08 +09:00
|
|
|
use App\Http\Controllers\Lab\StrategyController;
|
2025-11-24 18:49:02 +09:00
|
|
|
use App\Http\Controllers\UserController;
|
2025-11-20 16:24:40 +09:00
|
|
|
use Illuminate\Support\Facades\Route;
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Guest Routes (인증 불필요)
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
Route::middleware('guest')->group(function () {
|
|
|
|
|
Route::get('/login', [LoginController::class, 'showLoginForm'])->name('login');
|
|
|
|
|
Route::post('/login', [LoginController::class, 'login']);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Authenticated Routes (인증 필요)
|
|
|
|
|
|--------------------------------------------------------------------------
|
2025-11-30 21:05:13 +09:00
|
|
|
| - auth: 기본 인증 확인
|
|
|
|
|
| - hq.member: 본사(HQ) 테넌트 소속 확인
|
2025-11-20 16:24:40 +09:00
|
|
|
*/
|
|
|
|
|
|
2025-12-01 23:44:56 +09:00
|
|
|
Route::middleware(['auth', 'hq.member', 'password.changed'])->group(function () {
|
2025-11-20 16:24:40 +09:00
|
|
|
Route::post('/logout', [LoginController::class, 'logout'])->name('logout');
|
|
|
|
|
|
2025-11-21 09:18:19 +09:00
|
|
|
// 테넌트 전환
|
|
|
|
|
Route::post('/tenant/switch', [TenantController::class, 'switch'])->name('tenant.switch');
|
|
|
|
|
|
2025-12-01 23:12:59 +09:00
|
|
|
// 프로필 설정
|
|
|
|
|
Route::prefix('profile')->name('profile.')->group(function () {
|
|
|
|
|
Route::get('/', [ProfileController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/update', [ProfileController::class, 'update'])->name('update');
|
|
|
|
|
Route::post('/password', [ProfileController::class, 'changePassword'])->name('password');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-21 15:00:30 +09:00
|
|
|
// 테넌트 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('tenants')->name('tenants.')->group(function () {
|
|
|
|
|
Route::get('/', [TenantController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [TenantController::class, 'create'])->name('create');
|
|
|
|
|
Route::get('/{id}/edit', [TenantController::class, 'edit'])->name('edit');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-24 16:36:02 +09:00
|
|
|
// 역할 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('roles')->name('roles.')->group(function () {
|
|
|
|
|
Route::get('/', [RoleController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [RoleController::class, 'create'])->name('create');
|
|
|
|
|
Route::get('/{id}/edit', [RoleController::class, 'edit'])->name('edit');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-24 16:52:23 +09:00
|
|
|
// 부서 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('departments')->name('departments.')->group(function () {
|
|
|
|
|
Route::get('/', [DepartmentController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [DepartmentController::class, 'create'])->name('create');
|
|
|
|
|
Route::get('/{id}/edit', [DepartmentController::class, 'edit'])->name('edit');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-24 18:49:02 +09:00
|
|
|
// 사용자 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('users')->name('users.')->group(function () {
|
|
|
|
|
Route::get('/', [UserController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [UserController::class, 'create'])->name('create');
|
|
|
|
|
Route::get('/{id}/edit', [UserController::class, 'edit'])->name('edit');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-24 22:02:09 +09:00
|
|
|
// 메뉴 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('menus')->name('menus.')->group(function () {
|
|
|
|
|
Route::get('/', [MenuController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [MenuController::class, 'create'])->name('create');
|
|
|
|
|
Route::get('/{id}/edit', [MenuController::class, 'edit'])->name('edit');
|
2025-12-02 21:41:15 +09:00
|
|
|
|
|
|
|
|
// 글로벌 메뉴 관리 (슈퍼관리자 전용)
|
|
|
|
|
Route::get('/global', [MenuController::class, 'globalIndex'])->name('global.index');
|
|
|
|
|
Route::get('/global/create', [MenuController::class, 'globalCreate'])->name('global.create');
|
|
|
|
|
Route::get('/global/{id}/edit', [MenuController::class, 'globalEdit'])->name('global.edit');
|
2025-11-24 22:02:09 +09:00
|
|
|
});
|
|
|
|
|
|
2025-11-25 11:05:57 +09:00
|
|
|
// 권한 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('permissions')->name('permissions.')->group(function () {
|
|
|
|
|
Route::get('/', [PermissionController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [PermissionController::class, 'create'])->name('create');
|
|
|
|
|
Route::get('/{id}/edit', [PermissionController::class, 'edit'])->name('edit');
|
|
|
|
|
});
|
|
|
|
|
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
// 시스템 게시판 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('boards')->name('boards.')->group(function () {
|
|
|
|
|
Route::get('/', [BoardController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [BoardController::class, 'create'])->name('create');
|
|
|
|
|
Route::get('/{id}/edit', [BoardController::class, 'edit'])->name('edit');
|
2025-12-01 23:44:56 +09:00
|
|
|
|
|
|
|
|
// 게시글 CRUD (board 하위 중첩 라우트)
|
|
|
|
|
Route::prefix('{board}/posts')->name('posts.')->group(function () {
|
|
|
|
|
Route::get('/', [PostController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [PostController::class, 'create'])->name('create');
|
|
|
|
|
Route::post('/', [PostController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{post}', [PostController::class, 'show'])->name('show');
|
|
|
|
|
Route::get('/{post}/edit', [PostController::class, 'edit'])->name('edit');
|
|
|
|
|
Route::put('/{post}', [PostController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{post}', [PostController::class, 'destroy'])->name('destroy');
|
2025-12-02 00:53:25 +09:00
|
|
|
|
|
|
|
|
// 파일 관리
|
|
|
|
|
Route::prefix('{post}/files')->name('files.')->group(function () {
|
|
|
|
|
Route::get('/{fileId}/download', [PostController::class, 'downloadFile'])->name('download');
|
|
|
|
|
Route::post('/', [PostController::class, 'uploadFiles'])->name('upload');
|
|
|
|
|
Route::delete('/{fileId}', [PostController::class, 'deleteFile'])->name('delete');
|
|
|
|
|
});
|
2025-12-01 23:44:56 +09:00
|
|
|
});
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
});
|
|
|
|
|
|
2025-11-25 15:21:48 +09:00
|
|
|
// 역할 권한 관리 (Blade 화면만)
|
|
|
|
|
Route::get('/role-permissions', [RolePermissionController::class, 'index'])->name('role-permissions.index');
|
|
|
|
|
|
2025-11-25 15:32:58 +09:00
|
|
|
// 부서 권한 관리 (Blade 화면만)
|
|
|
|
|
Route::get('/department-permissions', [\App\Http\Controllers\DepartmentPermissionController::class, 'index'])->name('department-permissions.index');
|
|
|
|
|
|
2025-11-26 20:40:54 +09:00
|
|
|
// 개인 권한 관리 (Blade 화면만)
|
|
|
|
|
Route::get('/user-permissions', [\App\Http\Controllers\UserPermissionController::class, 'index'])->name('user-permissions.index');
|
|
|
|
|
|
2025-11-26 21:42:51 +09:00
|
|
|
// 권한 분석 (Blade 화면만)
|
|
|
|
|
Route::get('/permission-analyze', [\App\Http\Controllers\PermissionAnalyzeController::class, 'index'])->name('permission-analyze.index');
|
|
|
|
|
|
2025-11-26 22:23:37 +09:00
|
|
|
// 삭제된 데이터 백업 (Blade 화면만)
|
|
|
|
|
Route::prefix('archived-records')->name('archived-records.')->group(function () {
|
|
|
|
|
Route::get('/', [ArchivedRecordController::class, 'index'])->name('index');
|
2025-11-26 23:16:39 +09:00
|
|
|
Route::get('/{batchId}', [ArchivedRecordController::class, 'show'])->name('show');
|
2025-12-01 00:43:58 +09:00
|
|
|
Route::get('/{batchId}/restore-check', [ArchivedRecordController::class, 'checkRestore'])->name('restore-check');
|
|
|
|
|
Route::post('/{batchId}/restore', [ArchivedRecordController::class, 'restore'])->name('restore');
|
2025-11-26 22:23:37 +09:00
|
|
|
});
|
|
|
|
|
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
// 프로젝트 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('project-management')->name('pm.')->group(function () {
|
|
|
|
|
// 대시보드
|
|
|
|
|
Route::get('/', [ProjectManagementController::class, 'index'])->name('index');
|
|
|
|
|
|
|
|
|
|
// 프로젝트
|
|
|
|
|
Route::get('/projects', [ProjectManagementController::class, 'projects'])->name('projects.index');
|
|
|
|
|
Route::get('/projects/create', [ProjectManagementController::class, 'createProject'])->name('projects.create');
|
|
|
|
|
Route::get('/projects/{id}', [ProjectManagementController::class, 'showProject'])->name('projects.show');
|
|
|
|
|
Route::get('/projects/{id}/edit', [ProjectManagementController::class, 'editProject'])->name('projects.edit');
|
|
|
|
|
|
|
|
|
|
// JSON Import
|
|
|
|
|
Route::get('/import', [ProjectManagementController::class, 'import'])->name('import');
|
|
|
|
|
});
|
|
|
|
|
|
feat: [daily-logs] 일일 스크럼 기능 구현
주요 기능:
- 일일 로그 CRUD (생성, 조회, 수정, 삭제, 복원, 영구삭제)
- 로그 항목(Entry) 관리 (추가, 상태변경, 삭제, 순서변경)
- 주간 타임라인 (최근 7일 진행률 표시)
- 테이블 리스트 아코디언 상세보기
- 담당자 자동완성 (일반 사용자는 슈퍼관리자 목록 제외)
- HTMX 기반 동적 테이블 로딩 및 필터링
- Soft Delete 지원
파일 추가:
- Models: AdminPmDailyLog, AdminPmDailyLogEntry
- Controllers: DailyLogController (Web, API)
- Service: DailyLogService
- Requests: StoreDailyLogRequest, UpdateDailyLogRequest
- Views: index, show, table partial, modal-form partial
라우트 추가:
- Web: /daily-logs, /daily-logs/today, /daily-logs/{id}
- API: /api/admin/daily-logs/* (CRUD + 항목관리)
2025-12-01 14:07:55 +09:00
|
|
|
// 일일 스크럼 (Blade 화면만)
|
|
|
|
|
Route::prefix('daily-logs')->name('daily-logs.')->group(function () {
|
|
|
|
|
Route::get('/', [DailyLogController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/today', [DailyLogController::class, 'today'])->name('today');
|
|
|
|
|
Route::get('/{id}', [DailyLogController::class, 'show'])->name('show');
|
|
|
|
|
});
|
|
|
|
|
|
2025-12-09 23:13:27 +09:00
|
|
|
// 품목기준 필드 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('item-fields')->name('item-fields.')->group(function () {
|
|
|
|
|
Route::get('/', [ItemFieldController::class, 'index'])->name('index');
|
|
|
|
|
});
|
|
|
|
|
|
feat(quote-formulas): 견적수식 관리 기능 구현
## 구현 내용
### 모델 (5개)
- QuoteFormulaCategory: 수식 카테고리
- QuoteFormula: 수식 정의 (input/calculation/range/mapping)
- QuoteFormulaRange: 범위별 값 정의
- QuoteFormulaMapping: 매핑 테이블
- QuoteFormulaItem: 수식-품목 연결
### 서비스 (3개)
- QuoteFormulaCategoryService: 카테고리 CRUD
- QuoteFormulaService: 수식 CRUD, 복제, 재정렬
- FormulaEvaluatorService: 수식 계산 엔진
- 지원 함수: SUM, ROUND, CEIL, FLOOR, ABS, MIN, MAX, IF, AND, OR, NOT
### API Controller (2개)
- QuoteFormulaCategoryController: 카테고리 API (11개 엔드포인트)
- QuoteFormulaController: 수식 API (16개 엔드포인트)
### FormRequest (4개)
- Store/Update QuoteFormulaCategoryRequest
- Store/Update QuoteFormulaRequest
### Blade Views (8개)
- 수식 목록/추가/수정/시뮬레이터
- 카테고리 목록/추가/수정
- HTMX 테이블 partial
### 라우트
- API: 27개 엔드포인트
- Web: 7개 라우트
2025-12-04 14:00:24 +09:00
|
|
|
// 견적수식 관리 (Blade 화면만)
|
|
|
|
|
Route::prefix('quote-formulas')->name('quote-formulas.')->group(function () {
|
|
|
|
|
// 수식 관리
|
|
|
|
|
Route::get('/', [QuoteFormulaController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [QuoteFormulaController::class, 'create'])->name('create');
|
|
|
|
|
Route::get('/{id}/edit', [QuoteFormulaController::class, 'edit'])->name('edit');
|
|
|
|
|
|
|
|
|
|
// 카테고리 관리
|
|
|
|
|
Route::get('/categories', [QuoteFormulaController::class, 'categories'])->name('categories.index');
|
|
|
|
|
Route::get('/categories/create', [QuoteFormulaController::class, 'createCategory'])->name('categories.create');
|
|
|
|
|
Route::get('/categories/{id}/edit', [QuoteFormulaController::class, 'editCategory'])->name('categories.edit');
|
|
|
|
|
|
|
|
|
|
// 시뮬레이터
|
|
|
|
|
Route::get('/simulator', [QuoteFormulaController::class, 'simulator'])->name('simulator');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-21 15:00:30 +09:00
|
|
|
// 대시보드
|
2025-11-20 16:24:40 +09:00
|
|
|
Route::get('/dashboard', function () {
|
|
|
|
|
return view('dashboard.index');
|
|
|
|
|
})->name('dashboard');
|
|
|
|
|
|
|
|
|
|
// 루트 리다이렉트
|
|
|
|
|
Route::get('/', function () {
|
|
|
|
|
return redirect()->route('dashboard');
|
|
|
|
|
});
|
2025-11-27 19:02:18 +09:00
|
|
|
|
2025-12-13 23:41:08 +09:00
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| 실험실 Routes (5130 마이그레이션)
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
Route::prefix('lab')->name('lab.')->group(function () {
|
|
|
|
|
// S. 전략 (Strategy)
|
|
|
|
|
Route::prefix('strategy')->name('strategy.')->group(function () {
|
|
|
|
|
Route::get('/tax', [StrategyController::class, 'tax'])->name('tax');
|
|
|
|
|
Route::get('/labor', [StrategyController::class, 'labor'])->name('labor');
|
|
|
|
|
Route::get('/debt', [StrategyController::class, 'debt'])->name('debt');
|
|
|
|
|
Route::get('/stablecoin', [StrategyController::class, 'stablecoin'])->name('stablecoin');
|
|
|
|
|
Route::get('/mrp-overseas', [StrategyController::class, 'mrpOverseas'])->name('mrp-overseas');
|
|
|
|
|
Route::get('/chatbot', [StrategyController::class, 'chatbot'])->name('chatbot');
|
|
|
|
|
Route::get('/kodata-vs-nice', [StrategyController::class, 'kodataVsNice'])->name('kodata-vs-nice');
|
|
|
|
|
Route::get('/barobill-vs-popbill', [StrategyController::class, 'barobillVsPopbill'])->name('barobill-vs-popbill');
|
|
|
|
|
Route::get('/knowledge-search', [StrategyController::class, 'knowledgeSearch'])->name('knowledge-search');
|
|
|
|
|
Route::get('/chatbot-compare', [StrategyController::class, 'chatbotCompare'])->name('chatbot-compare');
|
|
|
|
|
Route::get('/rag-startups', [StrategyController::class, 'ragStartups'])->name('rag-startups');
|
|
|
|
|
Route::get('/douzone', [StrategyController::class, 'douzone'])->name('douzone');
|
|
|
|
|
Route::get('/confluence-vs-notion', [StrategyController::class, 'confluenceVsNotion'])->name('confluence-vs-notion');
|
|
|
|
|
Route::get('/qa-solution', [StrategyController::class, 'qaSolution'])->name('qa-solution');
|
|
|
|
|
Route::get('/sales-strategy', [StrategyController::class, 'salesStrategy'])->name('sales-strategy');
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-27 19:02:18 +09:00
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| 개발 도구 Routes
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
Route::prefix('dev-tools')->name('dev-tools.')->group(function () {
|
|
|
|
|
// API 플로우 테스터
|
|
|
|
|
Route::prefix('flow-tester')->name('flow-tester.')->group(function () {
|
2025-12-03 16:47:57 +09:00
|
|
|
// 고정 경로 먼저 (구체적인 경로)
|
2025-11-27 19:02:18 +09:00
|
|
|
Route::get('/', [FlowTesterController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/create', [FlowTesterController::class, 'create'])->name('create');
|
|
|
|
|
Route::post('/', [FlowTesterController::class, 'store'])->name('store');
|
2025-12-03 16:47:57 +09:00
|
|
|
Route::post('/validate-json', [FlowTesterController::class, 'validateJson'])->name('validate-json');
|
|
|
|
|
|
|
|
|
|
// /runs/* 관련 라우트 (고정 경로)
|
|
|
|
|
Route::get('/runs/{runId}/status', [FlowTesterController::class, 'runStatus'])->name('run-status');
|
|
|
|
|
Route::get('/runs/{runId}', [FlowTesterController::class, 'runDetail'])->name('run-detail');
|
|
|
|
|
|
|
|
|
|
// /{id}/* 관련 라우트 (와일드카드는 마지막에)
|
2025-11-27 19:02:18 +09:00
|
|
|
Route::get('/{id}', [FlowTesterController::class, 'edit'])->name('edit');
|
|
|
|
|
Route::put('/{id}', [FlowTesterController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [FlowTesterController::class, 'destroy'])->name('destroy');
|
|
|
|
|
Route::post('/{id}/clone', [FlowTesterController::class, 'clone'])->name('clone');
|
|
|
|
|
Route::post('/{id}/run', [FlowTesterController::class, 'run'])->name('run');
|
|
|
|
|
Route::get('/{id}/history', [FlowTesterController::class, 'history'])->name('history');
|
|
|
|
|
});
|
|
|
|
|
});
|
2025-11-20 16:24:40 +09:00
|
|
|
});
|