summaryrefslogtreecommitdiff
path: root/app/api/nonsap-sync/cron/route.ts
diff options
context:
space:
mode:
Diffstat (limited to 'app/api/nonsap-sync/cron/route.ts')
-rw-r--r--app/api/nonsap-sync/cron/route.ts41
1 files changed, 41 insertions, 0 deletions
diff --git a/app/api/nonsap-sync/cron/route.ts b/app/api/nonsap-sync/cron/route.ts
new file mode 100644
index 00000000..80944280
--- /dev/null
+++ b/app/api/nonsap-sync/cron/route.ts
@@ -0,0 +1,41 @@
+import { NextRequest, NextResponse } from 'next/server';
+
+export async function GET(request: NextRequest) {
+ try {
+ // 인증 확인 (선택적)
+ const authToken = process.env.CRON_AUTH_TOKEN;
+ if (authToken) {
+ const providedToken = new URL(request.url).searchParams.get('token');
+ if (providedToken !== authToken) {
+ return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
+ }
+ }
+
+ // 동적 import로 cron 스케줄러 호출
+ const { triggerEnhancedSync } = await import('../../../../lib/nonsap-sync/enhanced-sync-service');
+
+ // 백그라운드에서 동기화 실행
+ triggerEnhancedSync().catch(error => {
+ console.error('Cron sync failed:', error);
+ });
+
+ return NextResponse.json({
+ success: true,
+ message: 'NONSAP sync triggered via cron endpoint',
+ timestamp: new Date().toISOString()
+ });
+ } catch (error) {
+ console.error('Cron endpoint error:', error);
+
+ return NextResponse.json({
+ success: false,
+ error: 'Failed to trigger sync',
+ timestamp: new Date().toISOString()
+ }, { status: 500 });
+ }
+}
+
+export async function POST() {
+ // POST 요청도 동일하게 처리
+ return GET();
+} \ No newline at end of file