This repository has been archived on 2026-02-01. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
siri-shortcuts/app/api/shortcut/route.ts
Riccardo Senica 7c9635ba83 Vercel ai gateway (#7)
* feat: use vercel ai gateway

* chore: update UI
2025-10-11 12:15:30 +02:00

84 lines
2.2 KiB
TypeScript

import { NextResponse } from 'next/server';
import { ShortcutsHandler } from '@utils/handler';
import { RequestSchema } from '@utils/types';
export async function POST(req: Request) {
const requestId = Math.random().toString(36).substring(7);
const startTime = Date.now();
console.info(
`[${requestId}] Incoming request at ${new Date().toISOString()}`
);
try {
const body = await req.json();
console.info(`[${requestId}] Request body:`, {
command: body.command,
hasParameters: !!body.parameters,
parametersCount: body.parameters
? Object.keys(body.parameters).length
: 0,
hasApiKey: !!body.apiKey
});
const result = RequestSchema.safeParse(body);
if (!result.success) {
console.warn(
`[${requestId}] Invalid request format:`,
result.error.issues
);
return NextResponse.json(
{
success: false,
message: 'Invalid request format.',
errors: result.error.issues
},
{ status: 400 }
);
}
const shortcutsHandler = new ShortcutsHandler();
const isValid = shortcutsHandler.validateRequest(result.data);
if (!isValid) {
console.warn(
`[${requestId}] Unauthorized request for command: ${result.data.command}`
);
return NextResponse.json(
{
success: false,
message: 'Unauthorized.'
},
{ status: 401 }
);
}
console.info(`[${requestId}] Processing command: ${result.data.command}`);
const response = await shortcutsHandler.processCommand(
result.data.command,
result.data.parameters
);
const duration = Date.now() - startTime;
console.info(`[${requestId}] Request completed in ${duration}ms`, {
success: response.success,
hasData: !!response.data
});
return NextResponse.json(response);
} catch (error) {
const duration = Date.now() - startTime;
console.error(
`[${requestId}] Error processing request after ${duration}ms:`,
error
);
return NextResponse.json(
{
success: false,
message: 'An error occurred while processing your request.'
},
{ status: 500 }
);
}
}