2020-06-28 21:42:07 -07:00
<h1 align="center">
2021-09-25 12:12:22 +02:00
<img
width="180"
alt="Homer's donut"
src="https://raw.githubusercontent.com//bastienwirtz/homer/main/public/logo.png">
2020-06-28 21:42:07 -07:00
<br/>
Homer
</h1>
<h4 align="center">
2021-09-25 12:12:22 +02:00
A dead simple static <strong>HOM</strong>epage for your serv<strong>ER</strong> to keep your services on hand, from a simple <code>yaml</code> configuration file.
2020-06-28 21:42:07 -07:00
</h4>
2022-10-28 10:24:38 +02:00
<p align="center">
<a href="https://www.buymeacoffee.com/bastien" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/default-yellow.png" alt="Buy Me A Coffee" height="41" width="174"></a>
<p>
2020-06-28 21:42:07 -07:00
<p align="center">
2021-09-25 12:12:22 +02:00
<strong>
<a href="https://homer-demo.netlify.app">Demo</a>
•
<a href="https://gitter.im/homer-dashboard/community">Chat</a>
•
<a href="#getting -started">Getting started</a>
</strong>
2020-06-28 21:42:07 -07:00
</p>
<p align="center">
2021-09-25 12:12:22 +02:00
<a href="https://opensource.org/licenses/Apache-2.0"><img
alt="License: Apache 2"
src="https://img.shields.io/badge/License-Apache%202.0-blue.svg"></a>
2020-06-28 21:42:07 -07:00
<a href="https://gitter.im/homer-dashboard/community?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge"><img
2021-09-25 12:12:22 +02:00
alt="Gitter chat"
src="https://badges.gitter.im/homer-dashboard/community.svg"></a>
2020-06-28 21:42:07 -07:00
<a href="https://github.com/bastienwirtz/homer/releases/latest/download/homer.zip"><img
2021-09-25 12:12:22 +02:00
alt="Download homer static build"
src="https://img.shields.io/badge/Download-homer.zip-orange"></a>
2022-09-01 15:29:12 +02:00
<a href="https://twitter.com/acdlite/status/974390255393505280"><img
alt="speed-blazing"
src="https://img.shields.io/badge/speed-blazing%20%F0%9F%94%A5-red"></a>
2021-09-25 12:12:22 +02:00
<a href="https://github.com/awesome-selfhosted/awesome-selfhosted"><img
alt="Awesome"
src="https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg"></a>
2020-06-28 21:42:07 -07:00
</p>
<p align="center">
2021-09-25 12:12:22 +02:00
<img src="https://raw.github.com/bastienwirtz/homer/main/docs/screenshot.png" width="100%">
2020-06-28 21:42:07 -07:00
</p>
2020-03-26 19:12:43 +00:00
2020-06-05 22:56:53 -07:00
## Table of Contents
2021-09-25 12:12:22 +02:00
2020-06-05 22:56:53 -07:00
- [Features ](#features )
- [Getting started ](#getting-started )
2024-05-18 08:41:38 +02:00
- [Kubernetes Installation ](docs/kubernetes.md )
2020-06-11 22:40:36 -07:00
- [Configuration ](docs/configuration.md )
2024-06-07 11:54:19 +02:00
- [Theming ](docs/theming.md )
2021-07-14 15:48:57 +02:00
- [Custom services ](docs/customservices.md )
2020-06-11 22:40:36 -07:00
- [Tips & tricks ](docs/tips-and-tricks.md )
2020-10-25 21:12:37 -07:00
- [Development ](docs/development.md )
2021-09-25 12:13:04 +02:00
- [Troubleshooting ](docs/troubleshooting.md )
2020-03-26 19:12:43 +00:00
2020-06-05 22:56:53 -07:00
## Features
2021-09-25 12:12:22 +02:00
2020-06-05 22:56:53 -07:00
- [yaml ](http://yaml.org/ ) file configuration
- Installable (pwa)
- Search
2020-11-14 13:25:01 +01:00
- Grouping
2020-06-05 22:56:53 -07:00
- Theme customization
2022-01-14 00:45:26 -05:00
- Offline health check
2020-06-05 22:56:53 -07:00
- keyboard shortcuts:
- `/` Start searching.
- `Escape` Stop searching.
- `Enter` Open the first matching result (respects the bookmark's `_target` property).
- `Alt` /`Option` + `Enter` Open the first matching result in a new tab.
2018-06-13 22:14:05 -07:00
2020-06-05 22:56:53 -07:00
## Getting started
2020-03-22 15:51:54 -07:00
2022-06-29 23:02:10 +02:00
Homer is a full static html/js dashboard, based on a simple yaml configuration file. See [documentation ](docs/configuration.md ) for information about the configuration (`assets/config.yml` ) options.
2020-02-27 15:13:48 -08:00
2022-06-29 23:02:10 +02:00
It's meant to be served by an HTTP server, **it will not work if you open the index.html directly over file:// protocol ** .
2020-06-11 22:40:36 -07:00
2020-02-27 15:13:48 -08:00
### Using docker
```sh
2021-02-15 22:23:16 -08:00
docker run -d \
-p 8080:8080 \
-v </your/local/assets/>:/www/assets \
--restart=always \
b4bz/homer:latest
2020-02-27 15:13:48 -08:00
```
2022-06-29 23:02:10 +02:00
The container will run using a user uid and gid 1000. Add `--user <your-UID>:<your-GID>` to the docker command to adjust it. Make sure this match the ownership of your assets directory.
**Environment variables:**
2022-04-10 11:55:11 +02:00
* **`INIT_ASSETS` ** (default: `1` )
2022-05-03 13:00:49 -04:00
Install example configuration file & assets (favicons, ...) to help you get started.
2020-06-06 23:15:27 -07:00
2022-04-10 11:55:11 +02:00
* **`SUBFOLDER` ** (default: `null` )
If you would like to host Homer in a subfolder, (ex: * http://my-domain/ * *homer***), set this to the subfolder path (ex `/homer` ).
2021-06-21 19:33:21 +02:00
2022-07-28 16:00:57 +07:00
* **`PORT` ** (default: `8080` )
If you would like to change internal port of Homer from default `8080` to your port choice.
2023-09-25 20:17:08 -04:00
* **`IPV6_DISABLE` ** (default: 0)
Set to `1` to disable listening on IPv6.
2022-07-28 16:00:57 +07:00
2022-06-29 23:02:10 +02:00
#### With docker-compose
2021-06-21 19:33:21 +02:00
2022-06-29 23:02:10 +02:00
A [`docker-compose.yml` ](docker-compose.yml ) file is available as an example. It must be edited to match your needs. You probably want to adjust the port mapping and volume binding (equivalent to `-p` and `-v` arguments).
2020-06-29 21:39:47 +02:00
2022-04-10 11:55:11 +02:00
Then launch the container:
2020-06-29 21:39:47 +02:00
```sh
2022-04-10 11:55:11 +02:00
cd /path/to/docker-compose.yml/
2020-06-29 21:39:47 +02:00
docker-compose up -d
```
2020-06-05 22:56:53 -07:00
### Using the release tarball (prebuilt, ready to use)
2020-05-25 15:07:03 -07:00
2021-09-25 12:12:22 +02:00
Download and extract the latest release (`homer.zip` ) from the [release page ](https://github.com/bastienwirtz/homer/releases ), rename the `assets/config.yml.dist` file to `assets/config.yml` , and put it behind a web server.
2020-11-14 13:25:01 +01:00
2020-05-25 15:07:03 -07:00
```sh
2020-06-05 22:56:53 -07:00
wget https://github.com/bastienwirtz/homer/releases/latest/download/homer.zip
unzip homer.zip
cd homer
2020-06-23 22:56:33 -07:00
cp assets/config.yml.dist assets/config.yml
2020-06-05 22:56:53 -07:00
npx serve # or python -m http.server 8010 or apache, nginx ...
2020-05-25 15:07:03 -07:00
```
2020-06-05 22:56:53 -07:00
### Build manually
2020-05-25 15:07:03 -07:00
```sh
2024-04-22 19:55:25 +02:00
pnpm install
pnpm build
2020-05-25 15:07:03 -07:00
```
2020-06-05 22:56:53 -07:00
Then your dashboard is ready to use in the `/dist` directory.