mirror of
https://github.com/kikootwo/ReadMeABook.git
synced 2026-06-03 04:40:09 +00:00
682836237b
Replaces scattered console statements with a unified RMABLogger across backend API routes and services. Adds LOG_LEVEL-based filtering, job-aware database persistence, and context-based logging. Updates documentation to describe the new logging system and usage patterns. Also documents qBittorrent CSRF header fix
85 lines
2.3 KiB
TypeScript
85 lines
2.3 KiB
TypeScript
/**
|
|
* Component: Configuration API Routes
|
|
* Documentation: documentation/backend/services/config.md
|
|
*/
|
|
|
|
import { NextRequest, NextResponse } from 'next/server';
|
|
import { getConfigService, ConfigUpdate } from '@/lib/services/config.service';
|
|
import { z } from 'zod';
|
|
import { RMABLogger } from '@/lib/utils/logger';
|
|
|
|
const logger = RMABLogger.create('API.Config');
|
|
|
|
const ConfigUpdateSchema = z.object({
|
|
updates: z.array(
|
|
z.object({
|
|
key: z.string(),
|
|
value: z.string(),
|
|
encrypted: z.boolean().optional(),
|
|
category: z.string().optional(),
|
|
description: z.string().optional(),
|
|
})
|
|
),
|
|
});
|
|
|
|
// PUT /api/config - Update multiple configuration values
|
|
export async function PUT(request: NextRequest) {
|
|
try {
|
|
// TODO: Add authentication middleware - admin only
|
|
|
|
const body = await request.json();
|
|
const { updates } = ConfigUpdateSchema.parse(body);
|
|
|
|
const configService = getConfigService();
|
|
await configService.setMany(updates as ConfigUpdate[]);
|
|
|
|
return NextResponse.json({
|
|
success: true,
|
|
updated: updates.length,
|
|
});
|
|
} catch (error) {
|
|
logger.error('Failed to update configuration', { error: error instanceof Error ? error.message : String(error) });
|
|
|
|
if (error instanceof z.ZodError) {
|
|
return NextResponse.json(
|
|
{
|
|
error: 'Validation error',
|
|
details: error.errors,
|
|
},
|
|
{ status: 400 }
|
|
);
|
|
}
|
|
|
|
return NextResponse.json(
|
|
{
|
|
error: 'Failed to update configuration',
|
|
message: error instanceof Error ? error.message : 'Unknown error',
|
|
},
|
|
{ status: 500 }
|
|
);
|
|
}
|
|
}
|
|
|
|
// GET /api/config - Get all configuration (masked sensitive values)
|
|
export async function GET() {
|
|
try {
|
|
// TODO: Add authentication middleware - admin only
|
|
|
|
const configService = getConfigService();
|
|
const allConfig = await configService.getAll();
|
|
|
|
return NextResponse.json({
|
|
config: allConfig,
|
|
});
|
|
} catch (error) {
|
|
logger.error('Failed to get all configuration', { error: error instanceof Error ? error.message : String(error) });
|
|
return NextResponse.json(
|
|
{
|
|
error: 'Failed to get configuration',
|
|
message: error instanceof Error ? error.message : 'Unknown error',
|
|
},
|
|
{ status: 500 }
|
|
);
|
|
}
|
|
}
|