Written by Llewellyn van der Merwe (@llewellynvdm)
A simple CLI utility to coordinate one-time initialization and cleanup across multiple programs or scripts.
Runs a specified init command when the first program starts, and a cleanup command when the last program stops.
Uses a shared lock directory to track active programs and prevent duplicate init/cleanup runs.
Supports .json configuration files and CLI overrides for full flexibility.
Linted by #ShellCheck
$ sudo curl -L "https://raw.githubusercontent.com/octoleo/octodinator/refs/heads/master/src/octodinator" -o /usr/local/bin/octodinator
$ sudo chmod +x /usr/local/bin/octodinator- Global config file can be set at: /home/$USER/.config/octodinator/config.json
- OR use the --conf=/path/to/config.jsonflag to load a project-specific configuration.
Configuration File (config.json):
{
  "lock_dir": "/tmp/octodinator",
  "init_command": "octoflare --domain=example.com --disable-attack-mode",
  "cleanup_command": "octoflare --domain=example.com --enable-attack-mode"
}- lock_dir: Required. Directory used to store- .lockfiles for running programs.
- init_command: Required. Command to run when the first program starts.
- cleanup_command: Required. Command to run when the last program stops.
To see the help menu
$ octodinator -hTo update
$ octodinator --updateTo uninstall
$ octodinator --uninstallUsage: octodinator [options] start|stop <id>
        Options
        ======================================================
        -ld | --lock-dir=<path>   Directory where lock files are stored
        -i  | --init=<command>    Command to run on first program start
        -c  | --cleanup=<command> Command to run on last program stop
        --conf=<path>             JSON config file with {lock_dir, init_command, cleanup_command}
        -q  | --quiet             Suppress all output
        --update                  Update this script to latest version
        --uninstall               Uninstall this script
        -h  | --help              Show this help menu
        ======================================================
                        Octodinator v1.0.0
        ======================================================Start a program and trigger the init command if this is the first active one:
$ octodinator --lock-dir="/tmp/octodinator" \
              --init="octoflare --domain=example.com --disable-attack-mode" \
              --cleanup="octoflare --domain=example.com --enable-attack-mode" \
              start program1Stop a program and trigger cleanup only if this was the last active one:
$ octodinator --lock-dir="/tmp/octodinator" stop program1Using a config file:
$ octodinator --conf=/home/$USER/.config/octodinator/config.json start program2
$ octodinator --conf=/home/$USER/.config/octodinator/config.json stop program2In a script (programA.sh):
#!/bin/bash
octodinator start programA
# Program logic here
sleep 5
octodinator stop programAWhen running multiple scripts with the same --lock-dir,
init runs once at the first start, cleanup runs once at the very end.
@copyright  Copyright (C) 2025 Llewellyn van der Merwe. All rights reserved.
@license    GNU General Public License version 2; see LICENSE.txt