Files
artsite/server/api/stats.get.ts
Arthur DANJOU f171be4460 feat: integrate evlog and enhance logging across API endpoints
- Added evlog and nuxthub dependencies in nuxt.config.ts and package.json.
- Implemented logging in various API endpoints (activity, contact, education, experiences, languages, projects, skills, stats, status-page, resumes) to track data retrieval and errors.
- Enhanced error handling in Wakatime fetch functions to log errors with additional context.
- Updated worker-configuration.d.ts to remove eslint-disable comments for better code quality.
2026-02-16 21:43:02 +01:00

83 lines
2.4 KiB
TypeScript

import type { H3Event } from 'h3'
const WAKATIME_HEADERS = {
'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36',
'Accept': 'application/json'
}
const fetchWakatime = async (url: string, log?: ReturnType<typeof useLogger>) => {
const startedAt = Date.now()
try {
return await $fetch<{ data: unknown[] }>(url, {
headers: WAKATIME_HEADERS,
timeout: 5000
})
}
catch (err) {
log?.error?.(err, {
action: 'wakatime.fetch',
url,
durationMs: Date.now() - startedAt
})
return { data: [] }
}
}
const cachedWakatimeCoding = defineCachedFunction(async (event: H3Event) => {
const config = useRuntimeConfig(event)
const log = useLogger(event)
return await fetchWakatime(`https://wakatime.com/share/${config.wakatime.userId}/${config.wakatime.coding}.json`, log)
}, {
maxAge: 60 * 50,
name: 'stats',
getKey: () => 'coding'
})
const cachedWakatimeEditors = defineCachedFunction(async (event: H3Event) => {
const config = useRuntimeConfig(event)
const log = useLogger(event)
return await fetchWakatime(`https://wakatime.com/share/${config.wakatime.userId}/${config.wakatime.editors}.json`, log)
}, {
maxAge: 60 * 60,
name: 'stats',
getKey: () => 'editors'
})
const cachedWakatimeOs = defineCachedFunction(async (event: H3Event) => {
const config = useRuntimeConfig(event)
const log = useLogger(event)
return await fetchWakatime(`https://wakatime.com/share/${config.wakatime.userId}/${config.wakatime.os}.json`, log)
}, {
maxAge: 60 * 60,
name: 'stats',
getKey: () => 'os'
})
const cachedWakatimeLanguages = defineCachedFunction(async (event: H3Event) => {
const config = useRuntimeConfig(event)
const log = useLogger(event)
return await fetchWakatime(`https://wakatime.com/share/${config.wakatime.userId}/${config.wakatime.languages}.json`, log)
}, {
maxAge: 60 * 60,
name: 'stats',
getKey: () => 'languages'
})
export default defineEventHandler(async (event) => {
const log = useLogger(event)
log.set({ source: 'wakatime' })
const [coding, editors, os, languages] = await Promise.all([
cachedWakatimeCoding(event),
cachedWakatimeEditors(event),
cachedWakatimeOs(event),
cachedWakatimeLanguages(event)
])
return {
coding: coding.data,
editors: editors.data,
os: os.data,
languages: languages.data
}
})