Nav apraksta

jamesread 5adab1091f cicd: Utility to get the latest snapshot 2 gadi atpakaļ
.githooks fadc616a67 doc: Allow "test" for unittests, integration tests, etc 3 gadi atpakaļ
.github 290a2ec91b cicd: upgrade codeql 2 gadi atpakaļ
cmd 50204f8180 feature: #175 Print verison with --version 2 gadi atpakaļ
integration-tests 5adab1091f cicd: Utility to get the latest snapshot 2 gadi atpakaļ
internal c12431d8a3 feature: popupOnStart allows for many feedback options when actions are started (#227) 2 gadi atpakaļ
media 796285c37d Updated screenshots in README 4 gadi atpakaļ
var 5b0cfb5c33 feature: entities wip (#226) 2 gadi atpakaļ
webui.dev 086d8fd21c feature: HTML/JS/CSS minifiction and cache busting 2 gadi atpakaļ
.air.toml 6116e954ba cicd: Useful for development settings 2 gadi atpakaļ
.dockerignore 286fa43e95 Less junk in the docker image 5 gadi atpakaļ
.gitignore 086d8fd21c feature: HTML/JS/CSS minifiction and cache busting 2 gadi atpakaļ
.goreleaser.yml b5e2c8d6b8 cicd: Include all of webui/* in packages now it is processed by parcel 2 gadi atpakaļ
.pre-commit-config.yaml 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
CODE_OF_CONDUCT.md 35562e5667 Create CODE_OF_CONDUCT.md 5 gadi atpakaļ
CONTRIBUTING.adoc 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
Dockerfile 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
Dockerfile.arm64 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
Dockerfile.armv7 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
Jenkinsfile 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
LICENSE f21b38d7a6 Create LICENSE 5 gadi atpakaļ
Makefile 086d8fd21c feature: HTML/JS/CSS minifiction and cache busting 2 gadi atpakaļ
OliveTin.proto 759e747f54 feature: readyz API endpoint support (#225) 2 gadi atpakaļ
OliveTin.service 0acf2cbdea /usr/local/bin as we are not building distro packages 5 gadi atpakaļ
README.md 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
SECURITY.md 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
buf.gen.yaml 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
buf.lock 2ef86beea5 cicd: buf mod update seemed to be needed 3 gadi atpakaļ
buf.yaml 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui 2 gadi atpakaļ
config.yaml c12431d8a3 feature: popupOnStart allows for many feedback options when actions are started (#227) 2 gadi atpakaļ
go.mod 68f04c0912 build(deps): bump golang.org/x/crypto from 0.14.0 to 0.17.0 (#199) 2 gadi atpakaļ
go.sum 68f04c0912 build(deps): bump golang.org/x/crypto from 0.14.0 to 0.17.0 (#199) 2 gadi atpakaļ
tools.go d53c88f314 fmt: gofmt 3 gadi atpakaļ

README.md

OliveTin

project logo

OliveTin gives safe and simple access to predefined shell commands from a web interface.

Discord Awesome CII Best Practices

Go Report Card Build Snapshot

Use cases

Safely give access to commands, for less technical people;

  • eg: Give your family a button to podman restart plex
  • eg: Give junior admins a simple web form with dropdowns, to start your custom script. backupScript.sh --folder {{ customerName }}
  • eg: Enable SSH access to the server for the next 20 mins firewall-cmd --add-service ssh --timeout 20m

Simplify complex commands, make them accessible and repeatable;

  • eg: Expose complex commands on touchscreen tablets stuck on walls around your house. wake-on-lan aa:bb:cc:11:22:33
  • eg: Run long running on your servers from your cell phone. dnf update -y
  • eg: Define complex commands with lots of preset arguments, and turn a few arguments into dropdown select boxes. docker rm {{ container }} && docker create {{ container }} && docker start {{ container }}

Join the community on Discord to talk with other users about use cases, or to ask for support in getting started.

YouTube demo video (6 mins)

6 minute demo video

Features

  • Responsive, touch-friendly UI - great for tablets and mobile
  • Super simple config in YAML - because if it's not YAML now-a-days, it's not "cloud native" :-)
  • Dark mode - for those of you that roll that way.
  • Accessible - passes all the accessibility checks in Firefox, and issues with accessibility are taken seriously.
  • Container - available for quickly testing and getting it up and running, great for the selfhosted community.
  • Integrate with anything - OliveTin just runs Linux shell commands, so theoretially you could integrate with a bunch of stuff just by using curl, ping, etc. However, writing your own shell scripts is a great way to extend OliveTin.
  • Lightweight on resources - uses only a few MB of RAM and barely any CPU. Written in Go, with a web interface written as a modern, responsive, Single Page App that uses the REST/gRPC API.
  • Good amount of unit tests and style checks - helps potential contributors be consistent, and helps with maintainability.

Screenshots

Desktop web browser;

Desktop screenshot

Desktop web browser (dark mode);

Desktop screenshot

Mobile screen size (responsive layout);

Mobile screenshot

Documentation

All documentation can be found at http://docs.olivetin.app . This includes installation and usage guide, etc.

Quickstart reference for config.yaml

This is a quick example of config.yaml - but again, lots of documentation for how to write your config.yaml can be found at the documentation site.

Put this config.yaml in /etc/OliveTin/ if you're running a standard service, or mount it at /config if running in a container.

# Listen on all addresses available, port 1337
listenAddressSingleHTTPFrontend: 0.0.0.0:1337

# Choose from INFO (default), WARN and DEBUG
logLevel: "INFO"

# Actions (buttons) to show up on the WebUI:
actions:
  # Docs: https://docs.olivetin.app/action-container-control.html
- title: Restart Plex
  icon: restart
  shell: docker restart plex

  # This will send 1 ping
  # Docs: https://docs.olivetin.app/action-ping.html
- title: Ping host
  shell: ping {{ host }} -c {{ count }}
  icon: ping
  arguments:
    - name: host
      title: host
      type: ascii_identifier
      default: example.com

    - name: count
      title: Count
      type: int
      default: 1

  # Restart http on host "webserver1"
  # Docs: https://docs.olivetin.app/action-ssh.html
- title: restart httpd
  icon: restart
  shell: ssh root@webserver1 'service httpd restart'

A full example config can be found at in this repository - config.yaml.