Static status page for hyperfast Hugo. Clean design, minimal JS, super light HTML/CSS, high customization, optional admin panel, read-only API, IE8+. Best used with Netlify, Docker.
Deploy this app to Linode with a free $100 credit!
Über fast to load and build, backwards compatible (IE8+), tiny, and simple OSS status page built with Hugo. Completely free with Netlify. Comes with Netlify CMS, read-only API, badges like from shields.io, and other useful features.
You can support the creator of this project by starring, sharing, using cState and/or financially supporting the author. Thank you!
cState's development is being sposnored by Instatus from June, 2022.
Want your status page here? Create a PR!
NEW: HTML Embed now in version 2. Check it out!
Fast.
Nice.
Free.
Please note that with all that cState can do, it cannot do automatic monitoring out of the box. See this thread You can think of the cState status page as an informational hub. Because the software is static, it cannot directly monitor any services in real time.
However, cState is a perfect option for recording incidents because most of the time your services are functioning, so the status page does not need to be updated. By default, the little bit of JavaScript on the page improves the user experience but is not required to see the most vital information.
There are other commercial options that may update faster because of their architecture, have built-in real-time uptime monitoring, send notifications by email or other means, but cState is not supposed to be better than paid solutions.
This is how you create a new site powered by cState. What you are generating is a Hugo site with specific, already existing modifications (to Hugo, cState acts like a theme).
IF YOU ARE A DEVELOPER / WANT TO CONTRIBUTE TO THE DEVELOPMENT, SCROLL TO THE BOTTOM. THIS IS FOR USERS.
Aside from hosting the repository itself on Git (usually on GitHub), your next options are:
You can also look at other headless CMS options (we use Git-based CMS types) on jamstack.org.
If you wish to use Netlify, use the button below for easier deployment.
All other static site generator platforms require you to follow this instruction:
These are the settings you should be using:
Build command: hugo
You don't have to use Netlify, but this is the best option if you need Netlify CMS which works best with Netlify. It takes just a few clicks to make it work, more info is in the documentation.
You can simply click this button to get started:
Here is a good guide for getting started with the service.
In short: a .gitlab-ci.yml
file is responsible for making cState work. As of v4.2.1, the cState automatically ships with this file, but support is still experimental. It may take up to 30 minutes before the site is available after the first deployment.
As of this time, this is a relatively untested option, but Hugo does seem to generate the right things (this can be checked by downloading the CI/CD artifacts).
You can make Netlify CMS work on GitLab, but that requires overriding an existing file in the theme. Create a file in static/admin/config.yml
and follow the instructions linked earlier. (cState by default ships with Git Gateway for Netlify.)
For this tutorial, it is assumed that you have Hugo and Git installed (check with hugo version
& git --version
).
A minimum version of
0.80
is required for Hugo, starting with v5.
git clone --recursive -b master https://github.com/cstate/example.git
You must use --recursive
so that Git downloads cState and you do not have an empty themes/cstate
folder.
Now you can edit what's inside the folder (cd example
) and try previewing that with this command:
hugo serve
Edit the config file. Once the changes you wanted done are finished, generate the final files like this:
hugo
And the folder public
can now be hosted.
As you can imagine, manual building is a little bit tedious but a great option to have available programatically.
cState comes with a Dockerfile and Netlify (according to their article from 2016) uses a similar Docker system to build cState. This is an option for people who prefer Docker and NGINX instead of serverless, but serverless still has the priority in cState development.
If you are updating from one major version to another, like from v3 to v4, then please read the migration guides.
Assuming the production install instructions were followed, keep cState updated by having an up to date Git submodule in the themes
folder. containing this repository. Your content should stay separate from the guts of cState.
Ask yourself these questions:
git clone --recursive <your repo link goes here> && git submodule foreach git pull origin master
.hugo serve
. Check to see if everything is working.git add -A; git commit -m "Update cState"; git push origin master; exit
. Your status page is now updated.themes/cstate
. If that is empty, it is easier to delete your local copy and do the steps outlined earlier.There is currently no easier way to do this, unfortunately, you will need the terminal / command line / Git Bash, unless you want to create a new status page from scratch and move your data over manually.
More info about submodules: updating & cloning.
Most of the settings are in the config.yml
file or under Settings, if you have set up Netlify CMS.
This takes a little more effort to set up but pays off in the long run — see the wiki for up to date information.
Create a file in content/issues
. The name of the file will be the slug (what shows up in the URL bar). For example, this is what 2017-02-30-major-outage-east-us.md
should look like:
---
title: Major outage in East US
date: 2017-02-30 14:30:00
resolved: true
resolvedWhen: 2017-02-30 16:00:00
severity: down
affected:
- API
section: issue
---
*Monitoring* - After hitting the ole reboot button Example Chat App is now recovering. We’re going to continue to monitor as everyone reconnects. {{< track "2018-04-13 16:50:00" >}}
*Investigating* - We’re aware of users experiencing unavailable guilds and issues when attempting to connect. We're currently investigating. {{< track "2018-04-13 15:54:00" >}}
This is what you would see for an issue that has been resolved.
Time to break that down.
title
: This is the one of the most important parts of an incident. (required)
date
: An ISO-8601 formatted date. Does not include time zone. This is when you first discovered the issue. (required)
resolved
: Whether issue should affect overall status. Either true
or false
. (boolean, required)
resolvedWhen
: An ISO-8601 formatted date. Does not include time zone. This is when downtime stopped. You may set the time that downtime ended without completely resolving the issue (thus leaving time for monitoring).
severity
: If an issue is not resolved, it will have an applied severity. There are 3 levels of severity: notice
, disrupted
, and down
. If there are multiple issues, the status page will take the appearance of the more drastic issue (such as disrupted
instead of notice
). (required)
affected
. Add the items that were present in the config file which should alter the status of each individual system (component). (array, required)
section
. This must be issue
, so that Hugo treats it as one. (required)
You don't have to define a date for resolvedWhen
when the issue is not resolved (obviously):
---
title: Major outage in East US
date: 2017-02-30 14:30:00
resolved: false
severity: down
affected:
- API
section: issue
---
We are looking into this...
For this very basic tutorial, yes.
Check out the wiki.
PRs should be submitted to the dev
branch, if it exists. Before submitting a pull request, create an issue to discuss the implications of your proposal.
The root directory is where the theme itself is (the cState guts, basically) and the exampleSite
folder houses all content for your specific site. Use this local setup to experiment before making a PR.
Here is a guide for how you should develop:
git clone --recursive -b master https://github.com/cstate/cstate.git
# old command
# navigate to the directory where your content is and start dev server from there
cd cstate/exampleSite
hugo serve --baseUrl=http://localhost/ --theme=cstate --themesDir=../.. --verbose
# new command partially works for v5.0.2; does not load images from static/
# for this you need to be in the theme root
hugo serve --config=exampleSite/config.yml --theme=../ --contentDir=exampleSite/content
A special thanks to all the contributors!
Note about versions
We use semantic versioning. Version numbers are logged in the console (JS partial), the HTML — the meta[generator]
tag (meta partial), and API index (index.json).
Please login to review this project.
No reviews for this project yet.
Comments (0)
Please login to join the discussion on this project.