Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ecelis/ianseo-docker

Run i@nseo software for managing archery tournaments results in docker
https://github.com/ecelis/ianseo-docker

archery docker showcase

Last synced: 17 days ago
JSON representation

Run i@nseo software for managing archery tournaments results in docker

Awesome Lists containing this project

README

        

# Ianseo Docker container

Ianseo is a software for managing archery tournaments results

This is an un-official repository, the official site for this software
is http://www.ianseo.net/

## How to use with compose

`compose.yaml`

```
services:
ianseodb:
image: mariadb:lts
environment:
- MARIADB_ROOT_PASSWORD=${MARIADB_ROOT_PASSWORD:-ianseo}
- MARIADB_USER=${MARIADB_USER:-ianseo}
- MARIADB_DATABASE=${MARIADB_DATABASE:-ianseo}
- MARIADB_PASSWORD=${MARIADB_PASSWORD:-ianseo}
restart: always
ianseo:
image: arqueria/ianseo
ports:
- "8080:80"
depends_on:
- ianseodb
restart: always
```

Start the services in the background

```
docker compose up -d
```

Browse to http://localhost:8080 and follow the instructions to
finish the installation.

⚠️ In the **Step 2: Database connection data** of ianseo has a default of
`localhost` for Database host, change it for the name of the MariaDB
container, `ianseodb` in the example above.

⚠️ Fill in the field for the **ADMIN Password to create users and databases**
with the value of the variable `MARIADB_ROOT_PASSWORD` of the MariaDB
container, `ianseo` in the example above.

### Run step by step

The following procedure assumes you created an `.env` file to store the required
environment variables values.

`.env`

```
MARIADB_ROOT_PASSWORD=ianseo
MARIADB_USER=ianseo
MARIADB_DATABASE=ianseo
MARIADB_PASSWORD=ianseo

```

First launch a MariaDB container.

```
docker run -d --env-file .env --name ianseodb mariadb:lts
```

Now launch the ianseo container linked to the database container.

```
docker run -d --name ianseo --link ianseodb:mysql -p 8080:80 arqueria/ianseo
```

Browse to http://127.0.0.1:8080 and follow the instructions to
finish the installation.

## Environment Variables

One of `MARIADB_ROOT_PASSWORD`, `MARIADB_ALLOW_EMPTY_ROOT_PASSWORD`, or
`MARIADB_RANDOM_ROOT_PASSWORD`, is required. The other environment
variables are optional.

**MARIADB_ROOT_PASSWORD / MYSQL_ROOT_PASSWORD**

This specifies the password that will be set for the MariaDB root
superuser account. In the above example, it was set to `ianseo`.

**MARIADB_ALLOW_EMPTY_ROOT_PASSWORD / MYSQL_ALLOW_EMPTY_PASSWORD**

Set to a non-empty value, like yes, to allow the container to be started
with a blank password for the root user. NOTE: Setting this variable to
yes is not recommended unless you really know what you are doing, since
this will leave your MariaDB instance completely unprotected, allowing
anyone to gain complete superuser access.

**MARIADB_RANDOM_ROOT_PASSWORD / MYSQL_RANDOM_ROOT_PASSWORD**

Set to a non-empty value, like yes, to generate a random initial
password for the root user. The generated root password will be printed
to stdout (`GENERATED ROOT PASSWORD: .....`).

**MARIADB_DATABASE / MYSQL_DATABASE**

This variable allows you to specify the name of a database to be created
on image startup.

**MARIADB_USER / MYSQL_USER, MARIADB_PASSWORD / MYSQL_PASSWORD**

These are used in conjunction to create a new user and to set that
user's password. Both user and password variables are required for a
user to be created. This user will be granted all access (corresponding
to `GRANT ALL`) to the `MARIADB_DATABASE` database.

Do note that there is no need to use this mechanism to create the root
superuser, that user gets created by default with the password specified
by the `MARIADB_ROOT_PASSWORD` / `MYSQL_ROOT_PASSWORD` variable.

Refer to the MariaDB official repository for deeper information about
variable environments https://hub.docker.com/_/mariadb

### .env file

You can use an `.env` file to store the required environment variables values.
Copy `sample.env` to `.env` and edit to suit your requirements.

```
cp sample.env .env`
```

## NodeJS development dependency

NodeJS is used to support some tasks related to maitaining the docker image. NodeJS is **NOT REQUIRED** to run ianseo in docker.

If you plan to contribute to this repository install NodeJS and required modules first.

```
npm install
```

## Fetch a newer ianseo releases

```
npm run ianseo:fetch
```

## Build the docker image

To build the ianseo image only for the current CPU architecture run:

```
npm run ianseo:build
```

To build images for x86_64, aarch64 and arm7, run:

```
npm run ianseo:build:multi
```

## Release and Publish images to Docker registries

There are github actions wired to this repository, after mergin a branch into
`main` you must tag the commit to publish with semantic versioning.
Ex: v2022.01.01.1 `vYEAR.MONTH.DAY.REVISION`. Official Ianseo versioning has
integers as **REVISION**, however docker releases may add an alphabetic character
to the **REVISION** integer to support docker releases linked to official ones.

```
git checkout main
git pull
git tag v..

.
git push origin v..
.
```

##### Ernesto Celis notes

Mine is a fork from Brian Nelson's `brian-nelson/ianseo` repository but
mixed with the official release, since Brian's repository seems
unmaintained.

This fork goal is running ianseo in Docker containers. Docker setup is
out of scope.