1import { NextRequest, NextResponse } from 'next/server';
2import { fieldpineServerApi } from '@/lib/server/fieldpineApi';
3import { getStoredAuth } from '@/lib/server/auth';
6 * OpenAPI Locations Endpoint
7 * Uses Fieldpine's OpenAPI2_RmSystem endpoints
8 * Documentation: https://docs.fieldpine.com/openapi/
10export async function GET(request: NextRequest) {
12 // Verify authentication
13 const authData = await getStoredAuth();
14 if (!authData || !authData.authenticated) {
15 return NextResponse.json(
16 { error: 'Authentication required' },
22 const clientId = request.headers.get('x-forwarded-for') ||
23 request.headers.get('x-real-ip') ||
26 if (!fieldpineServerApi.checkClientRateLimit(clientId)) {
27 return NextResponse.json(
28 { error: 'Rate limit exceeded' },
33 // Parse query parameters
34 const { searchParams } = new URL(request.url);
35 const params: Record<string, string | number> = {};
37 const limit = searchParams.get('limit');
38 if (limit) params.limit = parseInt(limit);
40 // Call Fieldpine OpenAPI directly (no BUCK fallback)
42 const locations = await fieldpineServerApi.apiCall("/Locations", {
44 cookie: authData.apiKey,
48 return NextResponse.json({
55 console.error('OpenAPI locations error:', error);
56 return NextResponse.json(
57 { error: 'OpenAPI endpoint unavailable', source: 'openapi' },
63 console.error('OpenAPI locations error:', error);
64 return NextResponse.json(
65 { error: 'Failed to fetch locations' },