]> git.mxchange.org Git - friendica.git/blob - doc/Settings.md
Update "storage" console command
[friendica.git] / doc / Settings.md
1 # Settings
2
3 * [Home](help)
4
5 If you are the admin of a Friendica node, you have access to the **Admin Panel** where you can configure your Friendica node.
6
7 ## Overview
8
9 In the main page of the admin panel you will see an information summary about your node.
10
11 ### Queues
12
13 The three numbers shown are respectively:
14 - The retry queue: These outgoing messages couldn't be received by the remote host, and will be resent at longer intervals before being dropped entirely after 30 days.
15 - The deferred queue: These internal tasks failed and will be retried at most 14 times.
16 - The task queue: These internal tasks are queued for execution during the next background worker run.
17
18 ### Additional information
19
20 Then you get an overview of the accounts on your node, which can be moderated in the "Users" section of the panel.
21 As well as an overview of the currently active addons.
22 The list is linked, so you can have quick access to the Addon settings.
23 And finally you are informed about the version of Friendica you have installed.
24 If you contact the developers with a bug or problem, please also mention the version of your node.
25
26 The admin panel is separated into subsections accessible from the side bar of the panel.
27
28 ## Site
29
30 This section of the admin panel contains the main configuration of your Friendica node.
31 It is separated into several sub-section beginning with the basic settings at the top, advancing towards the bottom of the page.
32
33 Most configuration options have a help text in the admin panel.
34 Therefore this document does not yet cover all the options
35
36 ### Basic Settings
37
38 #### Banner/Logo
39
40 Set the content for the site banner.
41 The default logo is the Friendica logo and name.
42 You may wish to provide HTML/CSS to style and/or position this content, as it may not be themed by default.
43
44 #### Language
45
46 This option will set the default language for the node.
47 It is used as fall back setting should Friendica fail to recognize the visitors preferences and can be overwritten by user settings.
48
49 The Friendica community offers some translations.
50 Some more complete then others.
51 See [this help page](/help/translations) for more information about the translation process.
52
53 #### System Theme
54
55 Choose a theme to be the default system theme.
56 This can be over-ridden by user profiles.
57 Default theme is `vier` at the moment.
58
59 You may also want to set a special theme for mobile interfaces.
60 Which may or may not be necessary depending of the mobile friendliness of the desktop theme you have chosen.
61 The `vier` theme for instance is mobile friendly.
62
63 ### Registration
64
65 #### Register policy
66
67 With this drop down selector you can set the nodes registration policy.
68 You can chose between the following modes:
69
70 * **open**: Everybody can register a new account and start using it right away.
71 * **requires approval**: Everybody can register a new account, but the admin has to approve it before it can be used.
72 * **closed**: No new registrations are possible.
73
74 ##### Invitation based registry
75
76 Additionally to the setting in the admin panel, you can decide if registrations are only possible using an invitation code or not.
77 To enable invitation based registration, you have to set the `invitation_only` setting in the [config/local.config.php](/help/Config) file.
78 If you want to use this method, the registration policy has to be set to either *open* or *requires approval*.
79
80 #### Check Full Names
81
82 You may find a lot of spammers trying to register on your site.
83 During testing we discovered that since these registrations were automatic, the "Full Name" field was often set to just an account name with no space between first and last name.
84 If you would like to support people with only one name as their full name, you may change this setting to true.
85 Default is false.
86
87 #### OpenID
88
89 By default, OpenID may be used for both registration and logins.
90 If you do not wish to make OpenID facilities available on your system (at all), set 'no_openid' to true.
91 Default is false.
92
93 #### Multiple Registrations
94
95 The ability to create "Pages" requires a person to register more than once.
96 Your site configuration can block registration (or require approval to register).
97 By default, logged in users can register additional accounts for use as pages.
98 These will still require approval if the registration policy is set to *require approval*
99 You may prohibit logged in users from creating additional accounts by setting *block multiple registrations* to true.
100 Default is false.
101
102 ### File upload
103
104 #### File storage backend
105
106 Set the backend used by Friendica to store uploaded file data.
107 Two storage backends are avaiable with Friendica:
108
109 - **Database** : Data is stored in a dedicated table in database (`storage`)
110 - **Filesystem** : Data is stored as file on the filesystem.
111
112 More storage backends can be avaiable from third-party addons.
113
114 Default value is 'None': it's the legacy way used to store data directly in database.
115
116 Existing data can be moved to the current active backend using the ['storage move' console command](help/tools)
117
118 If selected backend has configurable options, new fields are shown here.
119
120 ##### Filesystem: Storage base path
121
122 The base path where Filesystem storage backend saves data.
123
124 For maximum security, this path should be outside the folder tree served by the web server: this way files can't be downloaded bypassing the privacy checks.
125
126 Default value is `storage`, that is the `storage` folder in Friendica code root folder.
127
128
129 #### Maximum Image Size
130
131 Maximum size in bytes of uploaded images.
132 The default is set to 0, which means no limits.
133
134 ### Policies
135
136 #### Global Directory
137
138 This configures the URL to update the global directory, and is supplied in the default configuration.
139 The undocumented part is that if this is not set, the global directory is completely unavailable to the application.
140 This allows a private community to be completely isolated from the global network.
141
142 #### Force Publish
143
144 By default, each user can choose on their Settings page whether or not to have their profile published in the site directory.
145 This setting forces all profiles on this site to be listed in the site directory and there is no option provided to the user to change it.
146 Default is false.
147
148 #### Block Public
149
150 Set to true to block public access to all otherwise public personal pages on this site unless you are currently logged in.
151 This blocks the viewing of profiles, friends, photos, the site directory and search pages to unauthorised persons.
152 A side effect is that entries from this site will not appear in the global directory.
153 We recommend specifically disabling that also (setting is described elsewhere on this page).
154 Note: this is specifically for sites that desire to be "standalone" and do not wish to be connected to any other Friendica sites.
155 Unauthorised persons will also not be able to request friendship with site members.
156 Default is false.
157 Available in version 2.2 or greater.
158
159 #### Community pages for Visitors
160
161 The community pages show all public postings, separated by their origin being local or the entire network.
162 With this setting you can select which community pages will be shown to visitors of your Friendica node.
163 Your local users will always have access to both pages.
164
165 **Note**: Several settings, like users hiding their contacts from the public will prevent the postings to show up on the global community page.
166
167 #### Allowed Friend Domains
168
169 Comma separated list of domains which are allowed to establish friendships with this site.
170 Wildcards are accepted.
171 (Wildcard support on Windows platforms requires PHP5.3).
172 By default, any (valid) domain may establish friendships with this site.
173
174 This is useful if you want to setup a closed network for educational groups, cooperatives and similar communities that don't want to communicate with the rest of the network.
175
176 #### Allowed Email Domains
177
178 Comma separated list of domains which are allowed in email addresses for registrations to this site.
179 This can lockout those who are not part of this organisation from registering here.
180 Wildcards are accepted.
181 (Wildcard support on Windows platforms requires PHP5.3).
182 By default, any (valid) email address is allowed in registrations.
183
184 #### Allow Users to set remote_self
185
186 If you enable the `Allow Users to set remote_self` users can select Atom feeds from their contact list being their *remote self* in the advanced contact settings.
187 Which means that postings by the remote self are automatically reposted by Friendica in their names.
188
189 This feature can be used to let the user mirror e.g. blog postings into their Friendica postings.
190 It is disabled by default, as it causes additional load on the server and may be misused to distribute SPAM.
191
192 As admin of the node you can also set this flag directly in the database.
193 Before doing so, you should be sure you know what you do and have a backup of the database.
194
195 #### Explicit Content
196
197 If you are running a node with explicit content, you can announce this with this option.
198 When checked an information flag will be set in the published information about your node.
199 (Should *Publish Server Information* be enabled.)
200
201 Additionally a note will be displayed on the registration page for new users.
202
203 ### Advanced
204
205 #### Proxy Configuration Settings
206
207 If your site uses a proxy to connect to the internet, you may use these settings to communicate with the outside world.
208 The outside world still needs to be able to see your website, or this will not be very useful.
209
210 #### Network Timeout
211
212 How long to wait on a network communication before timing out.
213 Value is in seconds.
214 Default is 60 seconds.
215 Set to 0 for unlimited (not recommended).
216
217 #### Verify SSL Certificates
218
219 By default Friendica allows SSL communication between websites that have "self-signed" SSL certificates.
220 For the widest compatibility with browsers and other networks we do not recommend using self-signed certificates, but we will not prevent you from using them.
221 SSL encrypts all the data transmitted between sites (and to your browser).
222 This allows you to have completely encrypted communications, and also protect your login session from hijacking.
223 Self-signed certificates can be generated for free, without paying top-dollar for a website SSL certificate.
224 However these aren't looked upon favourably in the security community because they can be subject to so-called "man-in-the-middle" attacks.
225 If you wish, you can turn on strict certificate checking.
226 This will mean you cannot connect (at all) to self-signed SSL sites.
227
228 #### Check upstream version
229
230 If this option is enabled your Friendica node will check the upstream version once per day from the github repository.
231 You can select if the stable version or the development version should be checked out.
232 If there is a new version published, you will get notified in the admin panel summary page.
233
234 ### Auto Discovered Contact Directory
235
236 ### Performance
237
238 ### Worker
239
240 This section allows you to configure the background process that is triggered by the `cron` job that was created during the installation.
241 The process does check the available system resources before creating a new worker for a task.
242 Because of this, it may happen that the maximum number of worker processes you allow will not be reached.
243
244 If your server setup does not allow you to use the `proc_open` function of PHP, please disable it in this section.
245
246 The tasks for the background process have priorities.
247 To guarantee that important tasks are executed even though the system has a lot of work to do, it is useful to enable the *fastlane*.
248
249 Should you not be able to run a cron job on your server, you can also activate the *frontend* worker.
250 If you have done so, you can call `example.com/worker` (replace example.com with your actual domain name) on a regular basis from an external service.
251 This will then trigger the execution of the background process.
252
253 ### Relocate
254
255 ## Users
256
257 This section of the panel let the admin control the users registered on the node.
258
259 If you have selected "Requires approval" for the *Register policy* in the general nodes configuration, new registrations will be listed at the top of the page.
260 There the admin can then approve or disapprove the request.
261
262 Below the new registration block the current accounts on the Friendica node are listed.
263 You can sort the user list by name, email, registration date, date of last login, date of last posting and the account type.
264 Here the admin can also block/unblock users from accessing the node or delete the accounts entirely.
265
266 In the last section of the page admins can create new accounts on the node.
267 The password for the new account will be send by email to the chosen email address.
268
269 ## Addons
270
271 This page is for selecting and configuration of extensions for Friendica which have to be placed into the `/addon` subdirectory of your Friendica installation.
272 You are presented with a long list of available addons.
273 The name of each addon is linked to a separate page for that addon which offers more information and configuration possibilities.
274 Also shown is the version of the addon and an indicator if the addon is currently active or not.
275
276 When you update your node and the addons they may have to be reloaded.
277 To simplify this process there is a button at the top of the page to reload all active Addons.
278
279 ## Themes
280
281 The Themes section of the admin panel works similar to the Addons section but let you control the themes on your Friendica node.
282 Each theme has a dedicated subpage showing the current status, some information about the theme and a screen-shot of the Friendica interface using the theme.
283 Should the theme offer special settings, admins can set a global default value here.
284
285 You can activate and deactivate themes on their dedicated sub-pages thus making them available for the users of the node.
286 To select a default theme for the Friendica node, see the *Site* section of the admin panel.
287
288 ## Additional Features
289
290 There are several optional features in Friendica like the *dislike* button.
291 In this section of the admin panel you can select a default setting for your node and eventually fix it, so users cannot change the setting anymore.
292
293 ## DB Updates
294
295 Should the database structure of Friendica change, it will apply the changes automatically.
296 In case you are suspecting the update might not have worked, you can use this section of the admin panel to check the situation.
297
298 ## Inspect Queue
299
300 In the admin panel summary there are two numbers for the message queues.
301 The second number represents messages which could not be delivered and are queued for later retry.
302 If this number goes sky-rocking you might ask yourself which recipient is not receiving.
303
304 Behind the inspect queue section of the admin panel you will find a list of the messages that could not be delivered.
305 The listing is sorted by the recipient name so identifying potential broken communication lines should be simple.
306 These lines might be broken for various reasons.
307 The receiving end might be off-line, there might be a high system load and so on.
308
309 Don't panic!
310 Friendica will not queue messages for all time but will sort out *dead* nodes automatically after a while and remove messages from the queue then.
311
312 ## Server Blocklist
313
314 This page allows to block all communications (inbound and outbound) with a specific domain name.
315 Each blocked domain entry requires a reason that will be displayed on the [friendica](/friendica) page.
316 Matching is exact, blocking a domain doesn't block subdomains.
317
318 ## Federation Statistics
319
320 The federation statistics page gives you a short summery of the nodes/servers/pods of the decentralized social network federation your node knows.
321 These numbers are not complete and only contain nodes from networks Friendica federates directly with.
322
323 ## Delete Item
324
325 Using this page an admin can delete postings and eventually associated discussion threads from their Friendica node.
326 To do so, they need to know the GUID of the posting.
327 This can be found on the `/display` page of the posting, it is the last part of the URL displayed in the browsers navigation bar.
328 You can get to the `/display` page by following the *Link to source*.
329
330 ## Addon Features
331
332 Some of the addons you can install for your Friendica node have settings which have to be set by the admin.
333 All those addons will be listed in this area of the admin panels side bar with their names.
334
335 ## Logs
336
337 The log section of the admin panel is separated into two pages.
338 On the first, following the "log" link, you can configure how much Friendica shall log.
339 And on the second you can read the log.
340
341 You should not place your logs into any directory that is accessible from the web.
342 If you have to, and you are using the default configuration from Apache, you should choose a name for the logfile ending in ``.log`` or ``.out``.
343 Should you use another web server, please make sure that you have the correct access rules in place so that your log files are not accessible.
344
345 There are five different log levels: Normal, Trace, Debug, Data and All.
346 Specifying different verbosity of information and data written out to the log file.
347 Normally you should not need to log at all.
348 The *DEBUG* level will show a good deal of information about system activity but will not include detailed data.
349 In the *ALL* level Friendica will log everything to the file.
350 But due to the volume of information we recommend only enabling this when you are tracking down a specific problem.
351
352 **The amount of data can grow the filesize of the logfile quickly**.
353 You should set up some kind of [log rotation](https://en.wikipedia.org/wiki/Log_rotation) to keep the log file from growing too big.
354
355 **Known Issues**: The filename ``friendica.log`` can cause problems depending on your server configuration (see [issue 2209](https://github.com/friendica/friendica/issues/2209)).
356
357 By default PHP warnings and error messages are suppressed.
358 If you want to enable those, you have to activate them in the ``config/local.config.php`` file.
359 Use the following settings to redirect PHP errors to a file.
360
361 Config:
362
363         error_reporting(E_ERROR | E_WARNING | E_PARSE );
364         ini_set('error_log','php.out');
365         ini_set('log_errors','1');
366         ini_set('display_errors', '0');
367
368 This will put all PHP errors in the file php.out (which must be writeable by the webserver).
369 Undeclared variables are occasionally referenced in the program and therefore we do not recommend using `E_NOTICE` or `E_ALL`.
370 The vast majority of issues reported at these levels are completely harmless.
371 Please report to the developers any errors you encounter in the logs using the recommended settings above.
372 They generally indicate issues which need to be resolved.
373
374 If you encounter a blank (white) page when using the application, view the PHP logs - as this almost always indicates an error has occurred.
375
376 ## Diagnostics
377
378 In this section of the admin panel you find two tools to investigate what Friendica sees for certain resources.
379 These tools can help to clarify communication problems.
380
381 For the *probe address* Friendica will display information for the address provided.
382
383 With the second tool *check webfinger* you can request information about the thing identified by a webfinger (`someone@example.com`).
384
385 # Exceptions to the rule
386
387 There are four exceptions to the rule, that all the config will be read from the data base.
388 These are the data base settings, the admin account settings, the path of PHP and information about an eventual installation of the node in a sub-directory of the (sub)domain.
389
390 ## DB Settings
391
392 With the following settings, you specify the data base server, the username and password for Friendica and the database to use.
393
394         'database' => [
395                 'hostname' => 'localhost',
396                 'username' => 'mysqlusername',
397                 'password' => 'mysqlpassword',
398                 'database' => 'mysqldatabasename',
399                 'charset' => 'utf8mb4',
400         ],
401
402 ## Admin users
403
404 You can set one, or more, accounts to be *Admin*.
405 By default this will be the one account you create during the installation process.
406 But you can expand the list of email addresses by any used email address you want.
407 Registration of new accounts with a listed email address is not possible.
408
409         'config' => [
410                 'admin_email' => 'you@example.com, buddy@example.com',
411         ],
412
413 ## PHP Path
414
415 Some of Friendica's processes are running in the background.
416 For this you need to specify the path to the PHP binary to be used.
417
418         'config' => [
419                 'php_path' => '/usr/bin/php',
420         ],
421
422 ## Subdirectory configuration
423
424 It is possible to install Friendica into a subdirectory of your web server.
425 We strongly discourage you from doing so, as this will break federation to other networks (e.g. Diaspora, GNU Social, Hubzilla)
426 Say you have a subdirectory for tests and put Friendica into a further subdirectory, the config would be:
427
428         'system' => [
429                 'urlpath' => 'tests/friendica',
430         ],
431
432 ## Other exceptions
433
434 Furthermore there are some experimental settings, you can read-up in the [Config values that can only be set in config/local.config.php](help/Config) section of the documentation.
435