Skip to content

Commit

Permalink
docs: update README and example config for firewall support
Browse files Browse the repository at this point in the history
  • Loading branch information
tjhop committed Mar 5, 2024
1 parent a101584 commit 995f387
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 1 deletion.
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,15 @@ Tagger is an application that can enforce the presence/absence of API tags in bu
| NodeBalancers | `nodebalancers:read_write` |
| Domains | `domains:read_write` |
| LKEClusters | `lke:read_write` |
| Firewalls | `firewall:read_write` |

## Motivation

Tools like Terraform/Pulumi that are capable of programmatically managing all aspects of API resources are great -- but if there is already a large amount of infrastructure deployed (and the infrastructure isn't suitable to directly import to something like Terraform state as-is), it can be difficult to manage tags across API resources.

API tags provide a powerful and flexible way to dynamically annotate infrastructure. With tools like [Prometheus](https://prometheus.io), you can even discover monitoring targets using [Linode Service Discovery](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#linode_sd_config) based on API tags.

So it's helpful to be able to manage tags on Linode APIv4 resources en-masse -- but how can that be done in an idempotent and consistent way? This is where `tagger` comes into play. With tagger, you write a configuration file defining a list of tag rules for each of the various Linode APIv4 taggable objects (instances, domains, nodebalancers, volumes, LKE clusters).
So it's helpful to be able to manage tags on Linode APIv4 resources en-masse -- but how can that be done in an idempotent and consistent way? This is where `tagger` comes into play. With tagger, you write a configuration file defining a list of tag rules for each of the various Linode APIv4 taggable objects (instances, domains, nodebalancers, volumes, LKE clusters, firewalls).

Each rule is a regex to be matched against the resource's human-readable label, and a list of tags that should be enforced as either `present` or `absent` on the resource. `tagger` is idempotent and doesn't update resources unless required, and can be run in `--dry-run` mode to see what changes are waiting. JSON output is provided as well with the `--json` flag for easy manipulation/inspection of the diffs and integration with other tools. Full help text:

Expand Down
7 changes: 7 additions & 0 deletions packaging/etc/tagger.yml
Original file line number Diff line number Diff line change
Expand Up @@ -36,3 +36,10 @@ tagger:
absent:
- tagger_absent_1
- tagger_absent_2
firewalls:
- regex: '.+'
tags:
present:
- tagger_managed_1
absent:
- tagger_absent_1

0 comments on commit 995f387

Please sign in to comment.