Save workspace changes
This commit is contained in:
@@ -31,14 +31,24 @@ final class StudioArtworkAiAssistApiController extends Controller
|
||||
public function analyze(Request $request, int $id): JsonResponse
|
||||
{
|
||||
$artwork = $request->user()->artworks()->with(['tags', 'categories.contentType'])->findOrFail($id);
|
||||
$direct = (bool) $request->boolean('direct');
|
||||
$intent = $request->validate([
|
||||
$payload = $request->validate([
|
||||
'direct' => ['sometimes', 'boolean'],
|
||||
'intent' => ['sometimes', 'nullable', 'string', 'in:analyze,title,description,tags,category,similar'],
|
||||
])['intent'] ?? null;
|
||||
'provider' => ['sometimes', 'nullable', 'string'],
|
||||
]);
|
||||
$direct = (bool) ($payload['direct'] ?? false);
|
||||
$intent = $payload['intent'] ?? null;
|
||||
$provider = $this->normalizeProviderOption($payload['provider'] ?? null);
|
||||
|
||||
if ($provider === null && array_key_exists('provider', $payload) && $payload['provider'] !== null) {
|
||||
return response()->json([
|
||||
'success' => false,
|
||||
'message' => 'Invalid provider. Supported values: lm_studio, together.',
|
||||
], 422);
|
||||
}
|
||||
|
||||
if ($direct) {
|
||||
$assist = $this->aiAssist->analyzeDirect($artwork, false, $intent);
|
||||
$assist = $this->aiAssist->analyzeDirect($artwork, false, $intent, $provider);
|
||||
|
||||
return response()->json([
|
||||
'success' => true,
|
||||
@@ -48,7 +58,7 @@ final class StudioArtworkAiAssistApiController extends Controller
|
||||
]);
|
||||
}
|
||||
|
||||
$assist = $this->aiAssist->queueAnalysis($artwork, false, $intent);
|
||||
$assist = $this->aiAssist->queueAnalysis($artwork, false, $intent, $provider);
|
||||
|
||||
return response()->json([
|
||||
'success' => true,
|
||||
@@ -60,14 +70,24 @@ final class StudioArtworkAiAssistApiController extends Controller
|
||||
public function regenerate(Request $request, int $id): JsonResponse
|
||||
{
|
||||
$artwork = $request->user()->artworks()->with(['tags', 'categories.contentType'])->findOrFail($id);
|
||||
$direct = (bool) $request->boolean('direct');
|
||||
$intent = $request->validate([
|
||||
$payload = $request->validate([
|
||||
'direct' => ['sometimes', 'boolean'],
|
||||
'intent' => ['sometimes', 'nullable', 'string', 'in:analyze,title,description,tags,category,similar'],
|
||||
])['intent'] ?? null;
|
||||
'provider' => ['sometimes', 'nullable', 'string'],
|
||||
]);
|
||||
$direct = (bool) ($payload['direct'] ?? false);
|
||||
$intent = $payload['intent'] ?? null;
|
||||
$provider = $this->normalizeProviderOption($payload['provider'] ?? null);
|
||||
|
||||
if ($provider === null && array_key_exists('provider', $payload) && $payload['provider'] !== null) {
|
||||
return response()->json([
|
||||
'success' => false,
|
||||
'message' => 'Invalid provider. Supported values: lm_studio, together.',
|
||||
], 422);
|
||||
}
|
||||
|
||||
if ($direct) {
|
||||
$assist = $this->aiAssist->analyzeDirect($artwork, true, $intent);
|
||||
$assist = $this->aiAssist->analyzeDirect($artwork, true, $intent, $provider);
|
||||
|
||||
return response()->json([
|
||||
'success' => true,
|
||||
@@ -77,7 +97,7 @@ final class StudioArtworkAiAssistApiController extends Controller
|
||||
]);
|
||||
}
|
||||
|
||||
$assist = $this->aiAssist->queueAnalysis($artwork, true, $intent);
|
||||
$assist = $this->aiAssist->queueAnalysis($artwork, true, $intent, $provider);
|
||||
|
||||
return response()->json([
|
||||
'success' => true,
|
||||
@@ -114,4 +134,17 @@ final class StudioArtworkAiAssistApiController extends Controller
|
||||
|
||||
return response()->json(['success' => true], 201);
|
||||
}
|
||||
|
||||
private function normalizeProviderOption(mixed $value): ?string
|
||||
{
|
||||
if ($value === null || trim((string) $value) === '') {
|
||||
return null;
|
||||
}
|
||||
|
||||
return match (strtolower(trim((string) $value))) {
|
||||
'lm_studio', 'lm-studio', 'local', 'home' => 'lm_studio',
|
||||
'together', 'together_ai' => 'together',
|
||||
default => null,
|
||||
};
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user