From bc4b7ef44d3ea7e7afa33fa57589b12b74b8dcf4 Mon Sep 17 00:00:00 2001 From: Jens Langhammer Date: Mon, 17 Feb 2020 20:30:14 +0100 Subject: [PATCH] providers/saml: add custom help text for templates, add docs for User Object reference --- .../property-mappings/user-object.md | 20 +++++++++++++++++++ mkdocs.yml | 3 +++ passbook/providers/saml/forms.py | 2 ++ .../saml/idp/property_mapping_form.html | 19 ++++++++++++++++++ passbook/sources/ldap/forms.py | 2 ++ .../templates/ldap/property_mapping_form.html | 18 +++++++++++++++++ 6 files changed, 64 insertions(+) create mode 100644 docs/reference/property-mappings/user-object.md create mode 100644 passbook/providers/saml/templates/saml/idp/property_mapping_form.html create mode 100644 passbook/sources/ldap/templates/ldap/property_mapping_form.html diff --git a/docs/reference/property-mappings/user-object.md b/docs/reference/property-mappings/user-object.md new file mode 100644 index 000000000..8cc35c162 --- /dev/null +++ b/docs/reference/property-mappings/user-object.md @@ -0,0 +1,20 @@ +# Passbook User Object + +The User object has the following attributes: + + - `username`: User's Username + - `email` User's E-Mail + - `name` User's Display Name + - `is_staff` Boolean field if user is staff + - `is_active` Boolean field if user is active + - `date_joined` Date User joined/was created + - `password_change_date` Date Password was last changed + - `attributes` Dynamic Attributes + +## Examples + +List all the User's Group Names + +```jinja2 +[{% for group in user.groups.all() %}'{{ group.name }}',{% endfor %}] +``` diff --git a/mkdocs.yml b/mkdocs.yml index efda66a94..bd2251ab4 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -19,6 +19,9 @@ nav: - Rancher: integrations/services/rancher/index.md - Harbor: integrations/services/harbor/index.md - Sentry: integrations/services/sentry/index.md + - Reference: + - Property Mappings: + - User Object: reference/property-mappings/user-object.md repo_name: "BeryJu.org/passbook" repo_url: https://github.com/BeryJu/passbook diff --git a/passbook/providers/saml/forms.py b/passbook/providers/saml/forms.py index 7c305187a..11f9c1dc2 100644 --- a/passbook/providers/saml/forms.py +++ b/passbook/providers/saml/forms.py @@ -59,6 +59,8 @@ class SAMLProviderForm(forms.ModelForm): class SAMLPropertyMappingForm(forms.ModelForm): """SAML Property Mapping form""" + template_name = "saml/idp/property_mapping_form.html" + class Meta: model = SAMLPropertyMapping diff --git a/passbook/providers/saml/templates/saml/idp/property_mapping_form.html b/passbook/providers/saml/templates/saml/idp/property_mapping_form.html new file mode 100644 index 000000000..792be3c6d --- /dev/null +++ b/passbook/providers/saml/templates/saml/idp/property_mapping_form.html @@ -0,0 +1,19 @@ +{% extends "generic/form.html" %} + +{% load i18n %} + +{% block beneath_form %} +
+ +
+

+ Expression using Jinja. Following variables are available: +

    +
  • user: Passbook User Object (Reference)
  • +
  • request: Django HTTP Request Object (Reference)
  • +
+

+
+
+{% endblock %} diff --git a/passbook/sources/ldap/forms.py b/passbook/sources/ldap/forms.py index d7d463757..16d233028 100644 --- a/passbook/sources/ldap/forms.py +++ b/passbook/sources/ldap/forms.py @@ -50,6 +50,8 @@ class LDAPSourceForm(forms.ModelForm): class LDAPPropertyMappingForm(forms.ModelForm): """LDAP Property Mapping form""" + template_name = "ldap/property_mapping_form.html" + class Meta: model = LDAPPropertyMapping diff --git a/passbook/sources/ldap/templates/ldap/property_mapping_form.html b/passbook/sources/ldap/templates/ldap/property_mapping_form.html new file mode 100644 index 000000000..ff41588ed --- /dev/null +++ b/passbook/sources/ldap/templates/ldap/property_mapping_form.html @@ -0,0 +1,18 @@ +{% extends "generic/form.html" %} + +{% load i18n %} + +{% block beneath_form %} +
+ +
+

+ Expression using Jinja. Following variables are available: +

    +
  • ldap: A Dictionary of all values retrieved from LDAP.
  • +
+

+
+
+{% endblock %}