Skip to content

schech1/uptime-buddy

Repository files navigation

Uptime Mate

Uptime Buddy has been renamed to Uptime Mate.

GitHub Repo stars Docker pulls Static Badge Static Badge

App Store Link

Uptime Mate is an uptime monitoring tool for your Apple Watch, designed to keep you informed about the status of your services. Uptime Mate, requires a lightweight docker backend to run.

Apple Watch with Uptime Mate Apple Watch with Uptime Mate Apple Watch with Uptime Mate
Apple Watch with Uptime Mate Apple Watch with Uptime Mate Apple Watch with Uptime Mate

Prerequisites in the Uptime Mate iOS-App

For authentication, start the Uptime Mate iOS-App before you deploy the docker-container. On first start, a token will be generated and displayed in the app. Add the token to the docker-compose file or docker-run command. Then deploy the container as described below.

Settings on the iOS App

Before deploying the Docker container, open the Uptime Mate companion app on your iPhone. Follow the these steps to configure Uptime Mate:

  • Generate the token
  • Enter your backend address (Address where you host this container, including the port (e.g.http://your-server-ip:5005))
  • Test the backend
  • Copy the generated token into your docker-compose.yml and deploy it.
  • Send the setting to the Apple Watch. It will display your monitors from Uptime Kuma in the Apple Watch app
  • Check out the Watch Face complications

Apple Watch with Uptime Buddy

Installation via Docker

Uptime Mate requires a running instance of Uptime Kuma!

Be sure to set up Uptime Kuma correctly and provide the address, username and password of your Uptime Kuma instance to the docker compose file.

If you disabled authentication in Uptime Kuma, remove the two lines from the compose-file entirely:

- USERNAME=YOUR_UPTIME_KUMA_USERNAME
- PASSWORD=YOUR_UPTIME_KUMA_PASSWORD

Follow the steps below to set up the backend for Uptime Mate.

Docker Compose (recommended)

Create a docker-compose.yml file with the following content to deploy the backend:

version: '3.8'

services:
  uptime-buddy-api:
    image: schech1/uptime-buddy-api:latest
    restart: always
    ports:
      - "5005:5005" # If you change the port, also change the PORT Env var
    environment:
      - UPTIME_KUMA_URL=YOUR_UPTIME_KUMA_URL # e.g. http://192.168.1.34:3002/
      - EXTERNAL_URL=YOUR_EXTERNAL_URL_FOR_THE_BACKEND # Optional: e.g. https://uptime.domain.com Use this if you want to use the Qr code feature
      - USERNAME=YOUR_UPTIME_KUMA_USERNAME #Optional: remove line if auth is disabled in Uptime Kuma
      - PASSWORD=YOUR_UPTIME_KUMA_PASSWORD #Optional: remove line if auth is disabled in Uptime Kuma
      - TOKEN=SECRET_TOKEN # Created by iOS-App
      - PORT=NEW_PORT # If you change the port above, adjust this var accordingly. E.g. 5003
      - MFA=false #Is 2FA enabled in Uptime Kuma?

Docker image on DockerHub

The docker image supports amd64 and arm64 architecture.

Tested on Raspberry Pi 5 and Intel NUC 10.

Replace the environment variables with your actual Uptime Kuma URL, username, password and the generated token.

Deploying the Backend

Using docker-compose

Save the docker-compose.yml file.

Run the following command in the directory containing the docker-compose.yml file:

docker-compose up -d

This command will pull the necessary Docker image and start the backend service on port 5005.

Using docker run (alternative)

Hint: Remove USERNAME and PASSWORD, if authentication is disabled in Uptime Kuma

docker run -d --name uptime-buddy-api \
  -p 5005:5005 \
  -e UPTIME_KUMA_URL=YOUR_UPTIME_KUMA_URL \
  -e EXTERNAL_URL=YOUR_EXTERNAL_URL_FOR_THE_BACKEND \
  -e USERNAME=YOUR_UPTIME_KUMA_USERNAME \
  -e PASSWORD=YOUR_UPTIME_KUMA_PASSWORD \
  -e TOKEN=SECRET_TOKEN \
  -e PORT=5005 \
  -e MFA=false \
  schech1/uptime-buddy-api:latest

The Apple Watch and iOS App

Uptime Mate consists of an iOS app and an Apple Watch app. The iOS app is needed to set up the backend address and token. When the iOS app is installed, the Apple Watch app can be installed via the Watch app of the iPhone.

Uptime Mate comes with Complication and SmartStack support. The current update frequency of the Widgets is 15 minutes. In future versions this will frequency will be individually adjustable, to extend battery life of the Apple Watch.

Symbols on the Apple Watch

The following SF Symbols are used to illustrate the monitor type:

Apple Watch with Uptime Mate

Complications

Uptime Mate supports different complications on the WatchFace.

Circular

Circular

Corner

Corner

Rectangular Big

Rectangular Big

Rectangular Small

Rectangular Small

Rectangular Big

Rectangular Dashed

Rectangular Small

Circular Dashed

Data Privacy

Uptime Mate does not save, share or forward any data. The data that is fetched from the backend is only displayed on your device. The Apple Watch or iOS apps do not store any data locally on the devices, except the address of your backend. This is needed to keep setting over reboots.

Related Projects

This project is based on Uptime Kuma and uptime-kuma-api.

Uptime Kuma: A self-hosted monitoring tool to monitor uptime for websites, applications and services.

uptime-kuma-api: A Python API for Uptime Kuma.

Contributing

Contributions are welcome.

Support Me

If you enjoy using this app, please consider leaving a Rating on the App Store!

If you encounter any issues or have questions, please open an issue on this GitHub repository.