mirror of
https://github.com/QuantumNous/new-api.git
synced 2026-04-18 11:17:27 +00:00
Changes
1. web/src/helpers/token.js
• `fetchTokenKeys` now calls `/api/token/?p=1&size=10` (1-based paging).
• Supports new response shape `{ items, total, page, page_size }`; falls back gracefully if array is returned.
• Filters active tokens from `tokenItems`, not `data` directly.
`useTokenKeys` remains unchanged—its consumer code receives the same list of active keys.
44 lines
1.1 KiB
JavaScript
44 lines
1.1 KiB
JavaScript
import { API } from './api';
|
|
|
|
/**
|
|
* 获取可用的token keys
|
|
* @returns {Promise<string[]>} 返回active状态的token key数组
|
|
*/
|
|
export async function fetchTokenKeys() {
|
|
try {
|
|
const response = await API.get('/api/token/?p=1&size=10');
|
|
const { success, data } = response.data;
|
|
if (!success) throw new Error('Failed to fetch token keys');
|
|
|
|
const tokenItems = Array.isArray(data) ? data : data.items || [];
|
|
const activeTokens = tokenItems.filter((token) => token.status === 1);
|
|
return activeTokens.map((token) => token.key);
|
|
} catch (error) {
|
|
console.error('Error fetching token keys:', error);
|
|
return [];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 获取服务器地址
|
|
* @returns {string} 服务器地址
|
|
*/
|
|
export function getServerAddress() {
|
|
let status = localStorage.getItem('status');
|
|
let serverAddress = '';
|
|
|
|
if (status) {
|
|
try {
|
|
status = JSON.parse(status);
|
|
serverAddress = status.server_address || '';
|
|
} catch (error) {
|
|
console.error('Failed to parse status from localStorage:', error);
|
|
}
|
|
}
|
|
|
|
if (!serverAddress) {
|
|
serverAddress = window.location.origin;
|
|
}
|
|
|
|
return serverAddress;
|
|
}
|