| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315 |
- # There is a built-in micro proxy that will host the webui and REST API all on
- # one port (this is called the "Single HTTP Frontend") and means you just need
- # one open port in the container/firewalls/etc.
- #
- # Listen on all addresses available, port 1337
- listenAddressSingleHTTPFrontend: 0.0.0.0:1337
- # Choose from INFO (default), WARN and DEBUG
- logLevel: "INFO"
- # Checking for updates https://docs.olivetin.app/reference/updateChecks.html
- checkForUpdates: false
- # Actions are commands that are executed by OliveTin, and normally show up as
- # buttons on the WebUI.
- #
- # Docs: https://docs.olivetin.app/action_execution/create_your_first.html
- actions:
- # This is the most simple action, it just runs the command and flashes the
- # button to indicate status.
- #
- # If you are running OliveTin in a container remember to pass through the
- # docker socket! https://docs.olivetin.app/solutions/container-control-panel/index.html
- - title: Ping the Internet
- shell: ping -c 3 1.1.1.1
- icon: ping
- popupOnStart: execution-dialog-stdout-only
- # This uses `popupOnStart: execution-dialog-stdout-only` to simply show just
- # the command output.
- - title: Check disk space
- icon: disk
- shell: df -h /media
- popupOnStart: execution-dialog-stdout-only
- # This uses `popupOnStart: execution-dialog` to show a dialog with more
- # information about the command that was run.
- - title: check dmesg logs
- shell: dmesg | tail
- icon: logs
- popupOnStart: execution-dialog
- # This uses `popupOnStart: execution-button` to display a mini button that
- # links to the logs.
- #
- # You can also rate-limit actions too.
- - title: date
- shell: date
- timeout: 6
- icon: clock
- popupOnStart: execution-button
- maxRate:
- - limit: 3
- duration: 5m
- # You are not limited to operating system commands, and of course you can run
- # your own scripts. Here `maxConcurrent` stops the script running multiple
- # times in parallel. There is also a timeout that will kill the command if it
- # runs for too long.
- - title: Run backup script
- shell: /opt/backupScript.sh
- shellAfterCompleted: "apprise -t 'Notification: Backup script completed' -b 'The backup script completed with code {{ exitCode}}. The log is: \n {{ output }} '"
- maxConcurrent: 1
- timeout: 10
- icon: backup
- popupOnStart: execution-dialog
- # When you want to prompt users for input, that is when you should use
- # `arguments` - this presents a popup dialog and asks for argument values.
- #
- # Docs: https://docs.olivetin.app/action_examples/ping.html
- - title: Ping host
- id: ping_host
- shell: ping {{ host }} -c {{ count }}
- icon: ping
- timeout: 100
- popupOnStart: execution-dialog-stdout-only
- arguments:
- - name: host
- title: Host
- type: ascii_identifier
- default: example.com
- description: The host that you want to ping
- - name: count
- title: Count
- type: int
- default: 3
- description: How many times to do you want to ping?
- # OliveTin can control containers - docker is just a command line app.
- #
- # However, if you are running in a container you will need to do some setup,
- # see the docs below.
- #
- # Docs: https://docs.olivetin.app/solutions/container-control-panel/index.html
- - title: Restart Docker Container
- icon: restart
- shell: docker restart {{ container }}
- arguments:
- - name: container
- title: Container name
- choices:
- - value: plex
- - value: traefik
- - value: grafana
- # There is a special `confirmation` argument to help against accidental clicks
- # on "dangerous" actions.
- #
- # Docs: https://docs.olivetin.app/args/input_confirmation.html
- - title: Delete old backups
- icon: ashtonished
- shell: rm -rf /opt/oldBackups/
- arguments:
- - type: html
- title: Description
- default:
- The documentation for this action can be found at <a href = "example.com">example.com</a>.
- - type: confirmation
- title: Are you sure?!
- # This is an action that runs a script included with OliveTin, that will
- # download themes. You will still need to set theme "themeName" in your config.
- #
- # Docs: https://docs.olivetin.app/reference/reference_themes_for_users.html
- - title: Get OliveTin Theme
- shell: olivetin-get-theme {{ themeGitRepo }} {{ themeFolderName }}
- icon: theme
- arguments:
- - name: themeGitRepo
- title: Theme's Git Repository
- description: Find new themes at https://olivetin.app/themes
- type: url
- - name: themeFolderName
- title: Theme's Folder Name
- type: ascii_identifier
- # Sometimes you want to run actions on other servers - don't overcomplicate
- # it, just use SSH! OliveTin includes a helper to make this easier, which is
- # entirely optional. You can also setup SSH manually.
- #
- # Docs: https://docs.olivetin.app/action_examples/ssh-easy.html
- # Docs: https://docs.olivetin.app/action_examples/ssh-manual.html
- - title: "Setup easy SSH"
- icon: ssh
- shell: olivetin-setup-easy-ssh
- popupOnStart: execution-dialog
- # Here's how to use SSH with the "easy" config, to restart a service on
- # another server.
- #
- # Docs: https://docs.olivetin.app/action_examples/ssh-easy.html
- # Docs: https://docs.olivetin.app/action_examples/systemd_service.html
- - title: Restart httpd on server1
- id: restart_httpd
- icon: restart
- timeout: 1
- shell: ssh -F /config/ssh/easy.cfg root@server1 'service httpd restart'
- # Lots of people use OliveTin to build web interfaces for their electronics
- # projects. It's best to install OliveTin as a native package (eg, .deb), and
- # then you can use either a python script or the `gpio` command.
- - title: Toggle GPIO light
- shell: gpioset gpiochip1 9=1
- icon: light
- # There are several built-in shortcuts for the `icon` option, but you
- # can also just specify any HTML, this includes any unicode character,
- # or a <img = "..." /> link to a custom icon.
- #
- # Docs: https://docs.olivetin.app/action_customization/icons.html
- #
- # Lots of people use OliveTin to easily execute ansible-playbooks. You
- # probably want a much longer timeout as well (so that ansible completes).
- #
- # Docs: https://docs.olivetin.app/action_examples/ansible.html
- - title: "Run Automation Playbook"
- icon: '🤖'
- shell: ansible-playbook -i /etc/hosts /root/myRepo/myPlaybook.yaml
- timeout: 120
- # The following actions are "dummy" actions, used in a Dashboard. As long as
- # you have these referenced in a dashboard, they will not show up in the
- # `actions` view.
- - title: Ping hypervisor1
- shell: echo "hypervisor1 online"
- - title: Ping hypervisor2
- shell: echo "hypervisor2 online"
- - title: "{{ server.name }} Wake on Lan"
- shell: echo "Sending Wake on LAN to {{ server.hostname }}"
- entity: server
- - title: "{{ server.name }} Power Off"
- shell: "echo 'Power Off Server: {{ server.hostname }}'"
- entity: server
- - title: Ping All Servers
- shell: "echo 'Ping all servers'"
- icon: ping
- - title: Start {{ container.Names }}
- icon: box
- shell: docker start {{ container.Names }}
- entity: container
- triggers: ["Update container entity file"]
- - title: Stop {{ container.Names }}
- icon: box
- shell: docker stop {{ container.Names }}
- entity: container
- triggers: ["Update container entity file"]
- # Lastly, you can hide actions from the web UI, this is useful for creating
- # background helpers that execute only on startup or a cron, for updating
- # entity files.
- # - title: Update container entity file
- # shell: 'docker ps -a --format json > /etc/OliveTin/entities/containers.json'
- # hidden: true
- # execOnStartup: true
- # execOnCron: '*/1 * * * *'
- # An entity is something that exists - a "thing", like a VM, or a Container
- # is an entity. OliveTin allows you to then dynamically generate actions based
- # around these entities.
- #
- # This is really useful if you want to generate wake on lan or poweroff actions
- # for `server` entities, for example.
- #
- # A very popular use case that entities were designed for was for `container`
- # entities - in a similar way you could generate `start`, `stop`, and `restart`
- # container actions.
- #
- # Entities are just loaded fome files on disk, OliveTin will also watch these
- # files for updates while OliveTin is running, and update entities.
- #
- # Entities can have properties defined in those files, and those can be used
- # in your configuration as variables. For example; `container.status`,
- # or `vm.hostname`.
- #
- # Docs: https://docs.olivetin.app/entities/intro.html
- entities:
- # YAML files are the default expected format, so you can use .yml or .yaml,
- # or even .txt, as long as the file contains valid a valid yaml LIST, then it
- # will load properly.
- #
- # Docs: https://docs.olivetin.app/entities/intro.html
- - file: entities/servers.yaml
- name: server
- - file: entities/containers.json
- name: container
- # Dashboards are a way of taking actions from the default "actions" view, and
- # organizing them into groups - either into folders, or fieldsets.
- #
- # The only way to properly use entities, are to use them with a `fieldset` on
- # a dashboard.
- #
- # Docs: https://docs.olivetin.app/dashboards/intro.html
- dashboards:
- # Top level items are dashboards.
- - title: My Servers
- contents:
- - title: All Servers
- type: fieldset
- contents:
- # The contents of a dashboard will try to look for an action with a
- # matching title IF the `contents: ` property is empty.
- - title: Ping All Servers
- # If you create an item with some "contents:", OliveTin will show that as
- # directory.
- - title: Hypervisors
- contents:
- - title: Ping hypervisor1
- - title: Ping hypervisor2
- # If you specify `type: fieldset` and some `contents`, it will show your
- # actions grouped together without a folder.
- - type: fieldset
- entity: server
- title: 'Server: {{ server.hostname }}'
- contents:
- # By default OliveTin will look for an action with a matching title
- # and put it on the dashboard.
- #
- # Fieldsets also support `type: display`, which can display arbitary
- # text. This is useful for displaying things like a container's state.
- - type: display
- title: |
- Hostname: <strong>{{ server.name }}</strong>
- IP Address: <strong>{{ server.ip }}</strong>
- # These are the actions (defined above) that we want on the dashboard.
- - title: '{{ server.name }} Wake on Lan'
- - title: '{{ server.name }} Power Off'
- # This is the second dashboard.
- - title: My Containers
- contents:
- - title: 'Container {{ container.Names }} ({{ container.Image }})'
- entity: container
- type: fieldset
- contents:
- - type: display
- title: |
- {{ container.RunningFor }} <br /><br /><strong>{{ container.State }}</strong>
- - title: 'Start {{ container.Names }}'
- - title: 'Stop {{ container.Names }}'
|