Skip to content

Commit

Permalink
feat: add config option to disable enamil confirmation
Browse files Browse the repository at this point in the history
  • Loading branch information
mikonse committed Jan 4, 2024
1 parent 651c4a3 commit 7800f55
Show file tree
Hide file tree
Showing 4 changed files with 51 additions and 6 deletions.
5 changes: 4 additions & 1 deletion abrechnung/application/users.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ def __init__(
super().__init__(db_pool=db_pool, config=config)

self.enable_registration = self.cfg.registration.enabled
self.require_email_confirmation = self.cfg.registration.require_email_confirmation
self.allow_guest_users = self.cfg.registration.allow_guest_users
self.valid_email_domains = self.cfg.registration.valid_email_domains

Expand Down Expand Up @@ -172,7 +173,7 @@ async def demo_register_user(self, *, conn: Connection, username: str, email: st
def _validate_email_address(email: str) -> str:
try:
valid = validate_email(email)
email = valid.email
email = valid.normalized
except EmailNotValidError as e:
raise InvalidCommand(str(e))

Expand Down Expand Up @@ -203,6 +204,8 @@ async def register_user(
if not self.enable_registration:
raise PermissionError(f"User registrations are disabled on this server")

requires_email_confirmation = self.require_email_confirmation and requires_email_confirmation

await _check_user_exists(conn=conn, username=username, email=email)

email = self._validate_email_address(email)
Expand Down
1 change: 1 addition & 0 deletions abrechnung/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ class RegistrationConfig(BaseModel):
enabled: bool = False
allow_guest_users: bool = False
valid_email_domains: Optional[List[str]] = None
require_email_confirmation: bool = True


class EmailConfig(BaseModel):
Expand Down
36 changes: 32 additions & 4 deletions docs/usage/configuration.rst
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,7 @@ The config will then look like
port: 8080
id: default
In most cases there is no need to adjust either the ``host``, ``port`` or ``id`` options. For an overview of all
possible options see :ref:`abrechnung-config-all-options`.
In most cases there is no need to adjust either the ``host``, ``port`` or ``id`` options.

E-Mail Delivery
---------------
Expand Down Expand Up @@ -96,10 +95,39 @@ Currently supported ``mode`` options are
The ``auth`` section is optional, if omitted the mail delivery daemon will try to connect to the mail server
without authentication.

.. _abrechnung-config-all-options:
User Registration
-----------------

This section allows to configure how users can register at the abrechnung instance.
By default open registration is disabled.

When enabling registration without any additional settings any user will be able to create an account and use it after
a successful email confirmation.

E-mail confirmation can be turned of by setting the respective config variable to ``false``.

.. code-block:: yaml
registration:
enabled: true
require_email_confirmation: true
Additionally open registration can be restricted adding domains to the ``valid_email_domains`` config variable.
This will restrict account creation to users who possess an email from one of the configured domains.
To still allow outside users to take part the ``allow_guest_users`` flag can be set which enables users to create a
"guest" account when in possession of a valid group invite link.
Guest users will not be able to create new groups themselves but can take part in groups they are invited to normally.

.. code-block:: yaml
registration:
enabled: true
require_email_confirmation: true
valid_email_domains: ["some-domain.com"]
allow_guest_users: true
Configuration via Environment Variables
----------------------
---------------------------------------

All of the configuration options set in the config yaml file can also be set via environment variables.
The respective environment variable name for a config variable is in the pattern ``ABRECHNUNG_<config section>__<variable name in capslock>``.
Expand Down
15 changes: 14 additions & 1 deletion tests/test_auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@

from abrechnung.application.groups import GroupService
from abrechnung.application.users import UserService

from .common import TEST_CONFIG, BaseTestCase


Expand Down Expand Up @@ -67,3 +66,17 @@ async def test_register_guest_user(self):
email="[email protected]",
password="asdf1234",
)

async def test_register_without_email_confirmation(self):
config = TEST_CONFIG.model_copy(deep=True)
config.registration.require_email_confirmation = False
user_service = UserService(self.db_pool, config=config)

user_id = await user_service.register_user(
username="guest user 1",
email="[email protected]",
password="asdf1234",
)
self.assertIsNotNone(user_id)
user = await user_service.get_user(user_id=user_id)
self.assertFalse(user.pending)

0 comments on commit 7800f55

Please sign in to comment.