EverydayTech Platform - Developer Reference
Complete Source Code Documentation - All Applications
Loading...
Searching...
No Matches
route.ts
Go to the documentation of this file.
1import { NextRequest, NextResponse } from 'next/server';
2import { fieldpineServerApi } from '@/lib/server/fieldpineApi';
3import { getStoredAuth } from '@/lib/server/auth';
4
5/**
6 * OpenAPI SupplierMarketingMessages Endpoint
7 * GET /api/v1/openapi/supplier-marketing-messages
8 * List current marketing messages from suppliers
9 */
10export async function GET(request: NextRequest) {
11 try {
12 const authData = await getStoredAuth();
13 if (!authData || !authData.authenticated) {
14 return NextResponse.json(
15 { error: 'Authentication required' },
16 { status: 401 }
17 );
18 }
19
20 const { searchParams } = new URL(request.url);
21 const params: Record<string, string | number> = {};
22
23 const spid = searchParams.get('spid');
24 if (spid) params.spid = parseInt(spid);
25
26 const from = searchParams.get('from');
27 if (from) params.from = from;
28
29 const to = searchParams.get('to');
30 if (to) params.to = to;
31
32 const pid = searchParams.get('pid');
33 if (pid) params.pid = parseInt(pid);
34
35 const messages = await fieldpineServerApi.apiCall("/SupplierMarketingMessages", {
36 params,
37 cookie: authData.apiKey,
38 useOpenApi: true
39 });
40
41 return NextResponse.json({
42 success: true,
43 data: messages,
44 source: 'openapi'
45 });
46
47 } catch (error) {
48 console.error('SupplierMarketingMessages API error:', error);
49 return NextResponse.json(
50 { error: 'Failed to fetch supplier marketing messages' },
51 { status: 500 }
52 );
53 }
54}