You've already forked AstralRinth
60 lines
1.5 KiB
JavaScript
60 lines
1.5 KiB
JavaScript
let cachedRateLimitKey = undefined
|
|
let rateLimitKeyPromise = undefined
|
|
|
|
async function getRateLimitKey(config) {
|
|
if (config.rateLimitKey) return config.rateLimitKey
|
|
if (cachedRateLimitKey !== undefined) return cachedRateLimitKey
|
|
|
|
if (!rateLimitKeyPromise) {
|
|
rateLimitKeyPromise = (async () => {
|
|
try {
|
|
const mod = 'cloudflare:workers'
|
|
const { env } = await import(/* @vite-ignore */ mod)
|
|
return await env.RATE_LIMIT_IGNORE_KEY?.get()
|
|
} catch {
|
|
return undefined
|
|
}
|
|
})()
|
|
}
|
|
|
|
cachedRateLimitKey = await rateLimitKeyPromise
|
|
return cachedRateLimitKey
|
|
}
|
|
|
|
export const useBaseFetch = async (url, options = {}, skipAuth = false) => {
|
|
const config = useRuntimeConfig()
|
|
let base = import.meta.server ? config.apiBaseUrl : config.public.apiBaseUrl
|
|
|
|
if (!options.headers) {
|
|
options.headers = {}
|
|
}
|
|
|
|
if (import.meta.server) {
|
|
options.headers['x-ratelimit-key'] = await getRateLimitKey(config)
|
|
}
|
|
|
|
if (!skipAuth) {
|
|
const auth = await useAuth()
|
|
|
|
options.headers.Authorization = auth.value.token
|
|
}
|
|
|
|
if (options.apiVersion || options.internal) {
|
|
// Base may end in /vD/ or /vD. We would need to replace the digit with the new version number
|
|
// and keep the trailing slash if it exists
|
|
const baseVersion = base.match(/\/v\d\//)
|
|
|
|
const replaceStr = options.internal ? `/_internal/` : `/v${options.apiVersion}/`
|
|
|
|
if (baseVersion) {
|
|
base = base.replace(baseVersion[0], replaceStr)
|
|
} else {
|
|
base = base.replace(/\/v\d$/, replaceStr)
|
|
}
|
|
|
|
delete options.apiVersion
|
|
}
|
|
|
|
return await $fetch(`${base}${url}`, options)
|
|
}
|