*: rephrase strings
This commit is contained in:
parent
219acf76d5
commit
3b70d12a5f
|
@ -5,7 +5,7 @@ from urllib.parse import urlencode
|
||||||
from django import template
|
from django import template
|
||||||
from django.db.models import Model
|
from django.db.models import Model
|
||||||
from django.template import Context
|
from django.template import Context
|
||||||
from django.utils.html import escape
|
from django.utils.html import escape, mark_safe
|
||||||
from structlog import get_logger
|
from structlog import get_logger
|
||||||
|
|
||||||
from passbook.lib.config import CONFIG
|
from passbook.lib.config import CONFIG
|
||||||
|
@ -105,4 +105,4 @@ def debug(obj) -> str:
|
||||||
@register.filter
|
@register.filter
|
||||||
def doc(obj) -> str:
|
def doc(obj) -> str:
|
||||||
"""Return docstring of object"""
|
"""Return docstring of object"""
|
||||||
return obj.__doc__
|
return mark_safe(obj.__doc__.replace("\n", "<br>"))
|
||||||
|
|
|
@ -8,7 +8,7 @@ from passbook.policies.types import PolicyRequest, PolicyResult
|
||||||
|
|
||||||
|
|
||||||
class ExpressionPolicy(Policy):
|
class ExpressionPolicy(Policy):
|
||||||
"""Implement custom logic using python."""
|
"""Execute arbitrary Python code to implement custom checks and validation."""
|
||||||
|
|
||||||
expression = models.TextField()
|
expression = models.TextField()
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@ LOGGER = get_logger()
|
||||||
|
|
||||||
|
|
||||||
class HaveIBeenPwendPolicy(Policy):
|
class HaveIBeenPwendPolicy(Policy):
|
||||||
"""Check if password is on HaveIBeenPwned's list by upload the first
|
"""Check if password is on HaveIBeenPwned's list by uploading the first
|
||||||
5 characters of the SHA1 Hash."""
|
5 characters of the SHA1 Hash."""
|
||||||
|
|
||||||
allowed_count = models.IntegerField(default=0)
|
allowed_count = models.IntegerField(default=0)
|
||||||
|
|
|
@ -12,8 +12,9 @@ from passbook.lib.utils.template import render_to_string
|
||||||
|
|
||||||
|
|
||||||
class OAuth2Provider(Provider, AbstractApplication):
|
class OAuth2Provider(Provider, AbstractApplication):
|
||||||
"""Generic OAuth2 Provider for applications not using OpenID-Connect. This Provider
|
"""Generic OAuth2 Provider for applications not using OpenID-Connect.
|
||||||
also supports the GitHub-pretend mode."""
|
This Provider also supports the GitHub-pretend mode for Applications that don't support
|
||||||
|
generic OAuth."""
|
||||||
|
|
||||||
form = "passbook.providers.oauth.forms.OAuth2ProviderForm"
|
form = "passbook.providers.oauth.forms.OAuth2ProviderForm"
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ class SAMLBindings(models.TextChoices):
|
||||||
|
|
||||||
|
|
||||||
class SAMLProvider(Provider):
|
class SAMLProvider(Provider):
|
||||||
"""SAML 2.0-based authentication protocol."""
|
"""SAML 2.0 Endpoint for applications which support SAML."""
|
||||||
|
|
||||||
name = models.TextField()
|
name = models.TextField()
|
||||||
processor_path = models.CharField(max_length=255, choices=[])
|
processor_path = models.CharField(max_length=255, choices=[])
|
||||||
|
@ -157,7 +157,7 @@ class SAMLProvider(Provider):
|
||||||
|
|
||||||
|
|
||||||
class SAMLPropertyMapping(PropertyMapping):
|
class SAMLPropertyMapping(PropertyMapping):
|
||||||
"""SAML Property mapping, allowing Name/FriendlyName mapping to a list of strings"""
|
"""Map User/Group attribute to SAML Attribute, which can be used by the Service Provider."""
|
||||||
|
|
||||||
saml_name = models.TextField(verbose_name="SAML Name")
|
saml_name = models.TextField(verbose_name="SAML Name")
|
||||||
friendly_name = models.TextField(default=None, blank=True, null=True)
|
friendly_name = models.TextField(default=None, blank=True, null=True)
|
||||||
|
|
|
@ -10,7 +10,7 @@ from passbook.core.models import Group, PropertyMapping, Source
|
||||||
|
|
||||||
|
|
||||||
class LDAPSource(Source):
|
class LDAPSource(Source):
|
||||||
"""LDAP Authentication source"""
|
"""Federate LDAP Directory with passbook, or create new accounts in LDAP."""
|
||||||
|
|
||||||
server_uri = models.TextField(
|
server_uri = models.TextField(
|
||||||
validators=[URLValidator(schemes=["ldap", "ldaps"])],
|
validators=[URLValidator(schemes=["ldap", "ldaps"])],
|
||||||
|
@ -81,7 +81,7 @@ class LDAPSource(Source):
|
||||||
|
|
||||||
|
|
||||||
class LDAPPropertyMapping(PropertyMapping):
|
class LDAPPropertyMapping(PropertyMapping):
|
||||||
"""Map LDAP Property to User or Group object"""
|
"""Map LDAP Property to User or Group object attribute"""
|
||||||
|
|
||||||
object_field = models.TextField()
|
object_field = models.TextField()
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ from passbook.sources.oauth.clients import get_client
|
||||||
|
|
||||||
|
|
||||||
class OAuthSource(Source):
|
class OAuthSource(Source):
|
||||||
"""Configuration for OAuth provider."""
|
"""Login using a Generic OAuth provider."""
|
||||||
|
|
||||||
provider_type = models.CharField(max_length=255)
|
provider_type = models.CharField(max_length=255)
|
||||||
request_token_url = models.CharField(
|
request_token_url = models.CharField(
|
||||||
|
@ -78,7 +78,7 @@ class OAuthSource(Source):
|
||||||
|
|
||||||
|
|
||||||
class GitHubOAuthSource(OAuthSource):
|
class GitHubOAuthSource(OAuthSource):
|
||||||
"""Abstract subclass of OAuthSource to specify GitHub Form"""
|
"""Social Login using GitHub.com or a GitHub-Enterprise Instance."""
|
||||||
|
|
||||||
form = "passbook.sources.oauth.forms.GitHubOAuthSourceForm"
|
form = "passbook.sources.oauth.forms.GitHubOAuthSourceForm"
|
||||||
|
|
||||||
|
@ -90,7 +90,7 @@ class GitHubOAuthSource(OAuthSource):
|
||||||
|
|
||||||
|
|
||||||
class TwitterOAuthSource(OAuthSource):
|
class TwitterOAuthSource(OAuthSource):
|
||||||
"""Abstract subclass of OAuthSource to specify Twitter Form"""
|
"""Social Login using Twitter.com"""
|
||||||
|
|
||||||
form = "passbook.sources.oauth.forms.TwitterOAuthSourceForm"
|
form = "passbook.sources.oauth.forms.TwitterOAuthSourceForm"
|
||||||
|
|
||||||
|
@ -102,7 +102,7 @@ class TwitterOAuthSource(OAuthSource):
|
||||||
|
|
||||||
|
|
||||||
class FacebookOAuthSource(OAuthSource):
|
class FacebookOAuthSource(OAuthSource):
|
||||||
"""Abstract subclass of OAuthSource to specify Facebook Form"""
|
"""Social Login using Facebook.com."""
|
||||||
|
|
||||||
form = "passbook.sources.oauth.forms.FacebookOAuthSourceForm"
|
form = "passbook.sources.oauth.forms.FacebookOAuthSourceForm"
|
||||||
|
|
||||||
|
@ -114,7 +114,7 @@ class FacebookOAuthSource(OAuthSource):
|
||||||
|
|
||||||
|
|
||||||
class DiscordOAuthSource(OAuthSource):
|
class DiscordOAuthSource(OAuthSource):
|
||||||
"""Abstract subclass of OAuthSource to specify Discord Form"""
|
"""Social Login using Discord."""
|
||||||
|
|
||||||
form = "passbook.sources.oauth.forms.DiscordOAuthSourceForm"
|
form = "passbook.sources.oauth.forms.DiscordOAuthSourceForm"
|
||||||
|
|
||||||
|
@ -126,7 +126,7 @@ class DiscordOAuthSource(OAuthSource):
|
||||||
|
|
||||||
|
|
||||||
class GoogleOAuthSource(OAuthSource):
|
class GoogleOAuthSource(OAuthSource):
|
||||||
"""Abstract subclass of OAuthSource to specify Google Form"""
|
"""Social Login using Google or Gsuite."""
|
||||||
|
|
||||||
form = "passbook.sources.oauth.forms.GoogleOAuthSourceForm"
|
form = "passbook.sources.oauth.forms.GoogleOAuthSourceForm"
|
||||||
|
|
||||||
|
@ -138,7 +138,7 @@ class GoogleOAuthSource(OAuthSource):
|
||||||
|
|
||||||
|
|
||||||
class AzureADOAuthSource(OAuthSource):
|
class AzureADOAuthSource(OAuthSource):
|
||||||
"""Abstract subclass of OAuthSource to specify AzureAD Form"""
|
"""Social Login using Azure AD."""
|
||||||
|
|
||||||
form = "passbook.sources.oauth.forms.AzureADOAuthSourceForm"
|
form = "passbook.sources.oauth.forms.AzureADOAuthSourceForm"
|
||||||
|
|
||||||
|
@ -150,7 +150,7 @@ class AzureADOAuthSource(OAuthSource):
|
||||||
|
|
||||||
|
|
||||||
class OpenIDOAuthSource(OAuthSource):
|
class OpenIDOAuthSource(OAuthSource):
|
||||||
"""Abstract subclass of OAuthSource to specify OpenID Form"""
|
"""Login using a Generic OpenID-Connect compliant provider."""
|
||||||
|
|
||||||
form = "passbook.sources.oauth.forms.OAuthSourceForm"
|
form = "passbook.sources.oauth.forms.OAuthSourceForm"
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ class SAMLBindingTypes(models.TextChoices):
|
||||||
|
|
||||||
|
|
||||||
class SAMLSource(Source):
|
class SAMLSource(Source):
|
||||||
"""SAML Source"""
|
"""Authenticate using an external SAML Identity Provider."""
|
||||||
|
|
||||||
issuer = models.TextField(
|
issuer = models.TextField(
|
||||||
blank=True,
|
blank=True,
|
||||||
|
|
|
@ -6,7 +6,7 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class CaptchaStage(Stage):
|
class CaptchaStage(Stage):
|
||||||
"""Captcha Stage instance"""
|
"""Verify the user is human using Google's reCaptcha."""
|
||||||
|
|
||||||
public_key = models.TextField(
|
public_key = models.TextField(
|
||||||
help_text=_(
|
help_text=_(
|
||||||
|
|
|
@ -5,7 +5,7 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class ConsentStage(Stage):
|
class ConsentStage(Stage):
|
||||||
"""Consent Stage instance"""
|
"""Prompt the user for confirmation."""
|
||||||
|
|
||||||
type = "passbook.stages.consent.stage.ConsentStage"
|
type = "passbook.stages.consent.stage.ConsentStage"
|
||||||
form = "passbook.stages.consent.forms.ConsentStageForm"
|
form = "passbook.stages.consent.forms.ConsentStageForm"
|
||||||
|
|
|
@ -5,7 +5,7 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class DummyStage(Stage):
|
class DummyStage(Stage):
|
||||||
"""Dummy stage, mostly used to debug"""
|
"""Used for debugging."""
|
||||||
|
|
||||||
type = "passbook.stages.dummy.stage.DummyStage"
|
type = "passbook.stages.dummy.stage.DummyStage"
|
||||||
form = "passbook.stages.dummy.forms.DummyStageForm"
|
form = "passbook.stages.dummy.forms.DummyStageForm"
|
||||||
|
|
|
@ -21,7 +21,7 @@ class EmailTemplates(models.TextChoices):
|
||||||
|
|
||||||
|
|
||||||
class EmailStage(Stage):
|
class EmailStage(Stage):
|
||||||
"""Email-based verification."""
|
"""Sends an Email to the user with a token to confirm their Email address."""
|
||||||
|
|
||||||
host = models.TextField(default="localhost")
|
host = models.TextField(default="localhost")
|
||||||
port = models.IntegerField(default=25)
|
port = models.IntegerField(default=25)
|
||||||
|
|
|
@ -21,7 +21,7 @@ class Templates(models.TextChoices):
|
||||||
|
|
||||||
|
|
||||||
class IdentificationStage(Stage):
|
class IdentificationStage(Stage):
|
||||||
"""Identification stage, allows a user to identify themselves to authenticate."""
|
"""Allows the user to identify themselves for authentication."""
|
||||||
|
|
||||||
user_fields = ArrayField(
|
user_fields = ArrayField(
|
||||||
models.CharField(max_length=100, choices=UserFields.choices),
|
models.CharField(max_length=100, choices=UserFields.choices),
|
||||||
|
|
|
@ -10,7 +10,8 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class InvitationStage(Stage):
|
class InvitationStage(Stage):
|
||||||
"""Invitation stage, to enroll themselves with enforced parameters"""
|
"""Simplify enrollment; allow users to use a single
|
||||||
|
link to create their user with pre-defined parameters."""
|
||||||
|
|
||||||
continue_flow_without_invitation = models.BooleanField(
|
continue_flow_without_invitation = models.BooleanField(
|
||||||
default=False,
|
default=False,
|
||||||
|
|
|
@ -10,7 +10,7 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class OTPStaticStage(Stage):
|
class OTPStaticStage(Stage):
|
||||||
"""Generate static tokens for the user as a backup"""
|
"""Generate static tokens for the user as a backup."""
|
||||||
|
|
||||||
token_count = models.IntegerField(default=6)
|
token_count = models.IntegerField(default=6)
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ class TOTPDigits(models.IntegerChoices):
|
||||||
|
|
||||||
|
|
||||||
class OTPTimeStage(Stage):
|
class OTPTimeStage(Stage):
|
||||||
"""Enroll a user's device into Time-based OTP"""
|
"""Enroll a user's device into Time-based OTP."""
|
||||||
|
|
||||||
digits = models.IntegerField(choices=TOTPDigits.choices)
|
digits = models.IntegerField(choices=TOTPDigits.choices)
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@ from passbook.flows.models import NotConfiguredAction, Stage
|
||||||
|
|
||||||
|
|
||||||
class OTPValidateStage(Stage):
|
class OTPValidateStage(Stage):
|
||||||
"""Validate user's configured OTP Device"""
|
"""Validate user's configured OTP Device."""
|
||||||
|
|
||||||
not_configured_action = models.TextField(
|
not_configured_action = models.TextField(
|
||||||
choices=NotConfiguredAction.choices, default=NotConfiguredAction.SKIP
|
choices=NotConfiguredAction.choices, default=NotConfiguredAction.SKIP
|
||||||
|
|
|
@ -13,7 +13,7 @@ from passbook.flows.views import NEXT_ARG_NAME
|
||||||
|
|
||||||
|
|
||||||
class PasswordStage(Stage):
|
class PasswordStage(Stage):
|
||||||
"""Password-based Django-backend Authentication Stage"""
|
"""Prompts the user for their password, and validates it against the configured backends."""
|
||||||
|
|
||||||
backends = ArrayField(
|
backends = ArrayField(
|
||||||
models.TextField(),
|
models.TextField(),
|
||||||
|
|
|
@ -95,7 +95,7 @@ class Prompt(models.Model):
|
||||||
|
|
||||||
|
|
||||||
class PromptStage(PolicyBindingModel, Stage):
|
class PromptStage(PolicyBindingModel, Stage):
|
||||||
"""Prompt Stage, pointing to multiple prompts"""
|
"""Define arbitrary prompts for the user."""
|
||||||
|
|
||||||
fields = models.ManyToManyField(Prompt)
|
fields = models.ManyToManyField(Prompt)
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,8 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class UserDeleteStage(Stage):
|
class UserDeleteStage(Stage):
|
||||||
"""Delete stage, delete a user from saved data."""
|
"""Deletes the currently pending user without confirmation.
|
||||||
|
Use with caution."""
|
||||||
|
|
||||||
type = "passbook.stages.user_delete.stage.UserDeleteStageView"
|
type = "passbook.stages.user_delete.stage.UserDeleteStageView"
|
||||||
form = "passbook.stages.user_delete.forms.UserDeleteStageForm"
|
form = "passbook.stages.user_delete.forms.UserDeleteStageForm"
|
||||||
|
|
|
@ -5,7 +5,7 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class UserLoginStage(Stage):
|
class UserLoginStage(Stage):
|
||||||
"""Login stage, allows a user to identify themselves to authenticate."""
|
"""Attaches the currently pending user to the current session."""
|
||||||
|
|
||||||
type = "passbook.stages.user_login.stage.UserLoginStageView"
|
type = "passbook.stages.user_login.stage.UserLoginStageView"
|
||||||
form = "passbook.stages.user_login.forms.UserLoginStageForm"
|
form = "passbook.stages.user_login.forms.UserLoginStageForm"
|
||||||
|
|
|
@ -5,7 +5,7 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class UserLogoutStage(Stage):
|
class UserLogoutStage(Stage):
|
||||||
"""Logout stage, allows a user to identify themselves to authenticate."""
|
"""Resets the users current session."""
|
||||||
|
|
||||||
type = "passbook.stages.user_logout.stage.UserLogoutStageView"
|
type = "passbook.stages.user_logout.stage.UserLogoutStageView"
|
||||||
form = "passbook.stages.user_logout.forms.UserLogoutStageForm"
|
form = "passbook.stages.user_logout.forms.UserLogoutStageForm"
|
||||||
|
|
|
@ -5,7 +5,8 @@ from passbook.flows.models import Stage
|
||||||
|
|
||||||
|
|
||||||
class UserWriteStage(Stage):
|
class UserWriteStage(Stage):
|
||||||
"""Write stage, write a user from saved data."""
|
"""Writes currently pending data into the pending user, or if no user exists,
|
||||||
|
creates a new user with the data."""
|
||||||
|
|
||||||
type = "passbook.stages.user_write.stage.UserWriteStageView"
|
type = "passbook.stages.user_write.stage.UserWriteStageView"
|
||||||
form = "passbook.stages.user_write.forms.UserWriteStageForm"
|
form = "passbook.stages.user_write.forms.UserWriteStageForm"
|
||||||
|
|
Reference in a new issue