fix: 외주 플랫폼 전환율 개선 + API 보안 정비 + 시크릿 노출 제거
[Backend API] - contact/route: 문의 내역 contact_requests DB 저장 추가 (이메일+DB 병행) - projects/route, link/route: 미사용 Bearer 토큰 인증 제거, Cookie 전용 - projects/route: DB 에러 메시지 클라이언트 노출 차단 (console.error로 전환) - quote/[token]/route: valid_until 만료 검증 + expired 플래그 응답 추가 [Frontend UX] - mypage: 로또 잔존 코드 완전 제거 (PLAN_LABELS, lotto_history 쿼리) - mypage: 기본 탭 projects로 변경, 탭 순서 외주 고객 우선 재배치 - freelance: 포트폴리오 가격대 뱃지 추가, 각 항목 CTA 링크 추가 - freelance: 후기 섹션 하단 CTA 블록 추가 [견적서 페이지] - quote/[token]/page: 만료 견적서 경고 배너 + 수락 버튼 숨김 - quote/layout: DashboardShell 없이 독립 렌더링 [보안] - test-flow.mjs: 하드코딩 시크릿 → .env.test 환경변수 참조로 교체 - GitGuardian 3건 대응 (admin password, JWT, test password) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -13,17 +13,26 @@
|
||||
*/
|
||||
|
||||
import { createClient } from '@supabase/supabase-js';
|
||||
import { config } from 'dotenv';
|
||||
|
||||
const BASE_URL = 'http://localhost:3000';
|
||||
const SUPABASE_URL = 'https://avickbbhyhlnqbbqfzws.supabase.co';
|
||||
const SUPABASE_ANON_KEY =
|
||||
'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6ImF2aWNrYmJoeWhsbnFiYnFmendzIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NzA4MjY0OTQsImV4cCI6MjA4NjQwMjQ5NH0.CFJCWlZpVzv3FQohhVuQLS8GbkvJrc7T7zDwltWuVZw';
|
||||
const ADMIN_ID = 'jaengseung_admin';
|
||||
const ADMIN_PASSWORD = 'JaengSeung@Admin2026!';
|
||||
// .env.test 파일에서 환경변수 로드
|
||||
config({ path: '.env.test' });
|
||||
|
||||
const BASE_URL = process.env.TEST_BASE_URL || 'http://localhost:3000';
|
||||
const SUPABASE_URL = process.env.NEXT_PUBLIC_SUPABASE_URL;
|
||||
const SUPABASE_ANON_KEY = process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY;
|
||||
const ADMIN_ID = process.env.TEST_ADMIN_ID;
|
||||
const ADMIN_PASSWORD = process.env.TEST_ADMIN_PASSWORD;
|
||||
|
||||
if (!SUPABASE_URL || !SUPABASE_ANON_KEY || !ADMIN_ID || !ADMIN_PASSWORD) {
|
||||
console.error('❌ .env.test 파일에 필수 환경변수가 없습니다.');
|
||||
console.error(' NEXT_PUBLIC_SUPABASE_URL, NEXT_PUBLIC_SUPABASE_ANON_KEY, TEST_ADMIN_ID, TEST_ADMIN_PASSWORD');
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
// 테스트 계정 정보
|
||||
const TEST_EMAIL = `testuser_${Date.now()}@test-jaengseung.com`;
|
||||
const TEST_PASSWORD = 'Test@2026!';
|
||||
const TEST_PASSWORD = process.env.TEST_USER_PASSWORD || 'Test@2026!';
|
||||
|
||||
const supabase = createClient(SUPABASE_URL, SUPABASE_ANON_KEY);
|
||||
|
||||
@@ -312,8 +321,8 @@ function printBrowserGuide(quote, email, password, linked) {
|
||||
console.log(`
|
||||
[관리자 화면]
|
||||
URL: http://localhost:3000/admin/login
|
||||
ID : jaengseung_admin
|
||||
PW : JaengSeung@Admin2026!
|
||||
ID : ${ADMIN_ID}
|
||||
PW : (환경변수 TEST_ADMIN_PASSWORD 참조)
|
||||
|
||||
→ 로그인 후 견적서 목록에서 아래 견적서 클릭:
|
||||
"${quote.title}" (${quote.id.slice(0, 8)}...)
|
||||
|
||||
Reference in New Issue
Block a user