Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Uberspace/cachet_netbox_sync
import netbox data (circuits, virtual machines, sites, IP adresses, tenants, clusters, ...) into a cachet status page.
https://github.com/Uberspace/cachet_netbox_sync
Last synced: about 2 months ago
JSON representation
import netbox data (circuits, virtual machines, sites, IP adresses, tenants, clusters, ...) into a cachet status page.
- Host: GitHub
- URL: https://github.com/Uberspace/cachet_netbox_sync
- Owner: Uberspace
- Created: 2020-04-11T17:16:57.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-26T22:27:53.000Z (about 2 years ago)
- Last Synced: 2024-11-24T08:42:06.772Z (about 2 months ago)
- Language: Python
- Homepage:
- Size: 44.9 KB
- Stars: 9
- Watchers: 6
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-starred - Uberspace/cachet_netbox_sync - import netbox data (circuits, virtual machines, sites, IP adresses, tenants, clusters, ...) into a cachet status page. (others)
README
# cachet netbox sync
An application to import [netbox] data (circuits, virtual machines, sites, IP
adresses, tenants, clusters, ...) into [cachet]. It saves you from manually
updating your status page inventory when you add a new component to report
status on. All entries can be filtered and grouped arbitrarily as configurated
in a simple plain-text file - no code necessary.```ini
[source.netbox.u6]
endpoint=virtualization.virtual_machines
filters.tenant=uberspace-6
filters.status=1
group_by_field=tenant.name
```This example will fetch all active VMs beloning to Uberspace 6, put them into a
group called "Uberspace 6" and display their status on your cachet instance.[netbox]: https://netbox.readthedocs.io/
[cachet]: https://cachethq.io/## Setup
The tool can be installed conventionally using the python package manager or
newage new age-y using docker.### Python pip
The easiest way to install this tool is using `pip`, the python package
manager. This will install the dependencies as well as the `cachet_netbox_sync`
command into the python context of the currently logged in user.```console
$ pip install git+https://github.com/uberspace/cachet_netbox_sync.git
```### Docker
Alternatively, you can use the [`uberspace/cachet_netbox_sync`](https://hub.docker.com/r/uberspace/cachet_netbox_sync)
docker image to keep the python dependency management off your system.#### Command
The docker image can be used like a shell command like so:
```console
$ docker pull uberspace/cachet_netbox_sync
$ docker run -V config.ini:/config.ini uberspace/cachet_netbox_sync --config /config.ini
```#### Custom image
Instead of using our pre-built image, you can make your own. Save the following
snippet as a `Dockerfile`, place a `config.ini` next to it and there you go:
your very own `cachet_netbox_sync` with baked-in config. Just be carefull to not
include any secrets in there, as they can be read by anyone in possession of the
image.```dockerfile
FROM uberspace/cachet_netbox_sync
COPY config.ini /config.ini
ENTRYPOINT ["cachet_netbox_sync", "-c", "/config.ini"]
```#### Gitlab
If you have a GitLab with GitLab-CI running, you can use it to refresh your
cachet on-demand or in a cronjob-like fashion.1. create a new project
2. commit a `config.ini`
3. add your secrets as [variables](https://docs.gitlab.com/ee/ci/variables/#via-the-ui)
4. commit the following `.gitlab-ci.yml````yaml
---
sync_cachet:
image:
name: uberspace/cachet_netbox_sync
# https://gitlab.com/gitlab-org/gitlab-runner/issues/1170#note_271904909
entrypoint: [""]
script:
- cachet_netbox_sync --config cachet_netbox_sync.ini
```## Operation
1. get a cachet API token from `https://cachet.example.com/dashboard/user`
2. get a netbox readonly API token from `https://netbox.example.com/admin/users/token/`
3. copy `config.example.ini` to anywhere (e.g. `~/.cachet_netbox_sync.config.ini`)
and edit it according to the comments in the file
4. if you decide to leave the API tokens out of the config file, make sure
`CACHET_TOKEN` and `NETBOX_TOKEN` are defined in the environment you will
execute `cachet_netbox_sync` from.
5. run `cachet_netbox_sync -c config.ini`. The configuration path must always
be supplied as a parameter.### Syncing
The tool syncs two types of objects: components (e.g. VMs, network or sites)
and component groups. In both cases data is taken from netbox to cachet, never
the other way around.#### Components
* imports netbox data specified `[source.netbox.*]` sections into cachet
* deletes all components, which are not present in netbox
* deletes only if there are fewer or equal to `component_delete_limit`
components to be deleted
* only touches components which have the `cachet-netbox-sync` tag, so you can
create additional components in the cachet web interface.#### Component Groups
* creates all groups implicitly specified via `group_by_field` in sources
* deletes (or keeps) groups, which are not present in netbox, depending on the
`unknown_group_action` setting
* just like components, there is a `group_delete_limit` setting### Configuration
Please refer to the comments in [`config.example.ini`](config.example.ini) for
details on how to configure syncing.### Automation
Once there is a working configuration, a cronjob can be used to sync
the data regularily. The script can also be executed by your CI/CD system
or anything else you use internally.Add the follwing to the crontab of the user you ran `make install` as:
```cron
0 * * * * cachet_netbox_sync -c ~/.cachet_netbox_sync.config.ini
```This assumes your `$PATH` includes `~/.local/bin`, which is where pip
installs python "binaries".## Dev Setup
```console
$ git clone https://github.com/uberspace/cachet_netbox_sync.git
$ cd cachet_netbox_sync
$ virtualenv venv
$ source venv/bin/activate
$ make devsetup
```To actually run the tool you will need netbox and cachet instances as well as a
configuration file.