kopia lustrzana https://github.com/badgen/badgen.net
124 wiersze
3.3 KiB
TypeScript
124 wiersze
3.3 KiB
TypeScript
import got from '../libs/got'
|
|
import { scale } from '../libs/utils'
|
|
import {
|
|
badgenServe,
|
|
BadgenServeMeta as Meta,
|
|
BadgenServeHandlers as Handlers,
|
|
BadgenServeHandlerArgs as Args
|
|
} from '../libs/badgen-serve'
|
|
|
|
const help = `## Usage
|
|
|
|
- \`/uptime-robot/status/:api-key\` _status_
|
|
- \`/uptime-robot/day/:api-key\` _(24 hours) uptime_
|
|
- \`/uptime-robot/week/:api-key\` _(past week) uptime_
|
|
- \`/uptime-robot/month/:api-key\` _(past month) uptime_
|
|
- \`/uptime-robot/response/:api-key\` _(last hours) response_
|
|
|
|
## Creating the API key
|
|
|
|
To use an \`/uptime-robot\` badge, you have to create or find an API key specific to your monitor.
|
|
|
|
From your UptimeRobot dashboard, go to
|
|
[My Settings](https://uptimerobot.com/dashboard.php#mySettings) > API Settings > Monitor-Specific API Keys.`
|
|
|
|
export const meta: Meta = {
|
|
help,
|
|
title: 'Uptime Robot',
|
|
examples: {
|
|
'/uptime-robot/status/m780862024-50db2c44c703e5c68d6b1ebb': 'status',
|
|
'/uptime-robot/day/m780862024-50db2c44c703e5c68d6b1ebb': '(24 hours) uptime',
|
|
'/uptime-robot/week/m780862024-50db2c44c703e5c68d6b1ebb': '(past week) uptime',
|
|
'/uptime-robot/month/m780862024-50db2c44c703e5c68d6b1ebb': '(past month) uptime',
|
|
'/uptime-robot/response/m780862024-50db2c44c703e5c68d6b1ebb': '(last hour) response',
|
|
}
|
|
}
|
|
|
|
export const handlers: Handlers = {
|
|
'/uptime-robot/:topic<status|day|week|month|response>/:apikey': handler
|
|
}
|
|
|
|
export default badgenServe(handlers)
|
|
|
|
/**
|
|
* DOCS
|
|
* https://uptimerobot.com/api
|
|
*
|
|
* USAGE
|
|
* /uptime-robot/:topic/:api_key
|
|
* :api_key are generated from uptimerobot settings page
|
|
*/
|
|
async function handler ({ topic, apikey }: Args) {
|
|
const endpoint = `https://api.uptimerobot.com/v2/getMonitors`
|
|
const { monitors } = await got.post(endpoint, {
|
|
body: {
|
|
api_key: apikey,
|
|
custom_uptime_ratios: '1-7-30',
|
|
response_times: 1,
|
|
response_times_limit: 12
|
|
}
|
|
}).then(res => res.body)
|
|
|
|
/* eslint-disable camelcase */
|
|
const { status, custom_uptime_ratio, average_response_time } = monitors[0]
|
|
|
|
switch (topic) {
|
|
case 'status':
|
|
const _stat = statuses[status]
|
|
return {
|
|
subject: 'status',
|
|
status: _stat ? _stat[0] : 'unknown',
|
|
color: _stat ? _stat[1] : 'grey'
|
|
}
|
|
case 'day':
|
|
return uptime('past-day', custom_uptime_ratio)
|
|
case 'week':
|
|
return uptime('past-week', custom_uptime_ratio)
|
|
case 'month':
|
|
return uptime('past-month', custom_uptime_ratio)
|
|
case 'response':
|
|
return {
|
|
subject: 'response',
|
|
status: average_response_time + 'ms',
|
|
color: 'blue'
|
|
}
|
|
}
|
|
}
|
|
|
|
const statuses = {
|
|
0: ['paused', 'yellow'],
|
|
1: ['not checked yet', 'grey'],
|
|
2: ['up', 'green'],
|
|
8: ['seems down', 'orange'],
|
|
9: ['down', 'red']
|
|
}
|
|
|
|
const uptime = (period, ratios) => {
|
|
const [day, week, month] = ratios.split('-').map(r => parseFloat(r))
|
|
switch (period) {
|
|
case 'past-day':
|
|
return {
|
|
subject: 'uptime /24h',
|
|
status: day + '%',
|
|
color: ratioColor(day)
|
|
}
|
|
case 'past-week':
|
|
return {
|
|
subject: 'uptime /week',
|
|
status: week + '%',
|
|
color: ratioColor(week)
|
|
}
|
|
case 'past-month':
|
|
return {
|
|
subject: 'uptime /month',
|
|
status: month + '%',
|
|
color: ratioColor(month)
|
|
}
|
|
}
|
|
}
|
|
|
|
const ratioColor = scale(
|
|
[94, 97, 99, 99.9],
|
|
['red', 'orange', 'EA2', '9C1', 'green']
|
|
)
|