Skip to content
/ fettle Public

Free GitHub-powered beautiful status page utilizing GitHub Pages, Actions, and Issues for real-time updates and incident management. Make sure to share love by giving it a star.๐ŸŒŸ

License

Notifications You must be signed in to change notification settings

mehatab/fettle

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Fettle ๐Ÿ’Ÿ

Fettle is the open-source status page, powered entirely by GitHub Actions, Issues, and Pages.

Usage

First of all, you need to fork this repository.

Update URL's

Update the urls and name in urls.cfg file present in public > urls.cfg file.

Google=https://google.com
Facebook=https://facebook.com

Incidents URL update

Go to src > incidents > hooks > useIncidents.tsx file and update the url with your repository url.

Replace mehatab/fettle with your username/repo-name

https://api.github.com/repos/mehatab/fettle/issues?per_page=20&state=all&labels=incident

Service status URL update

Go to src > services > hooks > useServices.tsx file and update the url with your repository url.

Replace mehatab/fettle with your username/repo-name

https://raw.githubusercontent.com/mehatab/fettle/main/public/status/${key}_report.log

Go to src > services > hooks > useSystemStatus.tsx file and update the url with your repository url.

Replace mehatab/fettle with your username/repo-name

https://raw.githubusercontent.com/mehatab/fettle/main/public/status/${key}_report.log

Deployment setup

Then, you need to enable GitHub Pages on your forked repository. You can do this by going to Settings > Pages and enabling it on the main branch.

In Build and deployment section select GitHub Actions.

Change monitoring interval

If you want to change the time interval of monitoring then you can change it in .github > workflows > health-check.yml file. update the cron time in the following line.

    on:
      schedule:
        - cron: "0 0/12 * * *"

Reporting your first incident

  1. Go to issues tab
  2. Create a new label incident
  3. Create a issue
  4. Add the label incident to the issue

How it works

  • Hosting

    • GitHub Pages is used for hosting the status page.
  • Monitoring

    • Github Workflow will be triggered every 1 Hr (Configurable) to visit the website.
    • Response status and response time is commited to github repository.
  • Incidents

    • Github issue is used for incident management.

Contributing

Feel free to submit pull requests and/or file issues for bugs and suggestions.

About

Free GitHub-powered beautiful status page utilizing GitHub Pages, Actions, and Issues for real-time updates and incident management. Make sure to share love by giving it a star.๐ŸŒŸ

Topics

Resources

License

Stars

Watchers

Forks