Vercel ai gateway (#7)
* feat: use vercel ai gateway * chore: update UI
This commit is contained in:
@@ -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,
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user