Files
awesome-app/app/api/webhook/route.ts
valknarness b63592f153 a new start
2025-10-25 16:09:02 +02:00

61 lines
1.7 KiB
TypeScript

import { NextRequest, NextResponse } from 'next/server';
import { createHmac } from 'crypto';
import { writeFileSync } from 'fs';
import { join } from 'path';
export const dynamic = 'force-dynamic';
// Verify webhook signature
function verifySignature(payload: string, signature: string, secret: string): boolean {
const hmac = createHmac('sha256', secret);
const digest = 'sha256=' + hmac.update(payload).digest('hex');
return digest === signature;
}
// Handle webhook from GitHub Actions
export async function POST(request: NextRequest) {
try {
const signature = request.headers.get('x-github-secret');
const body = await request.text();
// Verify signature if secret is configured
const webhookSecret = process.env.WEBHOOK_SECRET;
if (webhookSecret && signature) {
if (!verifySignature(body, signature, webhookSecret)) {
return NextResponse.json(
{ error: 'Invalid signature' },
{ status: 401 }
);
}
}
const data = JSON.parse(body);
console.log('📥 Webhook received:', {
version: data.version,
timestamp: data.timestamp,
lists: data.lists_count,
repos: data.repos_count,
});
// Save metadata
const metadataPath = join(process.cwd(), 'data', 'db-metadata.json');
writeFileSync(metadataPath, JSON.stringify(data, null, 2));
// TODO: Trigger database download from hosting
// const dbUrl = process.env.DB_URL;
// await downloadDatabase(dbUrl);
return NextResponse.json({
success: true,
message: 'Database metadata updated',
});
} catch (error) {
console.error('Webhook error:', error);
return NextResponse.json(
{ error: 'Webhook processing failed' },
{ status: 500 }
);
}
}