|
| 1 | +// src/app/api/fine-tune/model/train |
| 2 | +'use server'; |
| 3 | + |
| 4 | +import { NextResponse } from 'next/server'; |
| 5 | + |
| 6 | +export async function POST(request: Request) { |
| 7 | + try { |
| 8 | + console.log('Received train job request'); |
| 9 | + |
| 10 | + // Parse the request body for required data |
| 11 | + const { modelName, branchName } = await request.json(); |
| 12 | + const API_SERVER = process.env.NEXT_PUBLIC_API_SERVER!; |
| 13 | + |
| 14 | + console.log('Request body:', { modelName, branchName }); |
| 15 | + |
| 16 | + if (!modelName || !branchName) { |
| 17 | + console.error('Missing required parameters: modelName and branchName'); |
| 18 | + return NextResponse.json({ error: 'Missing required parameters: modelName and branchName' }, { status: 400 }); |
| 19 | + } |
| 20 | + |
| 21 | + // Forward the request to the API server |
| 22 | + const endpoint = `${API_SERVER}/model/train`; |
| 23 | + |
| 24 | + console.log(`Forwarding request to API server: ${API_SERVER}`); |
| 25 | + |
| 26 | + const response = await fetch(endpoint, { |
| 27 | + method: 'POST', |
| 28 | + headers: { |
| 29 | + 'Content-Type': 'application/json' |
| 30 | + }, |
| 31 | + body: JSON.stringify({ |
| 32 | + modelName, |
| 33 | + branchName |
| 34 | + }) |
| 35 | + }); |
| 36 | + |
| 37 | + console.log('Response from API server:', { |
| 38 | + status: response.status, |
| 39 | + statusText: response.statusText |
| 40 | + }); |
| 41 | + |
| 42 | + if (!response.ok) { |
| 43 | + console.error('Error response from API server:', response.status, response.statusText); |
| 44 | + return NextResponse.json({ error: 'Failed to train the model on the API server' }, { status: response.status }); |
| 45 | + } |
| 46 | + |
| 47 | + // Parse response safely |
| 48 | + let responseData; |
| 49 | + try { |
| 50 | + const text = await response.text(); |
| 51 | + responseData = text ? JSON.parse(text) : {}; |
| 52 | + console.log('Parsed response data:', responseData); |
| 53 | + } catch (error) { |
| 54 | + console.error('Error parsing JSON response from API server:', error); |
| 55 | + return NextResponse.json({ error: 'Invalid JSON response from the API server' }, { status: 500 }); |
| 56 | + } |
| 57 | + |
| 58 | + if (!responseData.job_id) { |
| 59 | + console.error('Missing job_id in API server response:', responseData); |
| 60 | + return NextResponse.json({ error: 'API server response does not contain job_id' }, { status: 500 }); |
| 61 | + } |
| 62 | + |
| 63 | + // Return the response from the API server to the client |
| 64 | + console.log('Returning success response with job_id:', responseData.job_id); |
| 65 | + return NextResponse.json(responseData, { status: 200 }); |
| 66 | + } catch (error) { |
| 67 | + console.error('Unexpected error during training:', error); |
| 68 | + return NextResponse.json({ error: 'An unexpected error occurred during training' }, { status: 500 }); |
| 69 | + } |
| 70 | +} |
0 commit comments