mirror of
https://github.com/ArthurDanjou/artdanj-api.git
synced 2026-01-31 11:57:50 +01:00
Add try catch
This commit is contained in:
@@ -12,28 +12,32 @@ interface StatesResponse {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function getCurrentTime(): Promise<void> {
|
async function getCurrentTime(): Promise<void> {
|
||||||
const response = await axios.get<{ data: StatesResponse[]}>(`https://wakatime.com/api/v1/users/${Env.get('WAKATIME_USER')}/heartbeats`, {
|
try {
|
||||||
headers: {
|
const response = await axios.get<{ data: StatesResponse[]}>(`https://wakatime.com/api/v1/users/${Env.get('WAKATIME_USER')}/heartbeats`, {
|
||||||
Authorization: `Basic ${btoa(Env.get('WAKATIME_KEY'))}`,
|
headers: {
|
||||||
},
|
Authorization: `Basic ${btoa(Env.get('WAKATIME_KEY'))}`,
|
||||||
params: {
|
},
|
||||||
date: new Date(),
|
params: {
|
||||||
},
|
date: new Date(),
|
||||||
})
|
},
|
||||||
|
})
|
||||||
|
|
||||||
if (response.status === 200) {
|
if (response.status === 200) {
|
||||||
const heartbeat = response.data.data[response.data.data.length - 1]
|
const heartbeat = response.data.data[response.data.data.length - 1]
|
||||||
const current_time = new Date(Date.now()).getTime() / 1000
|
const current_time = new Date(Date.now()).getTime() / 1000
|
||||||
|
|
||||||
if (heartbeat && heartbeat.time!) {
|
if (heartbeat && heartbeat.time!) {
|
||||||
const active = current_time - heartbeat.time <= 60 * 5 // Less than 5 min.
|
const active = current_time - heartbeat.time <= 60 * 5 // Less than 5 min.
|
||||||
const redis_state = await Redis.get('states:developing') === 'true'
|
const redis_state = await Redis.get('states:developing') === 'true'
|
||||||
|
|
||||||
if (redis_state !== active) {
|
if (redis_state !== active) {
|
||||||
await Redis.set('states:developing', String(active))
|
await Redis.set('states:developing', String(active))
|
||||||
if (redis_state) await Redis.set('states:sleeping', 'false')
|
if (redis_state) await Redis.set('states:sleeping', 'false')
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} catch (error) {
|
||||||
|
Logger.error('Error while getting the states')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -17,24 +17,28 @@ interface StatsResponse {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function getDevelopmentHours(): Promise<void> {
|
async function getDevelopmentHours(): Promise<void> {
|
||||||
const response = await axios.get<{ data: StatsResponse[]}>(`https://wakatime.com/share/@${Env.get('WAKATIME_USER')}/${Env.get('WAKATIME_ID')}.json`)
|
try {
|
||||||
if (response.status === 200) {
|
const response = await axios.get<{ data: StatsResponse[]}>(`https://wakatime.com/share/@${Env.get('WAKATIME_USER')}/${Env.get('WAKATIME_ID')}.json`)
|
||||||
const mapped_stats = response.data.data.map((item: StatsResponse) => {
|
if (response.status === 200) {
|
||||||
return {
|
const mapped_stats = response.data.data.map((item: StatsResponse) => {
|
||||||
seconds: item.grand_total.total_seconds, date: item.range.date,
|
return {
|
||||||
}
|
seconds: item.grand_total.total_seconds, date: item.range.date,
|
||||||
})
|
}
|
||||||
|
|
||||||
for (const data of mapped_stats) {
|
|
||||||
await DevelopmentHour.updateOrCreate({
|
|
||||||
date: data.date.split('T')[0],
|
|
||||||
}, {
|
|
||||||
date: data.date.split('T')[0],
|
|
||||||
seconds: data.seconds,
|
|
||||||
})
|
})
|
||||||
}
|
|
||||||
|
|
||||||
await UpdateGithubReadme()
|
for (const data of mapped_stats) {
|
||||||
|
await DevelopmentHour.updateOrCreate({
|
||||||
|
date: data.date.split('T')[0],
|
||||||
|
}, {
|
||||||
|
date: data.date.split('T')[0],
|
||||||
|
seconds: data.seconds,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
await UpdateGithubReadme()
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
Logger.error('Error while getting the stats')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user