一个基于 UptimeRobot API 的在线状态面板
An uptime status dashboard based on UptimeRobot API
原版:https://github.com/yb/uptime-status
Build an UptimeRobot API proxy based on Cloudflare Workers to solve the cross-domain issue of official API
const handleRequest = async ({
request
}) => {
let url = new URL(request.url);
let body = await request.text();
try {
body = JSON.parse(body);
body.api_key = '你的 UptimeRobot key'
body = JSON.stringify(body);
} catch (error) {
console.log(error)
}
let response = await fetch('https://api.uptimerobot.com' + url.pathname, {
body: body,
headers: {
'user-agent': 'Mozilla/4.0 MDN Example',
'content-type': 'application/json'
},
method: 'POST', // *GET, POST, PUT, DELETE, etc.
redirect: 'follow', // manual, *follow, error
});
response = new Response(response.body, response);
response.headers.set('Access-Control-Allow-Origin', '*');
response.headers.set('Access-Control-Allow-Methods', '*');
response.headers.set('Access-Control-Allow-Credentials', 'true');
response.headers.set('Access-Control-Allow-Headers', 'Content-Type,Access-Token');
response.headers.set('Access-Control-Expose-Headers', '*');
let json = await response.text()
try {
json = JSON.parse(json)
// 隐藏域名
json.monitors = json.monitors.map(site => {
site.url = undefined
return site
});
json = JSON.stringify(json)
} catch (error) {}
return new Response(json, response)
}
addEventListener('fetch', (event) => {
event.respondWith(handleRequest(event));
});
修改 config.js
中的 ApiDomian
为你的域名;
Modify ApiDomian
in config.js
to your domain;
- fork本仓库
- 去 Cloudflare Workers 创建,用上面的代码记得修改你的 UptimeRobot key
- 修改fork分支 build 分支的 config.js 配置信息
- setting-page-开启页面设置build分支-root/
20211010:U -> update theme css