Skip to content

Commit 1cd5d7b

Browse files
committed
Updated configuration documentation
1 parent c9576f0 commit 1cd5d7b

File tree

1 file changed

+35
-19
lines changed

1 file changed

+35
-19
lines changed

docs/configuration.md

Lines changed: 35 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@ Part-DBs behavior can be configured to your needs. There are different kinds of
1010
user-changeable (changeable dynamically via frontend), options that can be configured by environment variables, and
1111
options that are only configurable via Symfony config files.
1212

13-
## User changeable
13+
## User configruation
1414

1515
The following things can be changed for every user and a user can change it for himself (if he has the correct permission
1616
for it). Configuration is either possible via the user's own settings page (where you can also change the password) or via
@@ -24,15 +24,33 @@ the user admin page:
2424
* **Preferred currency**: One of the defined currencies, in which all prices should be shown, if possible. Prices with
2525
other currencies will be converted to the price selected here
2626

27+
## System configuration (via web interface)
28+
29+
Many common configuration options can be changed via the web interface. You can find the settings page in the sidebar under
30+
"System" -> "Settings". You need to have the "Change system settings" permission to access this page.
31+
32+
If a setting is greyed out and cannot be changed, it means that this setting is currently overwritten by an environment
33+
variable. You can either change the environment variable to change the setting, or you can migrate the setting to the
34+
database, so that it can be changed via the web interface. To do this, you can use the `php bin/console settings:migrate-env-to-settings` command
35+
and remove the environment variable afterward.
36+
2737
## Environment variables (.env.local)
2838

2939
The following configuration options can only be changed by the server administrator, by either changing the server
3040
variables, changing the `.env.local` file or setting env for your docker container. Here are just the most important
3141
options listed, see `.env` file for the full list of possible env variables.
3242

43+
Environment variables allow to overwrite settings in the web interface. This is useful, if you want to enforce certain
44+
settings to be unchangable by users, or if you want to configure settings in a central place in a deployed environment.
45+
On the settings page, you can hover over a setting to see, which environment variable can be used to overwrite it, it
46+
is shown as tooltip.
47+
48+
For technical and security reasons some settings can only be configured via environment variables and not via the web
49+
interface. These settings are marked with "(env only)" in the description below.
50+
3351
### General options
3452

35-
* `DATABASE_URL`: Configures the database which Part-DB uses:
53+
* `DATABASE_URL` (env only): Configures the database which Part-DB uses:
3654
* For MySQL (or MariaDB) use a string in the form of `mysql://<USERNAME>:<PASSWORD>@<HOST>:<PORT>/<TABLE_NAME>` here
3755
(e.g. `DATABASE_URL=mysql://user:[email protected]:3306/part-db`).
3856
* For SQLite use the following format to specify the
@@ -42,10 +60,10 @@ options listed, see `.env` file for the full list of possible env variables.
4260

4361
Please note that **`serverVersion=x.y`** variable is required due to dependency of Symfony framework.
4462

45-
* `DATABASE_MYSQL_USE_SSL_CA`: If this value is set to `1` or `true` and a MySQL connection is used, then the connection
63+
* `DATABASE_MYSQL_USE_SSL_CA` (env only): If this value is set to `1` or `true` and a MySQL connection is used, then the connection
4664
is encrypted by SSL/TLS and the server certificate is verified against the system CA certificates or the CA certificate
4765
bundled with Part-DB. Set `DATABASE_MYSQL_SSL_VERIFY_CERT` if you want to accept all certificates.
48-
* `DATABASE_EMULATE_NATURAL_SORT` (default 0): If set to 1, Part-DB will emulate natural sorting, even if the database
66+
* `DATABASE_EMULATE_NATURAL_SORT` (default 0) (env only): If set to 1, Part-DB will emulate natural sorting, even if the database
4967
does not support it natively. However this is much slower than the native sorting, and contain bugs or quirks, so use
5068
it only, if you have to.
5169
* `DEFAULT_LANG`: The default language to use server-wide (when no language is explicitly specified by a user or via
@@ -74,7 +92,7 @@ bundled with Part-DB. Set `DATABASE_MYSQL_SSL_VERIFY_CERT` if you want to accept
7492
to specify the size in kilobytes, megabytes or gigabytes. By default `100M` (100 megabytes). Please note that this is
7593
only the limit of Part-DB. You still need to configure the php.ini `upload_max_filesize` and `post_max_size` to allow
7694
bigger files to be uploaded.
77-
* `DEFAULT_URI`: The default URI base to use for the Part-DB, when no URL can be determined from the browser request.
95+
* `DEFAULT_URI` (env only): The default URI base to use for the Part-DB, when no URL can be determined from the browser request.
7896
This should be the primary URL/Domain, which is used to access Part-DB. This value is used to create correct links in
7997
emails and other places, where the URL is needed. It is also used, when SAML is enabled.s If you are using a reverse
8098
proxy, you should set this to the URL of the reverse proxy (e.g. `https://part-db.example.com`). **This value must end
@@ -91,14 +109,14 @@ bundled with Part-DB. Set `DATABASE_MYSQL_SSL_VERIFY_CERT` if you want to accept
91109
* `datastructure_create`: Creation of a new datastructure (e.g. category, manufacturer, ...)
92110
* `CHECK_FOR_UPDATES` (default `1`): Set this to 0, if you do not want Part-DB to connect to GitHub to check for new
93111
versions, or if your server can not connect to the internet.
94-
* `APP_SECRET`: This variable is a configuration parameter used for various security-related purposes,
112+
* `APP_SECRET` (env only): This variable is a configuration parameter used for various security-related purposes,
95113
particularly for securing and protecting various aspects of your application. It's a secret key that is used for
96114
cryptographic operations and security measures (session management, CSRF protection, etc..). Therefore this
97115
value should be handled as confidential data and not shared publicly.
98116
* `SHOW_PART_IMAGE_OVERLAY`: Set to 0 to disable the part image overlay, which appears if you hover over an image in the
99117
part image gallery
100118

101-
### E-Mail settings
119+
### E-Mail settings (all env only)
102120

103121
* `MAILER_DSN`: You can configure the mail provider which should be used for email delivery (
104122
see https://symfony.com/doc/current/components/mailer.html for full documentation). If you just want to use an SMTP
@@ -138,7 +156,7 @@ The following options are used to configure, which (and how much) data is writte
138156
If you want to use want to revert changes or view older revisions of entities,
139157
then `HISTORY_SAVE_CHANGED_FIELDS`, `HISTORY_SAVE_CHANGED_DATA` and `HISTORY_SAVE_REMOVED_DATA` all have to be true.
140158

141-
### Error pages settings
159+
### Error pages settings (all env only)
142160

143161
* `ERROR_PAGE_ADMIN_EMAIL`: You can set an email address here, which is shown on the error page, who should be contacted
144162
about the issue (e.g. an IT support email of your company)
@@ -153,7 +171,7 @@ then `HISTORY_SAVE_CHANGED_FIELDS`, `HISTORY_SAVE_CHANGED_DATA` and `HISTORY_SAV
153171
All parts in the selected category and all subcategories are shown in KiCad. Set this to a higher value, if you want to show more categories in KiCad.
154172
When you set this value to -1, all parts are shown inside a single category in KiCad.
155173

156-
### SAML SSO settings
174+
### SAML SSO settings (all env only)
157175

158176
The following settings can be used to enable and configure Single-Sign on via SAML. This allows users to log in to
159177
Part-DB without entering a username and password, but instead they are redirected to a SAML Identity Provider (IdP) and
@@ -201,34 +219,34 @@ See the [information providers]({% link usage/information_provider_system.md %})
201219

202220
### Other / less-used options
203221

204-
* `TRUSTED_PROXIES`: Set the IP addresses (or IP blocks) of trusted reverse proxies here. This is needed to get correct
222+
* `TRUSTED_PROXIES` (env only): Set the IP addresses (or IP blocks) of trusted reverse proxies here. This is needed to get correct
205223
IP information (see [here](https://symfony.com/doc/current/deployment/proxies.html) for more info).
206-
* `TRUSTED_HOSTS`: To prevent `HTTP Host header attacks` you can set a regex containing all host names via which Part-DB
224+
* `TRUSTED_HOSTS` (env only): To prevent `HTTP Host header attacks` you can set a regex containing all host names via which Part-DB
207225
should be accessible. If accessed via the wrong hostname, an error will be shown.
208-
* `DEMO_MODE`: Set Part-DB into demo mode, which forbids users to change their passwords and settings. Used for the demo
226+
* `DEMO_MODE` (env only): Set Part-DB into demo mode, which forbids users to change their passwords and settings. Used for the demo
209227
instance. This should not be needed for normal installations.
210-
* `NO_URL_REWRITE_AVAILABLE` (allowed values `true` or `false`): Set this value to true, if your webserver does not
228+
* `NO_URL_REWRITE_AVAILABLE` (allowed values `true` or `false`) (env only): Set this value to true, if your webserver does not
211229
support rewrite. In this case, all URL paths will contain index.php/, which is needed then. Normally this setting does
212230
not need to be changed.
213-
* `REDIRECT_TO_HTTPS`: If this is set to true, all requests to http will be redirected to https. This is useful if your
231+
* `REDIRECT_TO_HTTPS` (env only): If this is set to true, all requests to http will be redirected to https. This is useful if your
214232
web server does not already do this (like the one used in the demo instance). If your web server already redirects to
215233
https, you don't need to set this. Ensure that Part-DB is accessible via HTTPS before you enable this setting.
216234
* `FIXER_API_KEY`: If you want to automatically retrieve exchange rates for base currencies other than euros, you have to
217235
configure an exchange rate provider API. [Fixer.io](https://fixer.io/) is preconfigured, and you just have to register
218236
there and set the retrieved API key in this environment variable.
219-
* `APP_ENV`: This value should always be set to `prod` in normal use. Set it to `dev` to enable debug/development
237+
* `APP_ENV` (env only): This value should always be set to `prod` in normal use. Set it to `dev` to enable debug/development
220238
mode. (**You should not do this on a publicly accessible server, as it will leak sensitive information!**)
221239
* `BANNER`: You can configure the text that should be shown as the banner on the homepage. Useful especially for docker
222240
containers. In all other applications you can just change the `config/banner.md` file.
223-
* `DISABLE_YEAR2038_BUG_CHECK`: If set to `1`, the year 2038 bug check is disabled on 32-bit systems, and dates after
241+
* `DISABLE_YEAR2038_BUG_CHECK` (env only): If set to `1`, the year 2038 bug check is disabled on 32-bit systems, and dates after
224242
2038 are no longer forbidden. However this will lead to 500 error messages when rendering dates after 2038 as all current
225243
32-bit PHP versions can not format these dates correctly. This setting is for the case that future PHP versions will
226244
handle this correctly on 32-bit systems. 64-bit systems are not affected by this bug, and the check is always disabled.
227245

228246
## Banner
229247

230248
To change the banner you can find on the homepage, you can either set the `BANNER` environment variable to the text you
231-
want to show, or you can edit the `config/banner.md` file. The banner is written in markdown, so you can use all
249+
want to show, or change it in the system settings webinterface. The banner is written in markdown, so you can use all
232250
markdown (and even some subset of HTML) syntax to format the text.
233251

234252
## parameters.yaml
@@ -243,8 +261,6 @@ command `bin/console cache:clear`.
243261

244262
The following options are available:
245263

246-
* `partdb.global_theme`: The default theme to use, when no user specific theme is set. Should be one of the themes from
247-
the `partdb.available_themes` config option.
248264
* `partdb.locale_menu`: The codes of the languages, which should be shown in the language chooser menu (the one with the
249265
user icon in the navbar). The first language in the list will be the default language.
250266
* `partdb.gdpr_compliance`: When set to true (default value), IP addresses which are saved in the database will be

0 commit comments

Comments
 (0)