diff options
| author | joonhoekim <26rote@gmail.com> | 2025-11-06 18:59:58 +0900 |
|---|---|---|
| committer | joonhoekim <26rote@gmail.com> | 2025-11-06 18:59:58 +0900 |
| commit | 1b843e0a7ea55c64992f55033b30037239ff67f5 (patch) | |
| tree | 7b64d320eebc7c540a82d1a74fb67ba682b7a6a5 /lib/vendors/service.ts | |
| parent | a4bf0d8376962c922da90cd08781893a3658ecc2 (diff) | |
(김준회) request context가 없는 한계에 따라 revalidate를 api 구조로 수정, API 시크릿 환경변수 추가, 공통 컴포넌트 생성, request context 요구하는 코드 수정
Diffstat (limited to 'lib/vendors/service.ts')
| -rw-r--r-- | lib/vendors/service.ts | 31 |
1 files changed, 13 insertions, 18 deletions
diff --git a/lib/vendors/service.ts b/lib/vendors/service.ts index 76193eb9..6454bc7b 100644 --- a/lib/vendors/service.ts +++ b/lib/vendors/service.ts @@ -1772,10 +1772,8 @@ export async function approveVendors(input: ApproveVendorsInput & { userId: numb ? "[eVCP] 업체 승인 완료 - 계정 활성화" : "[eVCP] Vendor Approved - Account Activated"; - const headersList = await headers(); - const host = headersList.get('host') || 'localhost:3000'; - const protocol = headersList.get('x-forwarded-proto') || 'http'; - const baseUrl = `${protocol}://${host}`; + // ✅ Request Context가 없을 수 있으므로 환경변수 사용 + const baseUrl = process.env.NEXT_PUBLIC_BASE_URL || 'http://localhost:3000'; const loginUrl = `${baseUrl}/${userLang}/login`; const passwordSetupUrl = `${baseUrl}/${userLang}/auth/reset-password?token=${resetToken}`; // 패스워드 설정 URL @@ -1804,12 +1802,9 @@ export async function approveVendors(input: ApproveVendorsInput & { userId: numb return updated; }); - // 캐시 무효화 - revalidateTag("vendors"); - revalidateTag("vendor-status-counts"); - revalidateTag("users"); // 유저 캐시도 무효화 - revalidateTag("roles"); // 역할 캐시도 무효화 - revalidateTag("user-roles"); // 유저 역할 캐시도 무효화 + // ✅ 캐시 무효화 (cronjob에서도 작동하도록 API 사용) + const { revalidateApprovalRelatedCaches } = await import('@/lib/revalidation-utils'); + await revalidateApprovalRelatedCaches(); return { data: result, error: null }; } catch (err) { @@ -1933,10 +1928,8 @@ export async function rejectVendors(input: ApproveVendorsInput & { userId: numbe ? "[eVCP] 업체 등록 거절 안내" : "[eVCP] Vendor Registration Rejected"; - const headersList = await headers(); - const host = headersList.get('host') || 'localhost:3000'; - const protocol = headersList.get('x-forwarded-proto') || 'http'; - const baseUrl = `${protocol}://${host}`; + // ✅ Request Context가 없을 수 있으므로 환경변수 사용 + const baseUrl = process.env.NEXT_PUBLIC_BASE_URL || 'http://localhost:3000'; const loginUrl = `${baseUrl}/${userLang}/login`; await sendEmail({ @@ -1962,10 +1955,12 @@ export async function rejectVendors(input: ApproveVendorsInput & { userId: numbe return updated; }); - // 캐시 무효화 - revalidateTag("vendors"); - revalidateTag("vendor-status-counts"); - revalidateTag("users"); // 유저 캐시도 무효화 + // ✅ 캐시 무효화 (cronjob에서도 작동하도록 API 사용) + const { revalidateVendorCaches, revalidateUserCaches } = await import('@/lib/revalidation-utils'); + await Promise.all([ + revalidateVendorCaches(), + revalidateUserCaches(), + ]); return { data: result, error: null }; } catch (err) { |
