Няма описание

James Read a4fe32b6c1 chore(deps): bump github.com/grpc-ecosystem/grpc-gateway/v2 from 2.27.8 to 2.28.0 in /service (#891) преди 4 месеца
.github 2c7b33b730 chore: Dep update 2025-07-09 (#613) преди 1 година
.vscode 7d020873d6 fix: #672 Empty execution tracking ID in InternalLogEntry (backport to release/2k) преди 8 месеца
integration-tests 7a327b133d chore: dep update преди 4 месеца
proto a8ac719af7 feat kill acl (#618) преди 11 месеца
service ccfbbb16e9 chore(deps): bump github.com/grpc-ecosystem/grpc-gateway/v2 in /service преди 4 месеца
var e559c32c37 doc screenshots (#614) преди 1 година
webui.dev 6d8d385edb chore: dep update преди 4 месеца
.dockerignore 286fa43e95 Less junk in the docker image преди 5 години
.gitignore f62711a043 doc: ignore node_modules from 3k преди 7 месеца
.goreleaser.yml 061cf18d09 doc: Make 2k releases no longer "latest" преди 7 месеца
.pre-commit-config.yaml 6b9c6c8b9c refactor: Switch to conventional scripts, rather than custom script (#535) преди 1 година
AI.md f02982b451 docs: Add AI policy (#563) преди 1 година
CODE_OF_CONDUCT.md 35562e5667 Create CODE_OF_CONDUCT.md преди 5 години
CONTRIBUTING.adoc 2981fc4c1f doc: Point pull request template to contributors guide (#549) преди 1 година
Dockerfile 2c7b33b730 chore: Dep update 2025-07-09 (#613) преди 1 година
Dockerfile.arm64 2c7b33b730 chore: Dep update 2025-07-09 (#613) преди 1 година
Dockerfile.armv7 482ef0e5e8 feature: Helper scripts for ssh, themes, etc (#349) преди 2 години
LICENSE f21b38d7a6 Create LICENSE преди 5 години
Makefile aef70c0e1b build: Fix webui codestyle job преди 1 година
README.md e02ce2be4e Update README.md (#637) преди 11 месеца
SECURITY.md 11dad79794 fmt: Added pre-commit, fixed a few lint errors, npn updated webui преди 2 години
config.yaml 9bb17badad docs: Links and make targets преди 1 година

README.md

project logo

OliveTin

OliveTin gives **safe** and **simple** access to predefined shell commands from a web interface. [![Maturity Badge](https://img.shields.io/badge/maturity-Production-brightgreen)](#none) [![Discord](https://img.shields.io/discord/846737624960860180?label=Discord%20Server)](https://discord.gg/jhYWWpNJ3v) [![Awesome](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d2/media/badge.svg)](https://github.com/awesome-selfhosted/awesome-selfhosted#automation) [![CII Best Practices](https://bestpractices.coreinfrastructure.org/projects/5050/badge)](https://bestpractices.coreinfrastructure.org/projects/5050) [![Go Report Card](https://goreportcard.com/badge/github.com/Olivetin/OliveTin)](https://goreportcard.com/report/github.com/OliveTin/OliveTin) [![Build Snapshot](https://github.com/OliveTin/OliveTin/actions/workflows/build-snapshot.yml/badge.svg)](https://github.com/OliveTin/OliveTin/actions/workflows/build-snapshot.yml)

screenshot More screenshots below

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

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-lived commands 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

YouTube 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;

screenshot

Desktop web browser (dark mode);

screenshot

Mobile screen size (responsive layout);

screenshot

No-Nonsense Software Principles

OliveTin follows these principles:

  • Open Source & Free Software: following the Open Source Definition and the Free Software Definition. All code and assets are available under the AGPL-3.0 License.
  • Independent: No company owns the code or is responsible for the projects' governance.
  • Inclusive: No "core", "pro", "premium" or "enterprise" version. The only version is the one you can download and run, and it has all the features.
  • Invisible: No usage tracking, no user tracking, no ads, and no telemetry.
  • Internal: No internet connection required for any functionality.

Documentation

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

You can find instructions in the docs on how to install as a Linux package, Linux Container, on FreeBSD, Windows, MacOS and other platforms, too!