refactor: migrate all Tauri commands to camelCase parameters

This commit addresses parameter naming inconsistencies caused by Tauri v2's
requirement for camelCase parameter names in IPC commands.

Backend changes (Rust):
- Updated all command parameters from snake_case to camelCase
- Commands affected:
  * provider.rs: providerId (×4), timeoutSecs
  * import_export.rs: filePath (×2), defaultName
  * config.rs: defaultPath
- Added #[allow(non_snake_case)] attributes for camelCase parameters
- Removed unused QueryUsageParams struct

Frontend changes (TypeScript):
- Removed redundant snake_case parameters from all invoke() calls
- Updated API files:
  * usage.ts: removed debug logs, unified to providerId
  * vscode.ts: updated 8 functions (providerId, timeoutSecs, filePath, defaultName)
  * settings.ts: updated 4 functions (defaultPath, filePath, defaultName)
- Ensured all parameters now use camelCase exclusively

Test updates:
- Updated MSW handlers to accept both old and new parameter formats during transition
- Added i18n mock compatibility for tests

Root cause:
The issue stemmed from Tauri v2 strictly requiring camelCase for command
parameters, while the codebase was using snake_case. This caused parameters
like 'provider_id' to not be recognized by the backend, resulting in
"missing providerId parameter" errors.

BREAKING CHANGE: All Tauri command invocations now require camelCase parameters.
Any external tools or scripts calling these commands must be updated accordingly.

Fixes: Usage query always failing with "missing providerId" error
Fixes: Custom endpoint management not receiving provider ID
Fixes: Import/export dialogs not respecting default paths
This commit is contained in:
Jason
2025-11-03 16:50:23 +08:00
parent 85334d8dce
commit 36fd61b2a2
8 changed files with 57 additions and 52 deletions

View File

@@ -20,7 +20,7 @@ export const vscodeApi = {
): Promise<EndpointLatencyResult[]> {
return await invoke("test_api_endpoints", {
urls,
timeout_secs: options?.timeoutSecs,
timeoutSecs: options?.timeoutSecs,
});
},
@@ -30,7 +30,7 @@ export const vscodeApi = {
): Promise<CustomEndpoint[]> {
return await invoke("get_custom_endpoints", {
app: appId,
provider_id: providerId,
providerId: providerId,
});
},
@@ -41,7 +41,7 @@ export const vscodeApi = {
): Promise<void> {
await invoke("add_custom_endpoint", {
app: appId,
provider_id: providerId,
providerId: providerId,
url,
});
},
@@ -53,7 +53,7 @@ export const vscodeApi = {
): Promise<void> {
await invoke("remove_custom_endpoint", {
app: appId,
provider_id: providerId,
providerId: providerId,
url,
});
},
@@ -65,28 +65,25 @@ export const vscodeApi = {
): Promise<void> {
await invoke("update_endpoint_last_used", {
app: appId,
provider_id: providerId,
providerId: providerId,
url,
});
},
async exportConfigToFile(filePath: string) {
return await invoke("export_config_to_file", {
file_path: filePath,
filePath,
});
},
async importConfigFromFile(filePath: string) {
return await invoke("import_config_from_file", {
file_path: filePath,
filePath,
});
},
async saveFileDialog(defaultName: string): Promise<string | null> {
return await invoke("save_file_dialog", {
default_name: defaultName,
defaultName,
});
},