Add declarative attic cache
Signed-off-by: Nikolaos Karaolidis <nick@karaolidis.com>
This commit is contained in:
@@ -1,312 +0,0 @@
|
||||
From 2ef5994a21d694bdf50d1d9d4c524c9584368917 Mon Sep 17 00:00:00 2001
|
||||
From: Nikolaos Karaolidis <nick@karaolidis.com>
|
||||
Date: Mon, 28 Jul 2025 15:33:55 +0100
|
||||
Subject: [PATCH] fe: dynamic configuration env vars
|
||||
|
||||
Signed-off-by: Nikolaos Karaolidis <nick@karaolidis.com>
|
||||
---
|
||||
.../dynamic/auth.emailupdate.enabled.en.md | 1 +
|
||||
.../auth.login.local.maxattempts.en.md | 2 ++
|
||||
.../auth.signup.confirm.commenter.en.md | 2 ++
|
||||
.../dynamic/auth.signup.confirm.user.en.md | 2 ++
|
||||
.../backend/dynamic/auth.signup.enabled.en.md | 2 ++
|
||||
...in.defaults.comments.deletion.author.en.md | 2 ++
|
||||
...defaults.comments.deletion.moderator.en.md | 2 ++
|
||||
...ain.defaults.comments.editing.author.en.md | 2 ++
|
||||
....defaults.comments.editing.moderator.en.md | 2 ++
|
||||
...omain.defaults.comments.enablevoting.en.md | 2 ++
|
||||
...domain.defaults.comments.rss.enabled.en.md | 2 ++
|
||||
...domain.defaults.comments.showdeleted.en.md | 2 ++
|
||||
...ain.defaults.comments.text.maxlength.en.md | 2 ++
|
||||
.../domain.defaults.login.showforunauth.en.md | 2 ++
|
||||
...ain.defaults.markdown.images.enabled.en.md | 2 ++
|
||||
...main.defaults.markdown.links.enabled.en.md | 2 ++
|
||||
...ain.defaults.markdown.tables.enabled.en.md | 4 ++-
|
||||
...main.defaults.signup.enablefederated.en.md | 2 ++
|
||||
.../domain.defaults.signup.enablelocal.en.md | 2 ++
|
||||
.../domain.defaults.signup.enablesso.en.md | 2 ++
|
||||
.../dynamic/integrations.usegravatar.en.md | 1 +
|
||||
.../dynamic/operation.newowner.enabled.en.md | 2 ++
|
||||
internal/data/dyn_config.go | 28 +++++++++++++++++--
|
||||
23 files changed, 69 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/docs/content/configuration/backend/dynamic/auth.emailupdate.enabled.en.md b/docs/content/configuration/backend/dynamic/auth.emailupdate.enabled.en.md
|
||||
index 5b9c5716..a139c953 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/auth.emailupdate.enabled.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/auth.emailupdate.enabled.en.md
|
||||
@@ -20,3 +20,4 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter defines w
|
||||
* If no operational mailer is configured, the email will be updated right away, without intermediate confirmation.
|
||||
* If set to `Off`, users cannot change their emails themselves. Email can only be updated by a [superuser](/kb/permissions/superuser) (for example, at a user's request).
|
||||
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_AUTH_EMAILUPDATE_ENABLED`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/auth.login.local.maxattempts.en.md b/docs/content/configuration/backend/dynamic/auth.login.local.maxattempts.en.md
|
||||
index bada14ec..5a3993a8 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/auth.login.local.maxattempts.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/auth.login.local.maxattempts.en.md
|
||||
@@ -20,3 +20,5 @@ Comentario keeps a counter of failed login attempts for each user.
|
||||
* The failed login attempt counter gets reset to zero as soon as the user has successfully logged in.
|
||||
|
||||
This mechanism is mostly intended to safeguard users against brute-force attacks on their passwords. In order to disable it, set the value to `0`.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_AUTH_LOGIN_LOCAL_MAXATTEMPTS`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/auth.signup.confirm.commenter.en.md b/docs/content/configuration/backend/dynamic/auth.signup.confirm.commenter.en.md
|
||||
index 6ad25e5a..fbb38b3b 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/auth.signup.confirm.commenter.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/auth.signup.confirm.commenter.en.md
|
||||
@@ -17,3 +17,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter configure
|
||||
* If set to `Off`, commenters will be logged in immediately upon registration. This is not recommended due to security considerations; it may also render the user account unusable in the future if they misspelled their email address.
|
||||
|
||||
This setting applies only to websites embedding Comentario. For the Administration UI there's a [separate configuration item](auth.signup.confirm.user).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_AUTH_SIGNUP_CONFIRM_COMMENTER`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/auth.signup.confirm.user.en.md b/docs/content/configuration/backend/dynamic/auth.signup.confirm.user.en.md
|
||||
index 6a14a1d3..3aee4ae6 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/auth.signup.confirm.user.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/auth.signup.confirm.user.en.md
|
||||
@@ -17,3 +17,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter configure
|
||||
* If set to `Off`, users can log in immediately upon registration. This is not recommended due to security considerations; it may also render the user account unusable in the future if they misspelled their email address.
|
||||
|
||||
This setting applies only to the Administration UI. For websites embedding Comentario there's a [separate configuration item](auth.signup.confirm.commenter).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_AUTH_SIGNUP_CONFIRM_USER`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/auth.signup.enabled.en.md b/docs/content/configuration/backend/dynamic/auth.signup.enabled.en.md
|
||||
index 35acc2ba..d8a38804 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/auth.signup.enabled.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/auth.signup.enabled.en.md
|
||||
@@ -20,3 +20,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter controls
|
||||
* If set to `Off`, new user registrations are forbidden.
|
||||
|
||||
This setting applies only to the Administration UI. It can be useful for (temporarily) preventing new sign-ups.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_AUTH_SIGNUP_ENABLED`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.comments.deletion.author.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.comments.deletion.author.en.md
|
||||
index 9fef72b4..93f280cf 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.comments.deletion.author.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.comments.deletion.author.en.md
|
||||
@@ -18,3 +18,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter can be us
|
||||
|
||||
* When set to `On`, comment authors will see a *trashcan* button on their comments, which allows them to delete a written comment.
|
||||
* If set to `Off`, comments cannot be removed by their authors once submitted (but possibly can [by domain moderators](domain.defaults.comments.deletion.moderator) if enabled).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_COMMENTS_DELETION_AUTHOR`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.comments.deletion.moderator.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.comments.deletion.moderator.en.md
|
||||
index 97c3b3e0..f1c002f8 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.comments.deletion.moderator.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.comments.deletion.moderator.en.md
|
||||
@@ -18,3 +18,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter can be us
|
||||
|
||||
* When set to `On`, users with the moderator or owner [role](/kb/permissions/roles) and [superusers](/kb/permissions/superuser) will see a *trashcan* button on every comment, allowing them to delete any comment on the domain's pages.
|
||||
* If set to `Off`, comments cannot be removed by moderators (but possibly can [by their authors](domain.defaults.comments.deletion.author) if enabled).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_COMMENTS_DELETION_MODERATOR`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.comments.editing.author.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.comments.editing.author.en.md
|
||||
index 346a93b6..de989f59 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.comments.editing.author.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.comments.editing.author.en.md
|
||||
@@ -17,3 +17,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter can be us
|
||||
|
||||
* When set to `On`, comment authors will see a *pencil* button on their comments, which allows them to edit a written comment.
|
||||
* If set to `Off`, comments cannot be changed by their authors once submitted (but possibly can [by domain moderators](domain.defaults.comments.editing.moderator) if enabled).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_COMMENTS_EDITING_AUTHOR`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.comments.editing.moderator.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.comments.editing.moderator.en.md
|
||||
index 0b35d1e3..25bfcbf1 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.comments.editing.moderator.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.comments.editing.moderator.en.md
|
||||
@@ -17,3 +17,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter can be us
|
||||
|
||||
* When set to `On`, users with the moderator or owner [role](/kb/permissions/roles) and [superusers](/kb/permissions/superuser) will see a *pencil* button on every comment, allowing them to edit any comment on the domain's pages.
|
||||
* If set to `Off`, comments cannot be changed by moderators (but possibly can [by their authors](domain.defaults.comments.editing.author) if enabled).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_COMMENTS_EDITING_MODERATOR`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.comments.enablevoting.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.comments.enablevoting.en.md
|
||||
index a2e72f5b..17ec769e 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.comments.enablevoting.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.comments.enablevoting.en.md
|
||||
@@ -13,3 +13,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter can be us
|
||||
|
||||
* When set to `On`, every comment card will contain a score and a set of upvote/downvote buttons. Also, any commenter will be able to upvote or downvote others' comments (bot not those they authored self).
|
||||
* If set to `Off`, the score and the voting buttons will be hidden. It will also disable sorting comments by votes.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_COMMENTS_ENABLEVOTING`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.comments.rss.enabled.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.comments.rss.enabled.en.md
|
||||
index 3981741e..4108ed90 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.comments.rss.enabled.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.comments.rss.enabled.en.md
|
||||
@@ -21,3 +21,5 @@ When RSS is enabled, the users will be able to subscribe to comment feeds using:
|
||||
|
||||
* `RSS` dropdown button under the [comment editor](/kb/comment-editor) (left of the sorting buttons).
|
||||
* `Comment RSS feed` links in Domain properties and Domain page properties.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_COMMENTS_RSS_ENABLED`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.comments.showdeleted.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.comments.showdeleted.en.md
|
||||
index 89b26859..f2293dba 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.comments.showdeleted.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.comments.showdeleted.en.md
|
||||
@@ -18,3 +18,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter controls
|
||||
* If set to `Off`, deleted comments will be hidden in the comment tree immediately, as well as all its child comments.
|
||||
|
||||
This setting doesn't affect comment display in the Administration UI (it has a separate switch for hiding deleted comments).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_COMMENTS_SHOWDELETED`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.comments.text.maxlength.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.comments.text.maxlength.en.md
|
||||
index a87b2fff..9e068c5a 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.comments.text.maxlength.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.comments.text.maxlength.en.md
|
||||
@@ -21,3 +21,5 @@ It defines how long comment texts can be on a specific domain, representing the
|
||||
|
||||
* The lowest possible value for this setting is the "Twitter limit" of `140` characters.
|
||||
* The top (physical) limit is `1048576` (1 MiB).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_COMMENTS_TEXT_MAXLENGTH`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.login.showforunauth.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.login.showforunauth.en.md
|
||||
index 85b264e6..65a29ea4 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.login.showforunauth.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.login.showforunauth.en.md
|
||||
@@ -19,3 +19,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter allows to
|
||||
* If set to `Off`, the login dialog will be skipped if [commenting without registration](/configuration/frontend/domain/authentication) is enabled for this domain. Otherwise the dialog will be shown and user will be requested to log in or sign up.
|
||||
|
||||
When this setting is `Off`, the user can still authenticate explicitly using the `Sign in` button above the comment editor.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_LOGIN_SHOWFORUNAUTH`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.markdown.images.enabled.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.markdown.images.enabled.en.md
|
||||
index f229294c..6af7d884 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.markdown.images.enabled.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.markdown.images.enabled.en.md
|
||||
@@ -18,3 +18,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter configure
|
||||
* If set to `Off`, commenters won't be able to insert images, and the corresponding markup will be removed from the resulting text.
|
||||
|
||||
This setting only applies to newly written comments and does not affect images in existing comments.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_MARKDOWN_IMAGES_ENABLED`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.markdown.links.enabled.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.markdown.links.enabled.en.md
|
||||
index cfaaddcb..bb171b1e 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.markdown.links.enabled.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.markdown.links.enabled.en.md
|
||||
@@ -18,3 +18,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter configure
|
||||
* If set to `Off`, commenters won't be able to insert links, and the corresponding string will be rendered as plain, non-clickable text.
|
||||
|
||||
This setting only applies to newly written comments and does not affect links in existing comments.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_MARKDOWN_LINKS_ENABLED`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.markdown.tables.enabled.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.markdown.tables.enabled.en.md
|
||||
index 243affed..f38c097e 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.markdown.tables.enabled.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.markdown.tables.enabled.en.md
|
||||
@@ -16,5 +16,7 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter configure
|
||||
|
||||
* If set to `On`, commenters can insert [tables](/kb/markdown#tables) in comments.
|
||||
* If set to `Off`, commenters won't be able to insert tables, and the corresponding markup will be removed from the resulting text.
|
||||
-
|
||||
+
|
||||
This setting only applies to newly written comments and does not affect tables in existing comments.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_MARKDOWN_TABLES_ENABLED`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablefederated.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablefederated.en.md
|
||||
index 7a5d92a9..c6015fdb 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablefederated.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablefederated.en.md
|
||||
@@ -21,3 +21,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter controls
|
||||
This setting doesn't apply to the Administration UI, which uses a [separate configuration item](auth.signup.enabled) for that.
|
||||
|
||||
It also doesn't affect *existing users*, i.e. those already registered. They will be able to log in even when this setting is disabled. To disable federated login completely, switch off undesirable providers in the domain's [authentication settings](/configuration/frontend/domain/authentication).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_SIGNUP_ENABLEFEDERATED`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablelocal.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablelocal.en.md
|
||||
index 874d6dc4..f2dff20e 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablelocal.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablelocal.en.md
|
||||
@@ -23,3 +23,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter controls
|
||||
This setting doesn't apply to the Administration UI, which uses a [separate configuration item](auth.signup.enabled) for that.
|
||||
|
||||
It also doesn't affect *existing users*. They will be able to log in even when this setting is disabled. To disable login with email/password completely, switch it off in the domain's [authentication settings](/configuration/frontend/domain/authentication).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_SIGNUP_ENABLELOCAL`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablesso.en.md b/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablesso.en.md
|
||||
index 6da28064..86bc6826 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablesso.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/domain.defaults.signup.enablesso.en.md
|
||||
@@ -22,3 +22,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter controls
|
||||
* If set to `Off`, SSO registration on websites embedding comments will be forbidden.
|
||||
|
||||
This setting doesn't affect *SSO users who are already registered*. They will be able to log in even when this setting is disabled. To disable SSO login completely, switch it off in the domain's [authentication settings](/configuration/frontend/domain/authentication).
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_DOMAIN_DEFAULTS_SIGNUP_ENABLESSO`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/integrations.usegravatar.en.md b/docs/content/configuration/backend/dynamic/integrations.usegravatar.en.md
|
||||
index 8509944d..b81d1766 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/integrations.usegravatar.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/integrations.usegravatar.en.md
|
||||
@@ -16,3 +16,4 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter configure
|
||||
It also enables the use of Gravatar during import (e.g. from [Commento](/installation/migration/commento) or [WordPress](/installation/migration/wordpress)).
|
||||
* If set to `Off`, Gravatar won't be contacted.
|
||||
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_INTEGRATIONS_USEGRAVATAR`.
|
||||
diff --git a/docs/content/configuration/backend/dynamic/operation.newowner.enabled.en.md b/docs/content/configuration/backend/dynamic/operation.newowner.enabled.en.md
|
||||
index a3025d96..d2a27b15 100644
|
||||
--- a/docs/content/configuration/backend/dynamic/operation.newowner.enabled.en.md
|
||||
+++ b/docs/content/configuration/backend/dynamic/operation.newowner.enabled.en.md
|
||||
@@ -15,3 +15,5 @@ This [dynamic configuration](/configuration/backend/dynamic) parameter configure
|
||||
* If set to `Off`, users without domains (for example, commenters) won't be able to register their own domains in Comentario, and thus become domain owners. Most likely, this is what you want, therefore `Off` is the default.
|
||||
|
||||
This setting doesn't affect users who already own at least one domain.
|
||||
+
|
||||
+This default value of this setting can be overridden at startup using the environment variable `DYN_DEFAULT_OPERATION_NEWOWNER_ENABLED`.
|
||||
diff --git a/internal/data/dyn_config.go b/internal/data/dyn_config.go
|
||||
index 8595ea2a..ad5b9894 100644
|
||||
--- a/internal/data/dyn_config.go
|
||||
+++ b/internal/data/dyn_config.go
|
||||
@@ -2,14 +2,21 @@ package data
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
+ "os"
|
||||
+ "strconv"
|
||||
+ "strings"
|
||||
+ "time"
|
||||
+
|
||||
"github.com/go-openapi/strfmt"
|
||||
"github.com/go-openapi/swag"
|
||||
"github.com/google/uuid"
|
||||
+ "github.com/op/go-logging"
|
||||
"gitlab.com/comentario/comentario/internal/api/models"
|
||||
- "strconv"
|
||||
- "time"
|
||||
)
|
||||
|
||||
+// logger represents a package-wide logger instance
|
||||
+var logger = logging.MustGetLogger("data")
|
||||
+
|
||||
// DynConfigItemSectionKey is a key of dynamic configuration item section
|
||||
type DynConfigItemSectionKey string
|
||||
|
||||
@@ -196,6 +203,11 @@ const (
|
||||
// ConfigKeyDomainDefaultsPrefix is a prefix given to domain setting keys that turn them into global domain defaults keys
|
||||
const ConfigKeyDomainDefaultsPrefix = "domain.defaults."
|
||||
|
||||
+func getInitialDynConfigItemEnvVar(key DynConfigItemKey) (string, bool) {
|
||||
+ name := "DYN_DEFAULT_" + strings.ToUpper(strings.ReplaceAll(string(key), ".", "_"))
|
||||
+ return os.LookupEnv(name)
|
||||
+}
|
||||
+
|
||||
// DefaultDynInstanceConfig is the default dynamic instance configuration
|
||||
var DefaultDynInstanceConfig = DynConfigMap{
|
||||
ConfigKeyAuthEmailUpdateEnabled: {DefaultValue: "false", Datatype: ConfigDatatypeBool, Section: DynConfigItemSectionAuth},
|
||||
@@ -221,3 +233,15 @@ var DefaultDynInstanceConfig = DynConfigMap{
|
||||
ConfigKeyDomainDefaultsPrefix + DomainConfigKeyFederatedSignupEnabled: {DefaultValue: "true", Datatype: ConfigDatatypeBool, Section: DynConfigItemSectionAuth},
|
||||
ConfigKeyDomainDefaultsPrefix + DomainConfigKeySsoSignupEnabled: {DefaultValue: "true", Datatype: ConfigDatatypeBool, Section: DynConfigItemSectionAuth},
|
||||
}
|
||||
+
|
||||
+func init() {
|
||||
+ for key, item := range DefaultDynInstanceConfig {
|
||||
+ value, override := getInitialDynConfigItemEnvVar(key)
|
||||
+ if override {
|
||||
+ if err := item.ValidateValue(value); err != nil {
|
||||
+ logger.Fatalf("bad override for %q: %v", key, err)
|
||||
+ }
|
||||
+ item.DefaultValue = value
|
||||
+ }
|
||||
+ }
|
||||
+}
|
||||
--
|
||||
GitLab
|
||||
|
@@ -12,8 +12,12 @@ pkgs.stdenv.mkDerivation (finalAttrs: {
|
||||
};
|
||||
|
||||
patches = [
|
||||
# Fix variety typo
|
||||
(builtins.fetchurl {
|
||||
url = "https://patch-diff.githubusercontent.com/raw/Clemens-E/obsidian-languagetool-plugin/pull/132.patch";
|
||||
sha256 = "sha256:13lzp0920h1kc9yl3r04r505zb417hlciyiwii0fm5b12g35av8v";
|
||||
})
|
||||
./settings-notification.patch
|
||||
./variety-typo.patch
|
||||
];
|
||||
|
||||
offlineCache = pkgs.fetchYarnDeps {
|
||||
|
@@ -1,149 +0,0 @@
|
||||
diff --git a/src/SettingsTab.ts b/src/SettingsTab.ts
|
||||
index d0d65bb..2a211b0 100644
|
||||
--- a/src/SettingsTab.ts
|
||||
+++ b/src/SettingsTab.ts
|
||||
@@ -33,10 +33,10 @@ export interface LanguageToolPluginSettings {
|
||||
staticLanguage?: string;
|
||||
motherTongue?: string;
|
||||
|
||||
- englishVeriety?: undefined | 'en-US' | 'en-GB' | 'en-CA' | 'en-AU' | 'en-ZA' | 'en-NZ';
|
||||
- germanVeriety?: undefined | 'de-DE' | 'de-AT' | 'de-CH';
|
||||
- portugueseVeriety?: undefined | 'pt-BR' | 'pt-PT' | 'pt-AO' | 'pt-MZ';
|
||||
- catalanVeriety?: undefined | 'ca-ES' | 'ca-ES-valencia';
|
||||
+ englishVariety?: undefined | 'en-US' | 'en-GB' | 'en-CA' | 'en-AU' | 'en-ZA' | 'en-NZ';
|
||||
+ germanVariety?: undefined | 'de-DE' | 'de-AT' | 'de-CH';
|
||||
+ portugueseVariety?: undefined | 'pt-BR' | 'pt-PT' | 'pt-AO' | 'pt-MZ';
|
||||
+ catalanVariety?: undefined | 'ca-ES' | 'ca-ES-valencia';
|
||||
|
||||
pickyMode: boolean;
|
||||
|
||||
@@ -286,13 +286,13 @@ export class LanguageToolSettingsTab extends PluginSettingTab {
|
||||
component.onChange(async value => {
|
||||
this.plugin.settings.staticLanguage = value;
|
||||
if (value !== 'auto') {
|
||||
- this.plugin.settings.englishVeriety = undefined;
|
||||
+ this.plugin.settings.englishVariety = undefined;
|
||||
englishVarietyDropdown?.setValue('default');
|
||||
- this.plugin.settings.germanVeriety = undefined;
|
||||
+ this.plugin.settings.germanVariety = undefined;
|
||||
germanVarietyDropdown?.setValue('default');
|
||||
- this.plugin.settings.portugueseVeriety = undefined;
|
||||
+ this.plugin.settings.portugueseVariety = undefined;
|
||||
portugueseVarietyDropdown?.setValue('default');
|
||||
- this.plugin.settings.catalanVeriety = undefined;
|
||||
+ this.plugin.settings.catalanVariety = undefined;
|
||||
catalanVarietyDropdown?.setValue('default');
|
||||
}
|
||||
await this.plugin.saveSettings();
|
||||
@@ -338,14 +338,14 @@ export class LanguageToolSettingsTab extends PluginSettingTab {
|
||||
'en-ZA': 'English (South Africa)',
|
||||
'en-NZ': 'English (New Zealand)',
|
||||
})
|
||||
- .setValue(this.plugin.settings.englishVeriety ?? 'default')
|
||||
+ .setValue(this.plugin.settings.englishVariety ?? 'default')
|
||||
.onChange(async value => {
|
||||
if (value === 'default') {
|
||||
- this.plugin.settings.englishVeriety = undefined;
|
||||
+ this.plugin.settings.englishVariety = undefined;
|
||||
} else {
|
||||
this.plugin.settings.staticLanguage = 'auto';
|
||||
staticLanguageComponent?.setValue('auto');
|
||||
- this.plugin.settings.englishVeriety = value as 'en-US' | 'en-GB' | 'en-CA' | 'en-AU' | 'en-ZA' | 'en-NZ';
|
||||
+ this.plugin.settings.englishVariety = value as 'en-US' | 'en-GB' | 'en-CA' | 'en-AU' | 'en-ZA' | 'en-NZ';
|
||||
}
|
||||
await this.plugin.saveSettings();
|
||||
});
|
||||
@@ -360,14 +360,14 @@ export class LanguageToolSettingsTab extends PluginSettingTab {
|
||||
'de-CH': 'German (Switzerland)',
|
||||
'de-AT': 'German (Austria)',
|
||||
})
|
||||
- .setValue(this.plugin.settings.germanVeriety ?? 'default')
|
||||
+ .setValue(this.plugin.settings.germanVariety ?? 'default')
|
||||
.onChange(async value => {
|
||||
if (value === 'default') {
|
||||
- this.plugin.settings.germanVeriety = undefined;
|
||||
+ this.plugin.settings.germanVariety = undefined;
|
||||
} else {
|
||||
this.plugin.settings.staticLanguage = 'auto';
|
||||
staticLanguageComponent?.setValue('auto');
|
||||
- this.plugin.settings.germanVeriety = value as 'de-DE' | 'de-CH' | 'de-AT';
|
||||
+ this.plugin.settings.germanVariety = value as 'de-DE' | 'de-CH' | 'de-AT';
|
||||
}
|
||||
await this.plugin.saveSettings();
|
||||
});
|
||||
@@ -383,14 +383,14 @@ export class LanguageToolSettingsTab extends PluginSettingTab {
|
||||
'pt-AO': 'Portuguese (Angola)',
|
||||
'pt-MZ': 'Portuguese (Mozambique)',
|
||||
})
|
||||
- .setValue(this.plugin.settings.portugueseVeriety ?? 'default')
|
||||
+ .setValue(this.plugin.settings.portugueseVariety ?? 'default')
|
||||
.onChange(async value => {
|
||||
if (value === 'default') {
|
||||
- this.plugin.settings.portugueseVeriety = undefined;
|
||||
+ this.plugin.settings.portugueseVariety = undefined;
|
||||
} else {
|
||||
this.plugin.settings.staticLanguage = 'auto';
|
||||
staticLanguageComponent?.setValue('auto');
|
||||
- this.plugin.settings.portugueseVeriety = value as 'pt-BR' | 'pt-PT' | 'pt-AO' | 'pt-MZ';
|
||||
+ this.plugin.settings.portugueseVariety = value as 'pt-BR' | 'pt-PT' | 'pt-AO' | 'pt-MZ';
|
||||
}
|
||||
await this.plugin.saveSettings();
|
||||
});
|
||||
@@ -404,14 +404,14 @@ export class LanguageToolSettingsTab extends PluginSettingTab {
|
||||
'ca-ES': 'Catalan',
|
||||
'ca-ES-valencia': 'Catalan (Valencian)',
|
||||
})
|
||||
- .setValue(this.plugin.settings.catalanVeriety ?? 'default')
|
||||
+ .setValue(this.plugin.settings.catalanVariety ?? 'default')
|
||||
.onChange(async value => {
|
||||
if (value === 'default') {
|
||||
- this.plugin.settings.catalanVeriety = undefined;
|
||||
+ this.plugin.settings.catalanVariety = undefined;
|
||||
} else {
|
||||
this.plugin.settings.staticLanguage = 'auto';
|
||||
staticLanguageComponent?.setValue('auto');
|
||||
- this.plugin.settings.catalanVeriety = value as 'ca-ES' | 'ca-ES-valencia';
|
||||
+ this.plugin.settings.catalanVariety = value as 'ca-ES' | 'ca-ES-valencia';
|
||||
}
|
||||
await this.plugin.saveSettings();
|
||||
});
|
||||
diff --git a/src/api.ts b/src/api.ts
|
||||
index 109984c..4cd1700 100644
|
||||
--- a/src/api.ts
|
||||
+++ b/src/api.ts
|
||||
@@ -58,27 +58,27 @@ export async function getDetectionResult(
|
||||
params.disabledRules = settings.ruleOtherDisabledRules;
|
||||
}
|
||||
|
||||
- if (settings.englishVeriety) {
|
||||
+ if (settings.englishVariety) {
|
||||
params.preferredVariants = `${params.preferredVariants ? `${params.preferredVariants},` : ''}${
|
||||
- settings.englishVeriety
|
||||
+ settings.englishVariety
|
||||
}`;
|
||||
}
|
||||
|
||||
- if (settings.germanVeriety) {
|
||||
+ if (settings.germanVariety) {
|
||||
params.preferredVariants = `${params.preferredVariants ? `${params.preferredVariants},` : ''}${
|
||||
- settings.germanVeriety
|
||||
+ settings.germanVariety
|
||||
}`;
|
||||
}
|
||||
|
||||
- if (settings.portugueseVeriety) {
|
||||
+ if (settings.portugueseVariety) {
|
||||
params.preferredVariants = `${params.preferredVariants ? `${params.preferredVariants},` : ''}${
|
||||
- settings.portugueseVeriety
|
||||
+ settings.portugueseVariety
|
||||
}`;
|
||||
}
|
||||
|
||||
- if (settings.catalanVeriety) {
|
||||
+ if (settings.catalanVariety) {
|
||||
params.preferredVariants = `${params.preferredVariants ? `${params.preferredVariants},` : ''}${
|
||||
- settings.catalanVeriety
|
||||
+ settings.catalanVariety
|
||||
}`;
|
||||
}
|
||||
|
Reference in New Issue
Block a user