Vercel ai gateway (#7)

* feat: use vercel ai gateway

* chore: update UI
This commit is contained in:
2025-10-11 12:15:30 +02:00
committed by GitHub
parent ff84b75847
commit 7c9635ba83
14 changed files with 2348 additions and 1809 deletions

View File

@@ -3,16 +3,35 @@ 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.errors
errors: result.error.issues
},
{ status: 400 }
);
@@ -22,6 +41,9 @@ export async function POST(req: Request) {
const isValid = shortcutsHandler.validateRequest(result.data);
if (!isValid) {
console.warn(
`[${requestId}] Unauthorized request for command: ${result.data.command}`
);
return NextResponse.json(
{
success: false,
@@ -31,14 +53,25 @@ export async function POST(req: Request) {
);
}
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) {
console.error('Error processing shortcuts request:', error);
const duration = Date.now() - startTime;
console.error(
`[${requestId}] Error processing request after ${duration}ms:`,
error
);
return NextResponse.json(
{
success: false,

View File

@@ -1,15 +1,12 @@
import type { Metadata } from 'next';
import { ReactNode } from 'react';
export const metadata: Metadata = {
title: 'DiaryWhisper',
description: 'Siri-enabled diary tracker for expenses and day logs'
};
export default function RootLayout({
children
}: {
children: React.ReactNode;
}) {
export default function RootLayout({ children }: { children: ReactNode }) {
return (
<html lang='en'>
<body>{children}</body>

View File

@@ -7,7 +7,7 @@ export default function Home() {
<>
<div className='container'>
<div className='header'>
<h1>Siri Shortcuts v1.0.0</h1>
<h1>Siri Shortcuts v1.1.0</h1>
<p>Anthropic-based power up for Siri Shortcuts</p>
</div>
@@ -20,7 +20,7 @@ export default function Home() {
<div className='status'>
<span>Status: OPERATIONAL</span>
<span>Last Backup: 2024-01-18 14:30 UTC</span>
<span>Last Backup: 2025-10-11 10:00 UTC</span>
</div>
</div>