Skip to content

Commit

Permalink
fix: fix welcome screen azure config submit (#998)
Browse files Browse the repository at this point in the history
  • Loading branch information
ahau-square authored Jan 31, 2025
1 parent cccbb13 commit a46372c
Showing 1 changed file with 51 additions and 38 deletions.
89 changes: 51 additions & 38 deletions ui/desktop/src/components/welcome_screen/ProviderGrid.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,64 +70,77 @@ export function ProviderGrid({ onSubmit }: ProviderGridProps) {
setShowSetupModal(true);
};

const handleModalSubmit = async (apiKey: string) => {
const handleModalSubmit = async (configValues: { [key: string]: string }) => {
if (!selectedId) return;

const provider = providers.find((p) => p.id === selectedId)?.name;
const keyName = required_keys[provider]?.[0];
if (!provider) return;

if (!keyName) {
console.error(`No key found for provider ${provider}`);
const requiredKeys = required_keys[provider];
if (!requiredKeys || requiredKeys.length === 0) {
console.error(`No keys found for provider ${provider}`);
return;
}

const isSecret = isSecretKey(keyName);
try {
if (selectedId && providers.find((p) => p.id === selectedId)?.isConfigured) {
const deleteResponse = await fetch(getApiUrl('/configs/delete'), {
method: 'DELETE',
// Delete existing keys if provider is already configured
const isUpdate = providers.find((p) => p.id === selectedId)?.isConfigured;
if (isUpdate) {
for (const keyName of requiredKeys) {
const isSecret = isSecretKey(keyName);
const deleteResponse = await fetch(getApiUrl('/configs/delete'), {
method: 'DELETE',
headers: {
'Content-Type': 'application/json',
'X-Secret-Key': getSecretKey(),
},
body: JSON.stringify({
key: keyName,
isSecret,
}),
});

if (!deleteResponse.ok) {
const errorText = await deleteResponse.text();
console.error('Delete response error:', errorText);
throw new Error(`Failed to delete old key: ${keyName}`);
}
}
}

// Store new keys
for (const keyName of requiredKeys) {
const value = configValues[keyName];
if (!value) {
console.error(`Missing value for required key: ${keyName}`);
continue;
}

const isSecret = isSecretKey(keyName);
const storeResponse = await fetch(getApiUrl('/configs/store'), {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'X-Secret-Key': getSecretKey(),
},
body: JSON.stringify({
key: keyName,
body: JSON.stringify({
key: keyName,
value: value,
isSecret,
}),
});

if (!deleteResponse.ok) {
const errorText = await deleteResponse.text();
console.error('Delete response error:', errorText);
throw new Error('Failed to delete old key');
if (!storeResponse.ok) {
const errorText = await storeResponse.text();
console.error('Store response error:', errorText);
throw new Error(`Failed to store new key: ${keyName}`);
}
}

const storeResponse = await fetch(getApiUrl('/configs/store'), {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'X-Secret-Key': getSecretKey(),
},
body: JSON.stringify({
key: keyName,
value: apiKey.trim(),
isSecret,
}),
});

if (!storeResponse.ok) {
const errorText = await storeResponse.text();
console.error('Store response error:', errorText);
throw new Error('Failed to store new key');
}

const isUpdate = selectedId && providers.find((p) => p.id === selectedId)?.isConfigured;
const toastInfo = isSecret ? 'API key' : 'host';
toast.success(
isUpdate
? `Successfully updated ${toastInfo} for ${provider}`
: `Successfully added ${toastInfo} for ${provider}`
? `Successfully updated configuration for ${provider}`
: `Successfully added configuration for ${provider}`
);

const updatedKeys = await getActiveProviders();
Expand All @@ -138,7 +151,7 @@ export function ProviderGrid({ onSubmit }: ProviderGridProps) {
} catch (error) {
console.error('Error handling modal submit:', error);
toast.error(
`Failed to ${selectedId && providers.find((p) => p.id === selectedId)?.isConfigured ? 'update' : 'add'} API key for ${provider}`
`Failed to ${providers.find((p) => p.id === selectedId)?.isConfigured ? 'update' : 'add'} configuration for ${provider}`
);
}
};
Expand Down

0 comments on commit a46372c

Please sign in to comment.