refactor(api): add raw request helper and centralize headers

This commit is contained in:
hkfires
2025-11-21 10:16:06 +08:00
parent a6344a6a61
commit e58d462153
3 changed files with 35 additions and 32 deletions

View File

@@ -724,16 +724,11 @@ export const authFilesModule = {
this.vertexImportState.loading = true;
this.updateVertexImportButtonState();
const response = await fetch(`${this.apiUrl}/vertex/import`, {
const response = await this.apiClient.requestRaw('/vertex/import', {
method: 'POST',
headers: {
'Authorization': `Bearer ${this.managementKey}`
},
body: formData
});
this.updateVersionFromHeaders(response.headers);
if (!response.ok) {
let errorMessage = `HTTP ${response.status}`;
try {
@@ -879,13 +874,7 @@ export const authFilesModule = {
async downloadAuthFile(filename) {
try {
const response = await fetch(`${this.apiUrl}/auth-files/download?name=${encodeURIComponent(filename)}`, {
headers: {
'Authorization': `Bearer ${this.managementKey}`
}
});
this.updateVersionFromHeaders(response.headers);
const response = await this.apiClient.requestRaw(`/auth-files/download?name=${encodeURIComponent(filename)}`);
if (!response.ok) {
throw new Error(`HTTP ${response.status}`);
@@ -1017,16 +1006,11 @@ export const authFilesModule = {
const formData = new FormData();
formData.append('file', file, file.name);
const response = await fetch(`${this.apiUrl}/auth-files`, {
const response = await this.apiClient.requestRaw('/auth-files', {
method: 'POST',
headers: {
'Authorization': `Bearer ${this.managementKey}`
},
body: formData
});
this.updateVersionFromHeaders(response.headers);
if (!response.ok) {
const errorData = await response.json().catch(() => ({}));
throw new Error(errorData.error || `HTTP ${response.status}`);

View File

@@ -152,16 +152,13 @@ export const configEditorModule = {
const requestUrl = '/config.yaml';
try {
const response = await fetch(`${this.apiUrl}${requestUrl}`, {
const response = await this.apiClient.requestRaw(requestUrl, {
method: 'GET',
headers: {
'Authorization': `Bearer ${this.managementKey}`,
'Accept': 'application/yaml'
}
});
this.updateVersionFromHeaders(response.headers);
if (!response.ok) {
const errorText = await response.text().catch(() => '');
const message = errorText || `HTTP ${response.status}`;
@@ -227,18 +224,15 @@ export const configEditorModule = {
},
async writeConfigFile(endpoint, yamlText) {
const response = await fetch(`${this.apiUrl}${endpoint}`, {
const response = await this.apiClient.requestRaw(endpoint, {
method: 'PUT',
headers: {
'Authorization': `Bearer ${this.managementKey}`,
'Content-Type': 'application/yaml',
'Accept': 'application/json, text/plain, */*'
},
body: yamlText
});
this.updateVersionFromHeaders(response.headers);
if (!response.ok) {
const contentType = response.headers.get('content-type') || '';
let errorText = '';