mirror of https://github.com/watcha-fr/synapse
Port "Allow users to click account renewal links multiple times without hitting an 'Invalid Token' page #74" from synapse-dinsic (#9832)
This attempts to be a direct port of https://github.com/matrix-org/synapse-dinsic/pull/74 to mainline. There was some fiddling required to deal with the changes that have been made to mainline since (mainly dealing with the split of `RegistrationWorkerStore` from `RegistrationStore`, and the changes made to `self.make_request` in test code).code_spécifique_watcha
parent
e694a598f8
commit
71f0623de9
@ -0,0 +1 @@ |
||||
Don't return an error when a user attempts to renew their account multiple times with the same token. Instead, state when their account is set to expire. This change concerns the optional account validity feature. |
@ -0,0 +1,165 @@ |
||||
# -*- coding: utf-8 -*- |
||||
# Copyright 2020 The Matrix.org Foundation C.I.C. |
||||
# |
||||
# Licensed under the Apache License, Version 2.0 (the "License"); |
||||
# you may not use this file except in compliance with the License. |
||||
# You may obtain a copy of the License at |
||||
# |
||||
# http://www.apache.org/licenses/LICENSE-2.0 |
||||
# |
||||
# Unless required by applicable law or agreed to in writing, software |
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
# See the License for the specific language governing permissions and |
||||
# limitations under the License. |
||||
from synapse.config._base import Config, ConfigError |
||||
|
||||
|
||||
class AccountValidityConfig(Config): |
||||
section = "account_validity" |
||||
|
||||
def read_config(self, config, **kwargs): |
||||
account_validity_config = config.get("account_validity") or {} |
||||
self.account_validity_enabled = account_validity_config.get("enabled", False) |
||||
self.account_validity_renew_by_email_enabled = ( |
||||
"renew_at" in account_validity_config |
||||
) |
||||
|
||||
if self.account_validity_enabled: |
||||
if "period" in account_validity_config: |
||||
self.account_validity_period = self.parse_duration( |
||||
account_validity_config["period"] |
||||
) |
||||
else: |
||||
raise ConfigError("'period' is required when using account validity") |
||||
|
||||
if "renew_at" in account_validity_config: |
||||
self.account_validity_renew_at = self.parse_duration( |
||||
account_validity_config["renew_at"] |
||||
) |
||||
|
||||
if "renew_email_subject" in account_validity_config: |
||||
self.account_validity_renew_email_subject = account_validity_config[ |
||||
"renew_email_subject" |
||||
] |
||||
else: |
||||
self.account_validity_renew_email_subject = "Renew your %(app)s account" |
||||
|
||||
self.account_validity_startup_job_max_delta = ( |
||||
self.account_validity_period * 10.0 / 100.0 |
||||
) |
||||
|
||||
if self.account_validity_renew_by_email_enabled: |
||||
if not self.public_baseurl: |
||||
raise ConfigError("Can't send renewal emails without 'public_baseurl'") |
||||
|
||||
# Load account validity templates. |
||||
account_validity_template_dir = account_validity_config.get("template_dir") |
||||
|
||||
account_renewed_template_filename = account_validity_config.get( |
||||
"account_renewed_html_path", "account_renewed.html" |
||||
) |
||||
invalid_token_template_filename = account_validity_config.get( |
||||
"invalid_token_html_path", "invalid_token.html" |
||||
) |
||||
|
||||
# Read and store template content |
||||
( |
||||
self.account_validity_account_renewed_template, |
||||
self.account_validity_account_previously_renewed_template, |
||||
self.account_validity_invalid_token_template, |
||||
) = self.read_templates( |
||||
[ |
||||
account_renewed_template_filename, |
||||
"account_previously_renewed.html", |
||||
invalid_token_template_filename, |
||||
], |
||||
account_validity_template_dir, |
||||
) |
||||
|
||||
def generate_config_section(self, **kwargs): |
||||
return """\ |
||||
## Account Validity ## |
||||
|
||||
# Optional account validity configuration. This allows for accounts to be denied |
||||
# any request after a given period. |
||||
# |
||||
# Once this feature is enabled, Synapse will look for registered users without an |
||||
# expiration date at startup and will add one to every account it found using the |
||||
# current settings at that time. |
||||
# This means that, if a validity period is set, and Synapse is restarted (it will |
||||
# then derive an expiration date from the current validity period), and some time |
||||
# after that the validity period changes and Synapse is restarted, the users' |
||||
# expiration dates won't be updated unless their account is manually renewed. This |
||||
# date will be randomly selected within a range [now + period - d ; now + period], |
||||
# where d is equal to 10% of the validity period. |
||||
# |
||||
account_validity: |
||||
# The account validity feature is disabled by default. Uncomment the |
||||
# following line to enable it. |
||||
# |
||||
#enabled: true |
||||
|
||||
# The period after which an account is valid after its registration. When |
||||
# renewing the account, its validity period will be extended by this amount |
||||
# of time. This parameter is required when using the account validity |
||||
# feature. |
||||
# |
||||
#period: 6w |
||||
|
||||
# The amount of time before an account's expiry date at which Synapse will |
||||
# send an email to the account's email address with a renewal link. By |
||||
# default, no such emails are sent. |
||||
# |
||||
# If you enable this setting, you will also need to fill out the 'email' and |
||||
# 'public_baseurl' configuration sections. |
||||
# |
||||
#renew_at: 1w |
||||
|
||||
# The subject of the email sent out with the renewal link. '%(app)s' can be |
||||
# used as a placeholder for the 'app_name' parameter from the 'email' |
||||
# section. |
||||
# |
||||
# Note that the placeholder must be written '%(app)s', including the |
||||
# trailing 's'. |
||||
# |
||||
# If this is not set, a default value is used. |
||||
# |
||||
#renew_email_subject: "Renew your %(app)s account" |
||||
|
||||
# Directory in which Synapse will try to find templates for the HTML files to |
||||
# serve to the user when trying to renew an account. If not set, default |
||||
# templates from within the Synapse package will be used. |
||||
# |
||||
# The currently available templates are: |
||||
# |
||||
# * account_renewed.html: Displayed to the user after they have successfully |
||||
# renewed their account. |
||||
# |
||||
# * account_previously_renewed.html: Displayed to the user if they attempt to |
||||
# renew their account with a token that is valid, but that has already |
||||
# been used. In this case the account is not renewed again. |
||||
# |
||||
# * invalid_token.html: Displayed to the user when they try to renew an account |
||||
# with an unknown or invalid renewal token. |
||||
# |
||||
# See https://github.com/matrix-org/synapse/tree/master/synapse/res/templates for |
||||
# default template contents. |
||||
# |
||||
# The file name of some of these templates can be configured below for legacy |
||||
# reasons. |
||||
# |
||||
#template_dir: "res/templates" |
||||
|
||||
# A custom file name for the 'account_renewed.html' template. |
||||
# |
||||
# If not set, the file is assumed to be named "account_renewed.html". |
||||
# |
||||
#account_renewed_html_path: "account_renewed.html" |
||||
|
||||
# A custom file name for the 'invalid_token.html' template. |
||||
# |
||||
# If not set, the file is assumed to be named "invalid_token.html". |
||||
# |
||||
#invalid_token_html_path: "invalid_token.html" |
||||
""" |
@ -0,0 +1 @@ |
||||
<html><body>Your account is valid until {{ expiration_ts|format_ts("%d-%m-%Y") }}.</body><html> |
@ -1 +1 @@ |
||||
<html><body>Your account has been successfully renewed.</body><html> |
||||
<html><body>Your account has been successfully renewed and is valid until {{ expiration_ts|format_ts("%d-%m-%Y") }}.</body><html> |
||||
|
@ -0,0 +1,18 @@ |
||||
/* Copyright 2020 The Matrix.org Foundation C.I.C. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0 |
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
-- Track when users renew their account using the value of the 'renewal_token' column. |
||||
-- This field should be set to NULL after a fresh token is generated. |
||||
ALTER TABLE account_validity ADD token_used_ts_ms BIGINT; |
Loading…
Reference in new issue