Skip to content

Commit

Permalink
initial commits for IT-TOOLS
Browse files Browse the repository at this point in the history
  • Loading branch information
compgeniuses committed Mar 8, 2024
1 parent 5a4d950 commit a9d2e3a
Show file tree
Hide file tree
Showing 23 changed files with 135 additions and 279 deletions.
2 changes: 1 addition & 1 deletion .devcontainer/devcontainer.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// For format details, see https://aka.ms/devcontainer.json. For config options, see the README at:
// https://github.com/microsoft/vscode-dev-containers/tree/v0.245.2/containers/javascript-node
{
"name": "ns8-kickstart",
"name": "ns8-it-tools",
"image": "mcr.microsoft.com/devcontainers/javascript-node:0-18-bullseye",
// Configure tool-specific properties.
"customizations": {
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/clean-registry.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,5 @@ jobs:
steps:
- uses: NethServer/ns8-github-actions/.github/actions/delete-image@v1
with:
images: "kickstart"
images: "it-tools"
delete_image_token: ${{ secrets.IMAGES_CLEANUP_TOKEN }}
77 changes: 26 additions & 51 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,48 +1,23 @@
# ns8-kickstart
# ns8-it-tools

This is a template module for [NethServer 8](https://github.com/NethServer/ns8-core).
To start a new module from it:
This is a nehserver 8 App for [IT TEch Tools](https://github.com/CorentinTh/it-tools).
Useful tools for developer and people working in IT.

1. Click on [Use this template](https://github.com/NethServer/ns8-kickstart/generate).
Name your repo with `ns8-` prefix (e.g. `ns8-mymodule`).
Do not end your module name with a number, like ~~`ns8-baaad2`~~!

1. Clone the repository, enter the cloned directory and
[configure your GIT identity](https://git-scm.com/book/en/v2/Getting-Started-First-Time-Git-Setup#_your_identity)

1. Rename some references inside the repo:
```
modulename=$(basename $(pwd) | sed 's/^ns8-//') &&
git mv imageroot/systemd/user/kickstart.service imageroot/systemd/user/${modulename}.service &&
git mv imageroot/systemd/user/kickstart-app.service imageroot/systemd/user/${modulename}-app.service &&
git mv tests/kickstart.robot tests/${modulename}.robot &&
sed -i "s/kickstart/${modulename}/g" $(find .github/ * -type f) &&
git commit -a -m "Repository initialization"
```

1. Edit this `README.md` file, by replacing this section with your module
description

1. Adjust `.github/workflows` to your needs. `clean-registry.yml` might
need the proper list of image names to work correctly. Unused workflows
can be disabled from the GitHub Actions interface.

1. Commit and push your local changes

## Install

Instantiate the module with:

add-module ghcr.io/nethserver/kickstart:latest 1
add-module ghcr.io/geniusdynamics/it-tools:latest 1

The output of the command will return the instance name.
Output example:

{"module_id": "kickstart1", "image_name": "kickstart", "image_url": "ghcr.io/nethserver/kickstart:latest"}
{"module_id": "it-tools1", "image_name": "it-tools", "image_url": "ghcr.io/geniusdynamics/it-tools:latest"}

## Configure

Let's assume that the mattermost instance is named `kickstart1`.
Let's assume that the mattermost instance is named `it-tools1`.

Launch `configure-module`, by setting the following parameters:
- `host`: a fully qualified domain name for the application
Expand All @@ -53,31 +28,31 @@ Launch `configure-module`, by setting the following parameters:
Example:

```
api-cli run configure-module --agent module/kickstart1 --data - <<EOF
api-cli run configure-module --agent module/it-tools1 --data - <<EOF
{
"host": "kickstart.domain.com",
"host": "it-tools.domain.com",
"http2https": true,
"lets_encrypt": false
}
EOF
```

The above command will:
- start and configure the kickstart instance
- start and configure the it-tools instance
- configure a virtual host for trafik to access the instance

## Get the configuration
You can retrieve the configuration with

```
api-cli run get-configuration --agent module/kickstart1
api-cli run get-configuration --agent module/it-tools1
```

## Uninstall

To uninstall the instance:

remove-module --no-preserve kickstart1
remove-module --no-preserve it-tools1

## Smarthost setting discovery

Expand All @@ -86,14 +61,14 @@ Some configuration settings, like the smarthost setup, are not part of the
Redis keys. To ensure the module is always up-to-date with the
centralized [smarthost
setup](https://nethserver.github.io/ns8-core/core/smarthost/) every time
kickstart starts, the command `bin/discover-smarthost` runs and refreshes
it-tools starts, the command `bin/discover-smarthost` runs and refreshes
the `state/smarthost.env` file with fresh values from Redis.

Furthermore if smarthost setup is changed when kickstart is already
Furthermore if smarthost setup is changed when it-tools is already
running, the event handler `events/smarthost-changed/10reload_services`
restarts the main module service.

See also the `systemd/user/kickstart.service` file.
See also the `systemd/user/it-tools.service` file.

This setting discovery is just an example to understand how the module is
expected to work: it can be rewritten or discarded completely.
Expand All @@ -102,62 +77,62 @@ expected to work: it can be rewritten or discarded completely.

some CLI are needed to debug

- The module runs under an agent that initiate a lot of environment variables (in /home/kickstart1/.config/state), it could be nice to verify them
- The module runs under an agent that initiate a lot of environment variables (in /home/it-tools1/.config/state), it could be nice to verify them
on the root terminal

`runagent -m kickstart1 env`
`runagent -m it-tools1 env`

- you can become runagent for testing scripts and initiate all environment variables

`runagent -m kickstart1`
`runagent -m it-tools1`

the path become :
```
echo $PATH
/home/kickstart1/.config/bin:/usr/local/agent/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/
/home/it-tools1/.config/bin:/usr/local/agent/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/
```

- if you want to debug a container or see environment inside
`runagent -m kickstart1`
`runagent -m it-tools1`
```
podman ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d292c6ff28e9 localhost/podman-pause:4.6.1-1702418000 9 minutes ago Up 9 minutes 127.0.0.1:20015->80/tcp 80b8de25945f-infra
d8df02bf6f4a docker.io/library/mariadb:10.11.5 --character-set-s... 9 minutes ago Up 9 minutes 127.0.0.1:20015->80/tcp mariadb-app
9e58e5bd676f docker.io/library/nginx:stable-alpine3.17 nginx -g daemon o... 9 minutes ago Up 9 minutes 127.0.0.1:20015->80/tcp kickstart-app
9e58e5bd676f docker.io/library/nginx:stable-alpine3.17 nginx -g daemon o... 9 minutes ago Up 9 minutes 127.0.0.1:20015->80/tcp it-tools-app
```

you can see what environment variable is inside the container
```
podman exec kickstart-app env
podman exec it-tools-app env
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
TERM=xterm
PKG_RELEASE=1
MARIADB_DB_HOST=127.0.0.1
MARIADB_DB_NAME=kickstart
MARIADB_DB_NAME=it-tools
MARIADB_IMAGE=docker.io/mariadb:10.11.5
MARIADB_DB_TYPE=mysql
container=podman
NGINX_VERSION=1.24.0
NJS_VERSION=0.7.12
MARIADB_DB_USER=kickstart
MARIADB_DB_PASSWORD=kickstart
MARIADB_DB_USER=it-tools
MARIADB_DB_PASSWORD=it-tools
MARIADB_DB_PORT=3306
HOME=/root
```

you can run a shell inside the container

```
podman exec -ti kickstart-app sh
podman exec -ti it-tools-app sh
/ #
```
## Testing

Test the module using the `test-module.sh` script:


./test-module.sh <NODE_ADDR> ghcr.io/nethserver/kickstart:latest
./test-module.sh <NODE_ADDR> ghcr.io/nethserver/it-tools:latest

The tests are made using [Robot Framework](https://robotframework.org/)

Expand Down
14 changes: 7 additions & 7 deletions build-images.sh
Original file line number Diff line number Diff line change
Expand Up @@ -11,24 +11,24 @@ set -e
# Prepare variables for later use
images=()
# The image will be pushed to GitHub container registry
repobase="${REPOBASE:-ghcr.io/nethserver}"
repobase="${REPOBASE:-ghcr.io/geniusdynamics}"
# Configure the image name
reponame="kickstart"
reponame="it-tools"

# Create a new empty container image
container=$(buildah from scratch)

# Reuse existing nodebuilder-kickstart container, to speed up builds
if ! buildah containers --format "{{.ContainerName}}" | grep -q nodebuilder-kickstart; then
# Reuse existing nodebuilder-it-tools container, to speed up builds
if ! buildah containers --format "{{.ContainerName}}" | grep -q nodebuilder-it-tools; then
echo "Pulling NodeJS runtime..."
buildah from --name nodebuilder-kickstart -v "${PWD}:/usr/src:Z" docker.io/library/node:lts
buildah from --name nodebuilder-it-tools -v "${PWD}:/usr/src:Z" docker.io/library/node:lts
fi

echo "Build static UI files with node..."
buildah run \
--workingdir=/usr/src/ui \
--env="NODE_OPTIONS=--openssl-legacy-provider" \
nodebuilder-kickstart \
nodebuilder-it-tools \
sh -c "yarn install && yarn build"

# Add imageroot directory to the container image
Expand All @@ -45,7 +45,7 @@ buildah config --entrypoint=/ \
--label="org.nethserver.authorizations=traefik@node:routeadm" \
--label="org.nethserver.tcp-ports-demand=1" \
--label="org.nethserver.rootfull=0" \
--label="org.nethserver.images=docker.io/mariadb:10.11.5 docker.io/nginx:stable-alpine3.17" \
--label="org.nethserver.images=docker.io/corentinth/it-tools:latest" \
"${container}"
# Commit the image
buildah commit "${container}" "${repobase}/${reponame}"
Expand Down
2 changes: 1 addition & 1 deletion imageroot/actions/configure-module/80start_services
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,4 @@ exec 1>&2

touch smarthost.env

systemctl --user enable --now kickstart.service
systemctl --user enable --now it-tools.service
10 changes: 5 additions & 5 deletions imageroot/actions/configure-module/validate-input.json
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
{
"$schema": "http://json-schema.org/draft-07/schema#",
"title": "Configure kickstart",
"$id": "http://nethserver.org/json-schema/task/input/kickstart/configure-module",
"description": "Configure kickstart",
"title": "Configure it-tools",
"$id": "http://nethserver.org/json-schema/task/input/it-tools/configure-module",
"description": "Configure it-tools",
"examples": [
{
"host": "kickstart.domain.org",
"host": "it-tools.domain.org",
"http2https": true,
"lets_encrypt": true
}
Expand All @@ -19,7 +19,7 @@
"properties": {
"host": {
"type": "string",
"description": "Host name for the application, like 'kickstart.domain.org'",
"description": "Host name for the application, like 'it-tools.domain.org'",
"format": "hostname",
"pattern": "\\."
},
Expand Down
10 changes: 5 additions & 5 deletions imageroot/actions/get-configuration/validate-output.json
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
{
"$schema": "http://json-schema.org/draft-07/schema#",
"title": "Get kickstart settings",
"$id": "http://nethserver.org/json-schema/task/input/kickstart/get-configuration",
"description": "Get kickstart settings",
"title": "Get it-tools settings",
"$id": "http://nethserver.org/json-schema/task/input/it-tools/get-configuration",
"description": "Get it-tools settings",
"examples": [
{
"host": "kickstart.domain.org",
"host": "it-tools.domain.org",
"http2https": true,
"lets_encrypt": true
}
Expand All @@ -19,7 +19,7 @@
"properties": {
"host": {
"type": "string",
"description": "Host name for the application, like 'kickstart.domain.org'",
"description": "Host name for the application, like 'it-tools.domain.org'",
"format": "idn-hostname"
},
"lets_encrypt": {
Expand Down
41 changes: 0 additions & 41 deletions imageroot/actions/restore-module/40restore_database

This file was deleted.

8 changes: 0 additions & 8 deletions imageroot/bin/module-cleanup-state

This file was deleted.

21 changes: 0 additions & 21 deletions imageroot/bin/module-dump-state

This file was deleted.

4 changes: 2 additions & 2 deletions imageroot/etc/state-include.conf
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,6 @@
# List here what you want to save during backup : volumes or file Path


state/kickstart.sql
volumes/kickstart-app
#state/kickstart.sql
#volumes/kickstart-app

2 changes: 1 addition & 1 deletion imageroot/events/smarthost-changed/10reload_services
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,4 @@

set -e

systemctl --user try-reload-or-restart kickstart.service
systemctl --user try-reload-or-restart it-tools.service
Loading

0 comments on commit a9d2e3a

Please sign in to comment.