uptime-status

一个基于 UptimeRobot API 的在线状态面板

An uptime status dashboard based on UptimeRobot API


基于 Cloudflare Workers 搭建 UptimeRobot API 代理,以解决官网 API 跨域问题

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;