add option to netbox role for custom pipeline code for OIDC mapping
Add option to netbox role for ensuring custom pipeline code for OIDC
group and role mapping is either present or not.
The custom pipeline code is licensed under the Creative Commons: CC
BY-SA 4.0 license.
See:
https://github.com/goauthentik/authentik/blob/main/LICENSE
https://github.com/goauthentik/authentik/blob/main/website/integrations/services/netbox/index.md
https://docs.goauthentik.io/integrations/services/netbox/
5676b1a468
This commit is contained in:
parent
dbb784e2bb
commit
09a8551c8a
6 changed files with 95 additions and 2 deletions
README.md
roles/netbox
|
@ -48,4 +48,5 @@ Im Ansible-Repo müssen diese Sachen hinzugefügt werden:
|
|||
|
||||
## License
|
||||
|
||||
This CCCHH ansible-ccchh repository is licensed under the [MIT License](./LICENSE).
|
||||
This CCCHH ansible-ccchh repository is licensed under the [MIT License](./LICENSE).
|
||||
[`custom_pipeline_oidc_group_and_role_mapping.py`](./roles/netbox/files/custom_pipeline_oidc_group_and_role_mapping.py) is licensed under the Creative Commons: CC BY-SA 4.0 license.
|
||||
|
|
|
@ -18,7 +18,9 @@ Should work on Debian-based distributions.
|
|||
|
||||
## Optional Arguments
|
||||
|
||||
None.
|
||||
- `netbox__custom_pipeline_oidc_group_and_role_mapping`: Whether or not to have custom pipeline code for OIDC group and role mapping present.
|
||||
See [Custom Pipeline Code for OIDC Group and Role Mapping](#custom-pipeline-code-for-oidc-group-and-role-mapping) for more infos.
|
||||
Defaults to `false`.
|
||||
|
||||
## NetBox Configuration
|
||||
|
||||
|
@ -71,6 +73,15 @@ The relevant documentation on how to do that can be found here:
|
|||
- Web server setup docs: <https://netboxlabs.com/docs/netbox/en/stable/installation/5-http-server/>
|
||||
- Example base nginx config: <https://github.com/netbox-community/netbox/blob/main/contrib/nginx.conf>
|
||||
|
||||
## Custom Pipeline Code for OIDC Group and Role Mapping
|
||||
|
||||
Setting the option `netbox__custom_pipeline_oidc_group_and_role_mapping` to `true` makes this role ensure custom pipeline code for OIDC group and role mapping is present.
|
||||
Note that this role uses code for NetBox >= 4.0.0.
|
||||
The code is available in `files/custom_pipeline_oidc_group_and_role_mapping.py`, licensed under the CC BY-SA 4.0 license and taken from [this authentik NetBox documentation](https://docs.goauthentik.io/integrations/services/netbox/).
|
||||
The documentation also shows how to use the pipeline code by defining a custom `SOCIAL_AUTH_PIPELINE`, which you also need to do, as the configuration isn't provided by this role.
|
||||
However instead of under `netbox.custom_pipeline.` the functions are available under `netbox.custom_pipeline_oidc_mapping.` with this role.
|
||||
See also [the default settings.py](https://github.com/netbox-community/netbox/blob/main/netbox/netbox/settings.py) for the default `SOCIAL_AUTH_PIPELINE`.
|
||||
|
||||
## Links & Resources
|
||||
|
||||
- The NetBox Git Repo: <https://github.com/netbox-community/netbox>
|
||||
|
|
1
roles/netbox/defaults/main.yaml
Normal file
1
roles/netbox/defaults/main.yaml
Normal file
|
@ -0,0 +1 @@
|
|||
netbox__custom_pipeline_oidc_group_and_role_mapping: false
|
|
@ -0,0 +1,55 @@
|
|||
# Licensed under Creative Commons: CC BY-SA 4.0 license.
|
||||
# https://github.com/goauthentik/authentik/blob/main/LICENSE
|
||||
# https://github.com/goauthentik/authentik/blob/main/website/integrations/services/netbox/index.md
|
||||
# https://docs.goauthentik.io/integrations/services/netbox/
|
||||
from netbox.authentication import Group
|
||||
|
||||
class AuthFailed(Exception):
|
||||
pass
|
||||
|
||||
def add_groups(response, user, backend, *args, **kwargs):
|
||||
try:
|
||||
groups = response['groups']
|
||||
except KeyError:
|
||||
pass
|
||||
|
||||
# Add all groups from oAuth token
|
||||
for group in groups:
|
||||
group, created = Group.objects.get_or_create(name=group)
|
||||
user.groups.add(group)
|
||||
|
||||
def remove_groups(response, user, backend, *args, **kwargs):
|
||||
try:
|
||||
groups = response['groups']
|
||||
except KeyError:
|
||||
# Remove all groups if no groups in oAuth token
|
||||
user.groups.clear()
|
||||
pass
|
||||
|
||||
# Get all groups of user
|
||||
user_groups = [item.name for item in user.groups.all()]
|
||||
# Get groups of user which are not part of oAuth token
|
||||
delete_groups = list(set(user_groups) - set(groups))
|
||||
|
||||
# Delete non oAuth token groups
|
||||
for delete_group in delete_groups:
|
||||
group = Group.objects.get(name=delete_group)
|
||||
user.groups.remove(group)
|
||||
|
||||
|
||||
def set_roles(response, user, backend, *args, **kwargs):
|
||||
# Remove Roles temporary
|
||||
user.is_superuser = False
|
||||
user.is_staff = False
|
||||
try:
|
||||
groups = response['groups']
|
||||
except KeyError:
|
||||
# When no groups are set
|
||||
# save the user without Roles
|
||||
user.save()
|
||||
pass
|
||||
|
||||
# Set roles is role (superuser or staff) is in groups
|
||||
user.is_superuser = True if 'superusers' in groups else False
|
||||
user.is_staff = True if 'staff' in groups else False
|
||||
user.save()
|
|
@ -10,3 +10,7 @@ argument_specs:
|
|||
netbox__config:
|
||||
type: str
|
||||
required: true
|
||||
netbox__custom_pipeline_oidc_group_and_role_mapping:
|
||||
type: bool
|
||||
required: false
|
||||
default: false
|
||||
|
|
|
@ -25,6 +25,27 @@
|
|||
- Run upgrade script
|
||||
- Ensure netbox systemd services are set up and up-to-date
|
||||
|
||||
- name: Ensures custom pipeline code for OIDC group and role mapping is present
|
||||
ansible.builtin.copy:
|
||||
src: custom_pipeline_oidc_group_and_role_mapping.py
|
||||
dest: /opt/netbox/netbox/netbox/custom_pipeline_oidc_mapping.py
|
||||
mode: "0644"
|
||||
owner: root
|
||||
group: root
|
||||
when: netbox__custom_pipeline_oidc_group_and_role_mapping
|
||||
become: true
|
||||
notify:
|
||||
- Ensure netbox systemd services are set up and up-to-date
|
||||
|
||||
- name: Ensures custom pipeline code for OIDC group and role mapping is not present
|
||||
ansible.builtin.file:
|
||||
path: /opt/netbox/netbox/netbox/custom_pipeline_oidc_mapping.py
|
||||
state: absent
|
||||
when: not netbox__custom_pipeline_oidc_group_and_role_mapping
|
||||
become: true
|
||||
notify:
|
||||
- Ensure netbox systemd services are set up and up-to-date
|
||||
|
||||
- name: Ensure netbox user
|
||||
block:
|
||||
- name: Ensure netbox group exists
|
||||
|
|
Loading…
Add table
Reference in a new issue