Configuration Settings¶
Configuration settings let System Admins manage their Mattermost server and multiple teams. System Admins can modify configuration settings directly in the config.json
file or by using the web-based System Console user interface. Setting changes in the System Console are stored in config/config.json
.
The first user added to a new Mattermost install is assigned the System Admin role and can access the System Console from the Main Menu of any team.
Note: For any setting not explicitly set in config.json
the Mattermost server will use the default value as documented here, which can be observed in the default config/config.json
file included in each Mattermost release.
Quick Links:
- General
- Configuration - Localization - Users and Teams - Privacy - Policy - Compliance - Logging
- Authentication
- Email Auth - OAuth 2.0 - GitLab - Google - Office 365 - AD/LDAP - SAML
- Security
- Sign Up - Password - Public Links - Sessions - Connections
- Notifications
- Email - Mobile Push
- Integrations
- Custom Integrations - WebRTC (Beta) - External Services
- Files
- Storage - Images
- Customization
- Custom Branding - Custom Emoji - Legal and Support - Mattermost App Links
- Advanced
- Rate Limiting - Database - Developer - High Availability (Beta)
General¶
General settings for server configuration, language defaults, user and team management, privacy, compliance reporting and logs.
Configuration¶
Site URL¶
The URL, including port number and protocol, from which users will access Mattermost. Leave blank to automatically configure based on incoming traffic.
This feature’s config.json setting is "SiteURL": "" with string input. |
Listen Address¶
The address and port to which to bind and listen. Specifying ”:8065” will bind to all network interfaces. Specifying 127.0.0.1:8065
will only bind to the network interface having that IP address.
If you choose a port of a lower level (called “system ports” or “well-known ports”, in the range of 0-1023), you must have permissions to bind to that port.
On Linux you can use: sudo setcap cap_net_bind_service=+ep ./bin/platform
to allow Mattermost to bind to well-known ports.
This feature’s config.json setting is "ListenAddress": ":8065" with string input |
Connection Security¶
None: Mattermost will connect over an unsecure connection.
TLS: Encrypts the communication between Mattermost and your server. See [documentation](https://docs.mattermost.com/install/setup-tls.html) for more details.
This feature’s config.json setting is "ConnectionSecurity": "" with options "" and TLS for the above settings respectively |
TLS Certificate File¶
The path to the certificate file to use for TLS connection security.
This feature’s config.json setting is "TLSCertFile": "" with string input |
TLS Key File¶
The path to the TLS key file to use for TLS connection security.
This feature’s config.json setting is "TLSKeyFile": "" with string input |
Use Let’s Encrypt¶
True: Enable the automatic retreval of certificates from Let’s Encrypt. The certificate will be retrieved when a client attempts to connect from a new domain. This will work with multiple domains. See [documentation](https://docs.mattermost.com/install/setup-tls.html#automatic-certificate-retrieval) for more details on setting up Let’s Encrypt.
False: Manual certificate specification based on the TLS Certificate File and TLS Key File specified above.
This feature’s config.json setting is "UseLetsEncrypt": false with options true and false for above settings respectively. |
Let’s Encrypt Certificate Cache File¶
The path to the file where certificates and other data about the Let’s Encrypt service will be stored.
This feature’s config.json setting is "LetsEncryptCertificateCacheFile": "./config/letsencrypt.cache" with string input. |
Forward port 80 to 443¶
True: Forwards all insecure traffic from port 80 to secure port 443.
False: When using a proxy such as NGINX in front of Mattermost this setting is unnecessary and should be set to false.
This feature’s config.json setting is "Forward80To443": false with options true and false for above settings respectively. |
Read Timeout¶
Maximum time allowed from when the connection is accepted to when the request body is fully read.
This feature’s config.json setting is "ReadTimeout": 300 with string input |
Write Timeout¶
If using HTTP (insecure), this is the maximum time allowed from the end of reading the request headers until the response is written. If using HTTPS, it is the total time from when the connection is accepted until the response is written.
This feature’s config.json setting is "WriteTimeout": 300 with string input |
Webserver Mode¶
gzip compression applies to the HTML, CSS, Javascript, and other static content files that make up the Mattermost web client. It is recommended to enable gzip to improve performance unless your environment has specific restrictions, such as a web proxy that distributes gzip files poorly. This setting requires a server restart to take effect.
gzip: The Mattermost server will serve static files compressed with gzip to improve performance.
Uncompressed: The Mattermost server will serve static files uncompressed.
Disabled: The Mattermost server will not serve static files.
This feature’s config.json setting is "WebserverMode": "gzip" with options gzip , uncompressed and disabled for above settings respectively. |
Reload Configuration from Disk¶
Available in Enterprise Edition E20
This button resets the configuration settings by reloading the settings from the disk. The server will still need to be restarted if a setting requiring server restart was changed.
The workflow for failover without downing the server is to change the database line in the config.json file, click Reload Configuration from Disk then click Recycle Database Connections in the Advanced > Database section.
Localization¶
Default Server Language¶
Default language for system messages and logs. Changing this will require a server restart before taking effect.
This feature’s config.json setting is "DefaultServerLocale": "en" with options de , en , es , fr , ja , ko , nl , pt-br , zh_CN and zh_TW |
Default Client Language¶
Default language for newly created users and pages where the user hasn’t logged in.
This feature’s config.json setting is "DefaultClientLocale": "en" with options de , en , es , fr , ja , ko , nl , pt-br , zh_CN and zh_TW |
Available Languages¶
Sets which languages are available for users in Account Settings > Display > Languages. Leave the field blank to add new languages automatically by default, or add new languages using the dropdown menu manually as they become available. If you’re manually adding new languages, the Default Client Language must be added before saving the setting.
Note: Servers which upgraded to v3.1 need to manually set this field blank to have new languages added by default.
This feature’s config.json setting is "AvailableLocales": "" with options "" , de , en , es , fr , ja , ko , nl , pt-br , zh_CN and zh_TW |
Users and Teams¶
Enable Account Creation¶
True: Ability to create new accounts is enabled via inviting new members or sharing the team invite link.
False: Ability to create accounts is disabled. The Create Account button displays an error when trying to signup via an email invite or team invite link.
This feature’s config.json setting is "EnableUserCreation": true with options true and false for above settings respectively. |
Enable Team Creation¶
True: Ability to create a new team is enabled for all users.
False: Only System Administrators can create teams from the team selection page. The Create A New Team button is hidden in the main menu UI.
This feature’s config.json setting is "EnableTeamCreation": true with options true and false for above settings respectively. |
Max Users Per Team¶
Maximum number of users per team, including both active and inactive users.
This feature’s config.json setting is "MaxUsersPerTeam": 50 with whole number input. |
Max Channels Per Team¶
Maximum number of channels per team, including both active and deleted channels.
This feature’s config.json setting is "MaxChannelsPerTeam": 2000 with whole number input. |
Restrict account creation to specified email domains¶
Teams and user accounts can only be created by a verified email from this list of comma-separated domains (e.g. “corp.mattermost.com, mattermost.org”).
This feature’s config.json setting is "RestrictCreationToDomains": "" with string input. |
Restrict Team Names¶
Removed in November 16th, 2016 release
True: Newly created team names cannot contain the following restricted words: www, web, admin, support, notify, test, demo, mail, team, channel, internal, localhost, dockerhost, stag, post, cluster, api, oauth.
False: Newly created team names are not restricted.
This feature’s config.json setting is "RestrictTeamNames": true with options true and false for above settings respectively. |
Enable users to open Direct Message channels with¶
Any user on the Mattermost server: The Direct Messages “More” menu has the option to open a Direct Message channel with any user on the server.
Any member of the team: The Direct Messages “More” menu only has the option to open a Direct Message channel with users on the current team. If a user belongs to multiple teams, direct messages will still be received regardless of what team they are currently on.
This feature’s config.json setting is "RestrictDirectMessage": "any" with options any and team for above settings respectively. |
Enable Team Directory¶
Removed in May 16th, 2016 release
True: Teams that are configured to appear in the team directory will appear on the system main page. Teams can configure this setting from Team Settings > Include this team in the Team Directory.
False: Team directory on the system main page is disabled.
This feature’s config.json setting is "EnableTeamListing": false with options true and false for above settings respectively. |
Policy¶
Available in Enterprise Edition E10 and higher
Settings to configure the permission restrictions for sending team invite links and managing channels.
Enable sending team invites from:¶
Set policy on who can invite others to a team using “Invite New Member” to invite new users by email, or the “Get Team Invite Link” options from the main menu. If “Get Team Invite Link” is used to share a link, you can expire the invite code from Team Settings > Invite Code after the desired users joined the team. Options include:
All team members: Allows any team member to invite others using an email invitation or team invite link.
Team and System Admins: Hides the email invitation and team invite link in the Main Menu from users who are not Team Admins or System Admins.
System Admins: Hides the email invitation and team invite link in the Main Menu from users who are not System Admins.
This feature’s config.json setting is "RestrictTeamInvite": "all" with options all , team_admin and system_admin for above settings respectively. |
Enable public channel management permissions for¶
Restrict the permission levels required to create, delete, rename, and set the header or purpose for public channels. The last member of a public channel has the ability to delete the channel regardless of their permission level.
All team members: Channel management permissions for public channels are enabled for all users.
Team and System Admins: Channel management permissions for public channels are restricted to Team and System Admins.
System Admins: Channel management permissions for public channels are restricted to System Admins.
This feature’s config.json setting is "RestrictPublicChannelManagement": "all" with options all , team_admin and system_admin for above settings respectively. |
Enable private channel management permissions for¶
Restrict the permission levels required to to create, delete, rename, and set the header or purpose for private channels. The last member of a private channel has the ability to delete the channel regardless of their permission level.
All team members: Channel management permissions for private channels are enabled for all users.
Team and System Admins: Channel management permissions for private channels are restricted to Team and System Admins.
System Admins: Channel management permissions for private channels are restricted to System Admins.
This feature’s config.json setting is "RestrictPrivateChannelManagement": "all" with options all , team_admin and system_admin for above settings respectively. |
Privacy¶
Settings to configure the name and email privacy of users on your system.
Show Email Address¶
True: Show email address of all users.
False: Hide email address of users from other users in the user interface, including Team Admins. This is designed for managing teams where users choose to keep their contact information private. System Administrators will still be able to see email addresses in the UI.
This feature’s config.json setting is "ShowEmailAddress": true with options true and false for above settings respectively. |
Show Full Name¶
True: Show full name of all users.
False: hide full name of users from other users including Team Admins. This is designed for managing teams where users choose to keep their contact information private. System Administrators will still be able to see full names in the UI.
This feature’s config.json setting is "ShowFullName": true with options true and false for above settings respectively. |
Compliance¶
Available in Enterprise Edition E20
Settings used to enable and configure Mattermost compliance reports.
Enable Compliance Reporting¶
True: Compliance reporting is enabled in Mattermost.
False: Compliance reporting is disabled.
This feature’s config.json setting is "Enable": false with options true and false for above settings respectively. |
Compliance Report Directory¶
Sets the directory where compliance reports are written.
This feature’s config.json setting is "Directory": "./data/" with string input. |
Enable Daily Report¶
True: Mattermost generates a daily compliance report.
False: Daily reports are not generated.
This feature’s config.json setting is "EnableDaily": false with options true and false for above settings respectively. |
Logging¶
Output logs to console¶
True: Output log messages to the console based on ConsoleLevel option. The server writes messages to the standard output stream (stdout).
False: Output log messages are not written to the console.
This feature’s config.json setting is "EnableConsole": true with options true and false for above settings respectively. |
Console Log Level¶
Level of detail at which log events are written to the console when EnableConsole = true
.
DEBUG: Prints high detail for developers debugging issues.
ERROR: Outputs only error messages.
INFO: Outputs error messages and information around startup and initialization.
This feature’s config.json setting is "ConsoleLevel": "DEBUG" with options DEBUG , ERROR and INFO for above settings respectively. |
Output logs to file¶
True: Log files are written to files specified in FileLocation.
False: Log files are not written.
This feature’s config.json setting is "EnableFile": true with options true and false for above settings respectively. |
File Log Level¶
Level of detail at which log events are written to log files when EnableFile = true
.
ERROR: Outputs only error messages.
INFO: Outputs error messages and information around startup and initialization.
DEBUG: Prints high detail for developers debugging issues.
This feature’s config.json setting is "FileLevel": "INFO" with options DEBUG , ERROR and INFO for above settings respectively. |
File Log Directory¶
Directory to which log files are written. If blank, log files write to ./logs/mattermost/mattermost.log. Log rotation is enabled and every 10,000 lines of log information is written to new files stored in the same directory, for example mattermost.2015-09-23.001, mattermost.2015-09-23.002, and so forth.
This feature’s config.json setting is "FileLocation": "" with string input. |
File Log Format¶
Format of log message output. If blank, FileFormat = “[%D %T] [%L] (%S) %M”, where:
%T | Time (15:04:05 MST) |
%t | Time (15:04) |
%D | Date (2006/01/02) |
%d | Date (01/02/06) |
%L | Level (FNST, FINE, DEBG, TRAC, WARN, EROR, CRIT) |
%S | Source |
%M | Message |
This feature’s config.json setting is "FileFormat": "" with string input. |
Enable Webhook Debugging¶
True: Contents of incoming webhooks are printed to log files for debugging.
False: Contents of incoming webhooks are not printed to log files.
This feature’s config.json setting is "EnableWebhookDebugging": true with options true and false for above settings respectively. |
Enable Diagnostics and Error Reporting¶
True: To improve the quality and performance of Mattermost, you may send error reporting and diagnostic information to Mattermost, Inc. Read our privacy policy to learn more.
False: Diagnostics and error reporting are disabled.
This feature’s config.json setting is "EnableDiagnostics": true with options true and false for above settings respectively. |
Authentication¶
Authentication settings to enable account creation and sign in with email, GitLab, Google or Office 365 OAuth, AD/LDAP, or SAML.
Email Auth¶
Enable account creation with email¶
True: Allow team creation and account signup using email and password.
False: Email signup is disabled and users are not able to invite new members. This limits signup to single-sign-on services like OAuth or AD/LDAP.
This feature’s config.json setting is "EnableSignUpWithEmail": true with options true and false for above settings respectively. |
Enable sign-in with email¶
True: Mattermost allows users to sign in using their email and password.
False: sign in with email is disabled and does not appear on the login screen.
This feature’s config.json setting is "EnableSignInWithEmail": true with options true and false for above settings respectively. |
Enable sign-in with username¶
True: Mattermost allows users to sign in using their username and password. This setting is typically only used when email verification is disabled.
False: sign in with username is disabled and does not appear on the login screen.
This feature’s config.json setting is EnableSignInWithUsername": false with options true and false for above settings respectively. |
OAuth 2.0¶
Available in Enterprise Edition E10 and higher
Settings to configure OAuth login for account creation and login.
Select OAuth 2.0 service provider:¶
Choose whether OAuth can be used for account creation and login. Options include:
- Do not allow sign-in via an OAuth 2.0 provider
- GitLab (see GitLab Settings for more detail)
- Google Apps (see Google Settings for more detail)
- Office 365 (Beta) (see Office 365 Settings for more detail)
This feature’s setting does not appear in config.json
.
GitLab¶
Enable authentication with GitLab¶
True: Allow team creation and account signup using GitLab OAuth. To configure, input the Secret and Id credentials.
False: GitLab OAuth cannot be used for team creation or account signup.
This feature’s config.json setting is "Enable": false with options true and false for above settings respectively. |
Note: For Enterprise, GitLab settigs can be found under OAuth 2.0
Application ID¶
Obtain this value by logging into your GitLab account. Go to Profile Settings > Applications > New Application, enter a Name, then enter Redirect URLs https://<your-mattermost-url>/login/gitlab/complete
(example: https://example.com:8065/login/gitlab/complete``and ``https://<your-mattermost-url>/signup/gitlab/complete
.
This feature’s config.json setting is "Id": "" with string input. |
Application Secret Key¶
Obtain this value by logging into your GitLab account. Go to Profile Settings > Applications > New Application, enter a Name, then enter Redirect URLs https://<your-mattermost-url>/login/gitlab/complete
(example: https://example.com:8065/login/gitlab/complete``and ``https://<your-mattermost-url>/signup/gitlab/complete
.
This feature’s config.json setting is "Secret": "" with string input. |
User API Endpoint¶
Enter https://<your-gitlab-url>/api/v3/user
(example: https://example.com:3000/api/v3/user
). Use HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "UserApiEndpoint": "" with string input. |
Auth Endpoint¶
Enter https://<your-gitlab-url>/oauth/authorize
(example: https://example.com:3000/oauth/authorize
). Use HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "AuthEndpoint": "" with string input. |
Token Endpoint¶
Enter https://<your-gitlab-url>/oauth/token
(example: https://example.com:3000/oauth/token
). Use HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "TokenEndpoint": "" with string input. |
Google¶
Available in Enterprise Edition E20
Enable authentication with Google by selecting Google Apps
from OAuth 2.0 > Select OAuth 2.0 service provider
True: Allow team creation and account signup using Google OAuth. To configure, input the Client ID and Client Secret credentials. See Documentation for more detail.
False: Google OAuth cannot be used for team creation or account signup.
This feature’s config.json setting is "Enable": false with options true and false for above settings respectively. |
Client ID¶
Obtain this value by registering Mattermost as an application in your Google account.
This feature’s config.json setting is "Id": "" with string input. |
Client Secret¶
Obtain this value by registering Mattermost as an application in your Google account.
This feature’s config.json setting is "Secret": "" with string input. |
User API Endpoint¶
It is recommended to use https://www.googleapis.com/plus/v1/people/me as the User API Endpoint. Otherwise, enter a custom endpoint in config.json with HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "UserApiEndpoint": "https://www.googleapis.com/plus/v1/people/me" with string input. |
Auth Endpoint¶
It is recommended to use https://accounts.google.com/o/oauth2/v2/auth as the Auth Endpoint. Otherwise, enter a custom endpoint in config.json with HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "AuthEndpoint": "https://accounts.google.com/o/oauth2/v2/auth" with string input. |
Token Endpoint¶
It is recommended to use https://www.googleapis.com/oauth2/v4/token as the Token Endpoint. Otherwise, enter a custom endpoint in config.json with HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "TokenEndpoint": "https://www.googleapis.com/oauth2/v4/token" with string input. |
Office 365¶
Available in Enterprise Edition E20
Enable authentication with Office 365 by selecting Office 365 (Beta)
from OAuth 2.0 > Select OAuth 2.0 service provider
True: Allow team creation and account signup using Office 365 OAuth. To configure, input the Application ID and Application Secret Password credentials. See Documentation for more detail.
False: Office 365 OAuth cannot be used for team creation or account signup.
This feature’s config.json setting is "Enable": false with options true and false for above settings respectively. |
Application ID¶
Obtain this value by registering Mattermost as an application in your Microsoft or Office account.
This feature’s config.json setting is "Id": "" with string input. |
Application Secret Password¶
Obtain this value by registering Mattermost as an application in your Microsoft or Office account.
This feature’s config.json setting is "Secret": "" with string input. |
User API Endpoint¶
It is recommended to use https://graph.microsoft.com/v1.0/me as the User API Endpoint. Otherwise, enter a custom endpoint in config.json with HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "UserApiEndpoint": "https://graph.microsoft.com/v1.0/me" with string input. |
Auth Endpoint¶
It is recommended to use https://accounts.google.com/o/oauth2/v2/auth as the Auth Endpoint. Otherwise, enter a custom endpoint in config.json with HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "AuthEndpoint": "https://login.microsoftonline.com/common/oauth2/v2.0/authorize" with string input. |
Token Endpoint¶
It is recommended to use https://login.microsoftonline.com/common/oauth2/v2.0/token as the Token Endpoint. Otherwise, enter a custom endpoint in config.json with HTTP or HTTPS depending on how your server is configured.
This feature’s config.json setting is "TokenEndpoint": "https://login.microsoftonline.com/common/oauth2/v2.0/token" with string input. |
AD/LDAP¶
Available in Enterprise Edition E10 and higher
Enable sign-in with AD/LDAP¶
True: Mattermost allows login using AD/LDAP or Active Directory.
False: Login with AD/LDAP is disabled.
This feature’s config.json setting is "Enable": false with options true and false for above settings respectively. |
AD/LDAP Server¶
The domain or IP address of the AD/LDAP server.
This feature’s config.json setting is "LdapServer": "" with string input. |
AD/LDAP Port¶
The port Mattermost will use to connect to the AD/LDAP server. Default is 389.
This feature’s config.json setting is "LdapPort": 389 with numerical input. |
Connection Security¶
The type of connection security Mattermost uses to connect to AD/LDAP.
None: No encryption, Mattermost will not attempt to establish an encrypted connection to the AD/LDAP server.
TLS: Encrypts the communication between Mattermost and your server using TLS.
STARTTLS: Takes an existing insecure connection and attempts to upgrade it to a secure connection using TLS.
If the “No encryption” option is selected it is highly recommended that the AD/LDAP connection is secured outside of Mattermost, for example, by adding a stunnel proxy.
This feature’s config.json setting is "ConnectionSecurity": "" with options "" , TLS and STARTTLS for above settings respectively. |
Skip Certificate Verification¶
(Optional) The attribute in the AD/LDAP server that will be used to populate the nickname of users in Mattermost.
True: Skips the certificate verification step for TLS or STARTTLS connections. Not recommended for production environments where TLS is required. For testing only.
False: Mattermost does not skip certificate verification.
This feature’s config.json setting is "SkipCertificateVerification": false with options true and false for above settings respectively. |
Base DN¶
The Base Distinguished Name of the location where Mattermost should start its search for users in the AD/LDAP tree.
This feature’s config.json setting is "BaseDN": "" with string input. |
Bind Username¶
The username used to perform the AD/LDAP search. This should be an account created specifically for use with Mattermost Its permissions should be limited to read-only access to the portion of the AD/LDAP tree specified in the Base DN field. When using Active Directory, Bind Username should specify domain in DOMAIN/username
format. This field is required, and anonymous bind is not currently supported.
This feature’s config.json setting is "BindUsername": "" with string input. |
Bind Password¶
Password of the user given in Bind Username. This field is required, and anonymous bind is not currently supported.
This feature’s config.json setting is "BindPassword": "" with string input. |
User Filter¶
(Optional) Enter an AD/LDAP Filter to use when searching for user objects (accepts general syntax). Only the users selected by the query will be able to access Mattermost. For Active Directory, the query to filter out disabled users is (&(objectCategory=Person)(!(UserAccountControl:1.2.840.113556.1.4.803:=2)))
This filter uses the permissions of the Bind Username account to execute the search. Administrators should make sure to use a specially created account for Bind Username with read-only access to the portion of the AD/LDAP tree specified in the Base DN field.
This feature’s config.json setting is "UserFilter": "" with string input. |
First Name Attribute¶
(Optional) The attribute in the AD/LDAP server that will be used to populate the first name of users in Mattermost. When set, users will not be able to edit their First Name, since it is synchronized with the LDAP server. When left blank, users can set their own First Name in Account Settings.
This feature’s config.json setting is "FirstNameAttribute": "" with string input. |
Last Name Attribute¶
(Optional) The attribute in the AD/LDAP server that will be used to populate the last name of users in Mattermost. When set, users will not be able to edit their Last Name, since it is synchronized with the LDAP server. When left blank, users can set their own Last Name in Account Settings.
This feature’s config.json setting is "LastNameAttribute": "" with string input. |
Nickname Attribute¶
(Optional) The attribute in the AD/LDAP server that will be used to populate the nickname of users in Mattermost. When set, users will not be able to edit their Nickname, since it is synchronized with the LDAP server. When left blank, users can set their own Nickname in Account Settings.
This feature’s config.json setting is "NicknameAttribute": "" with string input. |
Email Attribute¶
The attribute in the AD/LDAP server that will be used to populate the email addresses of users in Mattermost.
Email notifications will be sent to this email address, and this email address may be viewable by other Mattermost users depending on privacy settings choosen by the System Admin.
This feature’s config.json setting is "EmailAttribute": "" with string input. |
Username Attribute¶
The attribute in the AD/LDAP server that will be used to populate the username field in Mattermost user interface. This attribute will be used within the Mattermost user interface to identify and mention users. For example, if a Username Attribute is set to john.smith a user typing @john
will see @john.smith
in their auto-complete options and posting a message with @john.smith
will send a notification to that user that they’ve been mentioned.
The Username Attribute may be set to the same value used to sign-in to the system, called an ID Attribute, or it can be mapped to a different value.
This feature’s config.json setting is "UsernameAttribute": "" with string input. |
ID Attribute¶
The attribute in the AD/LDAP server that will be used as a unique identifier in Mattermost. It serves two purposes:
This value is used to sign in to Mattermost in the AD/LDAP Username field on the sign in page. This attribute can be the same as the Username Attribute field above, which is what is used to identify users in the Mattermost interface, or it can be a different value, for example a User ID number. If your team typically uses DOMAIN\username
to sign in to other services with AD/LDAP, you may enter a field name that maps to DOMAIN\username
to maintain consistency between sites.
This is the attribute that will be used to create unique Mattermost accounts. This attribute should be an AD/LDAP attribute with a value that does not change, such as username
or uid
. If a user’s ID Attribute changes and the user attempts to login the Mattermost server will attempt to create a new Mattermost user account based on the new ID Attribute and fail since new Mattermost users accounts can’t be created with duplicate email addresses or Mattermost usernames (as defined in the Username Attribute).
This feature’s config.json setting is "IdAttribute": "" with string input. |
Login Field Name¶
The placeholder text that appears in the login field on the login page. Typically this would be whatever name is used to refer to AD/LDAP credentials in your company, so it is recognizable to your users. Defaults to AD/LDAP Username.
This feature’s config.json setting is "LoginFieldName": "" with string input. |
Synchronization Interval (minutes)¶
Set how often Mattermost accounts synchronize attributes with AD/LDAP, in minutes. When synchronizing, Mattermost queries AD/LDAP for relevant account information and updates Mattermost accounts based on changes to attributes (first name, last name, and nickname). When accounts are disabled in AD/LDAP users are made inactive in Mattermost, and their active sessions are revoked once Mattermost synchronizes attributes. To synchronize immediately after disabling an account, use the “AD/LDAP Synchronize Now” button.
This feature’s config.json setting is "SyncIntervalMinutes": 60 with whole number input. |
Maximum Page Size¶
The maximum number of users the Mattermost server will request from the AD/LDAP server at one time. Use this setting if your AD/LDAP server limits the number of users that can be requested at once. 0 is unlimited.
This feature’s config.json setting is "MaxPageSize": 0 with whole number input. |
Query Timeout (seconds)¶
The timeout value for queries to the AD/LDAP server. Increase this value if you are getting timeout errors caused by a slow AD/LDAP server.
This feature’s config.json setting is "QueryTimeout": 60 with whole number input. |
AD/LDAP Synchronize Now¶
This button causes AD/LDAP synchronization to occur as soon as it is pressed. Use it whenever you have made a change in the AD/LDAP server you want to take effect immediately. After using the button, the next AD/LDAP synchronization will occur after the time specified by the Synchronization Interval.
AD/LDAP Test¶
This button can be used to test the connection to the AD/LDAP server. If the test us successful, it shows a confirmation message and if there is a problem with the configuration settings it will show an error message.
SAML¶
Available in Enterprise Edition E20
Enable Login With SAML¶
True: Mattermost allows login using SAML. Please see documentation to learn more about configuring SAML for Mattermost.
False: Login with SAML is disabled.
This feature’s config.json setting is "Enable": false with options true and false for above settings respectively. |
SAML SSO URL¶
The URL where Mattermost sends a SAML request to start login sequence.
This feature’s config.json setting is "IdpURL": "" with string input. |
Identity Provider Issuer URL¶
The issuer URL for the Identity Provider you use for SAML requests.
This feature’s config.json setting is "IdpDescriptorUrl": "" with string input. |
Identity Provider Public Certificate¶
The public authentication certificate issued by your Identity Provider.
This feature’s config.json setting is "IdpCertificateFile": "" with string input. |
Verify Signature¶
true
: When true, Mattermost verifies that the signature sent from the SAML Response matches the Service Provider Login URL.
This feature’s config.json setting is "Verify": false with string input. |
Service Provider Login URL¶
Enter https://<your-mattermost-url>/login/sso/saml
(example: https://example.com/login/sso/saml
). Make sure you use HTTP or HTTPS in your URL depending on your server configuration. This field is also known as the Assertion Consumer Service URL.
This feature’s config.json setting is "AssertionConsumerServiceURL": "" with string input. |
Enable Encryption¶
True: Mattermost will decrypt SAML Assertions encrypted with your Service Provider Public Certificate.
False: Encyption is disabled.
This feature’s config.json setting is "Encrypt": false with options true and false for above settings respectively. |
Service Provider Private Key¶
The private key used to decrypt SAML Assertions from the Identity Provider.
This feature’s config.json setting is "PrivateKeyFile": "" with string input. |
Service Provider Public Certificate¶
The certificate file used to generate the signature on a SAML request to the Identity Provider for a service provider initiated SAML login, when Mattermost is the Service Provider.
This feature’s config.json setting is "PublicCertificateFile": "" with string input. |
Email Attribute¶
The attribute in the SAML Assertion that will be used to populate the email addresses of users in Mattermost.
Email notifications will be sent to this email address, and this email address may be viewable by other Mattermost users depending on privacy settings choosen by the System Admin.
This feature’s config.json setting is "EmailAttribute": "" with string input. |
Username Attribute¶
The attribute in the SAML Assertion that will be used to populate the username field in Mattermost user interface. This attribute will be used within the Mattermost user interface to identify and mention users. For example, if a Username Attribute is set to john.smith a user typing @john
will see @john.smith
in their auto-complete options and posting a message with @john.smith
will send a notification to that user that they’ve been mentioned.
This feature’s config.json setting is "UsernameAttribute": "" with string input. |
First Name Attribute¶
(Optional) The attribute in the SAML Assertion that will be used to populate the first name of users in Mattermost.
This feature’s config.json setting is "FirstNameAttribute": "" with string input. |
Last Name Attribute¶
(Optional) The attribute in the SAML Assertion that will be used to populate the last name of users in Mattermost.
This feature’s config.json setting is "LastNameAttribute": "" with string input. |
Nickname Attribute¶
(Optional) The attribute in the SAML Assertion that will be used to populate the nickname of users in Mattermost.
This feature’s config.json setting is "NicknameAttribute": "" with string input. |
Preferred Language Attribute¶
(Optional) The attribute in the SAML Assertion that will be used to populate the language of users in Mattermost.
This feature’s config.json setting is "LocaleAttribute": "" with string input. |
Login Button Text¶
(Optional) The text that appears in the login button on the login page. Defaults to With SAML
.
This feature’s config.json setting is "LoginButtonText": "" with string input. |
Security¶
Configure security settings for account creation, login, public links and connection requests.
Sign Up¶
Require Email Verification¶
True: Require email verification after account creation prior to allowing login.
False: Users do not need to verify their email address prior to login. Developers may set this field to false so skip sending verification emails for faster development.
This feature’s config.json setting is "RequireEmailVerification": false with options true and false for above settings respectively. |
Email Invite Salt¶
32-character (to be randomly generated via System Console) salt added to signing of email invites. Click Regenerate to create new salt.
This feature’s config.json setting is "InviteSalt": "" with string input. |
Enable Open Server¶
True: Users can sign up to the server from the root page without an invite.
False: Users can only sign up to the server if they receive an invite.
This feature’s config.json setting is "EnableOpenServer": false with options true and false for above settings respectively. |
Password¶
Minimum Password Length¶
Available in Enterprise Edition E10 and higher
Minimum number of characters required for a valid password. Must be a whole number greater than or equal to 5 and less than or equal to 64.
This feature’s config.json setting is "MinimumLength": 5" with whole number input. |
Password Requirements¶
Available in Enterprise Edition E10 and higher
Set the required character types to be included in a valid password. Defaults to allow any characters unless otherwise specified by the checkboxes. The error messasage previewed in the System Console will appear on the account creation page if a user enters an invalid password.
- At least one lowercase letter: Select this checkbox if a valid password must contain at least one lowercase letter.
- At least one uppercase letter: Select this checkbox if a valid password must contain at least one uppercase letter.
- At least one number: Select this checkbox if a valid password must contain at least one number.
- At least one symbol: Select this checkbox if a valid password must contain at least one symbol. Valid symbols include:
!"#$%&'()*+,-./:;<=>?@[]^_`|~
This feature’s config.json
settings are, respectively:
"Lowercase": false with options true and false |
"Number": false with options true and false |
"Uppercase": false with options true and false |
"Symbol": false with options true and false |
Password Reset Salt¶
32-character (to be randomly generated via Admin Console) salt added to signing of password reset emails. Click Regenerate to create new salt.
This feature’s config.json setting is "PasswordResetSalt": "" with string input. |
Maximum Login Attempts¶
Failed login attempts allowed before a user is locked out and required to reset their password via email.
This feature’s config.json setting is "MaximumLoginAttempts": 10 with whole number input. |
Enable Multi-factor Authentication¶
Available in Enterprise Edition E10 and higher
The default recommendation for secure deployment is to host Mattermost within your own private network, with VPN clients on mobile, so everything works under your existing security policies and authentication protocols, which may already include multi-factor authentication.
If you choose to run Mattermost outside your private network, bypassing your existing security protocols, it is recommended you upgrade to Mattermost Enterprise Edition to set up a multi-factor authentication service specifically for accessing Mattermost.
True: When true, users will be given the option to require a phone-based passcode, in addition to their password-based authentication, to sign-in to the Mattermost server. Specifically, they will be asked to download the Google Authenticator app to their iOS or Android mobile device, connect the app with their account, and then enter a passcode generated by the app on their phone whenever they log in to the Mattermost server.
False: Multi-factor authentication is disabled.
This feature’s config.json setting is "EnableMultifactorAuthentication": true with options true and false for above settings respectively. |
Public Links¶
Enable Public File Links¶
True: Allow users to generate public links to files and images for sharing outside the Mattermost system with a public URL.
False: The Get Public Link option is hidden from the image preview user interface.
Note: When switched to False, anyone who tries to visit a previously generated public link will receive an error message saying public links have been disabled. When switched back to True, old public links will work again unless the Public Link Salt has been regenerated.
This feature’s config.json setting is "EnablePublicLink": true with options true and false for above settings respectively. |
Public Link Salt¶
32-character salt added to the URL of public links when public links are enabled. Click Regenerate in the System Console to create a new salt, which will invalidate all existing public links.
This feature’s config.json setting is "PublicLinkSalt": "" with string input. |
Sessions¶
Session length for email and AD/LDAP authentication (days)¶
Set the number of days before web sessions expire and users will need to log in again.
This feature’s config.json setting is "SessionLengthWebInDays" : 30 with whole number input. |
Session length for mobile apps (days)¶
Set the number of days before native mobile sessions expire.
This feature’s config.json setting is "SessionLengthMobileInDays" : 30 with whole number input. |
Session length for GitLab SSO authentication (days)¶
Set the number of days before SSO sessions expire.
This feature’s config.json setting is "SessionLengthSSOInDays" : 30 with whole number input. |
Session Cache (minutes)¶
Set the number of minutes to cache a session in memory.
This feature’s config.json setting is "SessionCacheInMinutes" : 10 with whole number input. |
Connections¶
Enable cross-origin requests from¶
Enable HTTP cross-origin requests from specific domains separated by spaces. Type *
to allow CORS from any domain or leave it blank to disable it.
This feature’s config.json setting is "AllowCorsFrom": "" with string input. |
Enable Insecure Outgoing Connections¶
True: Outgoing HTTPS requests can accept unverified, self-signed certificates. For example, outgoing webhooks to a server with a self-signed TLS certificate, using any domain, will be allowed.
False: Only secure HTTPS requests are allowed.
Security note: Enabling this feature makes these connections susceptible to man-in-the-middle attacks.
This feature’s config.json setting is "EnableInsecureOutgoingConnections": false with options true and false for above settings respectively. |
Notifications¶
Settings to configure email and mobile push notifications.
Email¶
Enable Email Notifications¶
True: Enables sending of email notifications.
False: Disables email notifications for developers who may want to skip email setup for faster development. Setting this to true removes the Preview Mode: Email notifications have not been configured banner (requires logging out and logging back in after setting is changed)
This feature’s config.json setting is "SendEmailNotifications": false with options true and false for above settings respectively. |
Enable Email Batching¶
True: Users can select how often to receive email notifications, and multiple notifications within that timeframe will be combined into a single email, configurable in Account Settings > Notifications. Note: Email batching cannot be enabled unless the SiteURL is configured and High Availability is disabled.
False: If email notifications are enabled in Account Settings, emails will be sent individually for every mention or direct message received.
This feature’s config.json setting is "EnableEmailBatching": false with options true and false for above settings respectively. |
Notification Display Name¶
Name displayed on email account used when sending notification emails from Mattermost system.
This feature’s config.json setting is "FeedbackName": "" with string input. |
Notification From Address¶
Address displayed on email account used when sending notification emails from Mattermost system.
So you don’t miss messages, please make sure to change this value to an email your system administrator receives, example: admin@yourcompany.com.
This feature’s config.json setting is "FeedbackEmail": "" with string input. |
SMTP Server Username¶
Obtain this credential from the administrator setting up your email server.
This feature’s config.json setting is "SMTPUsername": "" with string input. |
SMTP Server Password¶
Obtain this credential from the administrator setting up your email server.
This feature’s config.json setting is "SMTPPassword": "" with string input. |
SMTP Server¶
Location of SMTP email server.
This feature’s config.json setting is "SMTPServer": "" with string input. |
SMTP Server Port¶
Port of SMTP email server.
This feature’s config.json setting is "SMTPPort": "" with string input. |
Connection Security¶
""
: Send email over an unsecure connection.
PLAIN
: Mattermost will connect and authenticate over an unsecure connection.
TLS
: Communication between Mattermost and your email server is encrypted.
STARTTLS
: Attempts to upgrade an existing insecure connection to a secure connection using TLS.
This feature’s config.json setting is "ConnectionSecurity": "" with options "" , PLAIN , TLS and STARTTLS for above settings respectively. |
Enable Security Alerts¶
True: System Admins are notified by email if a relevant security fix alert has been announced in the last 12 hours. Requires email to be enabled.
False: Security alerts are disabled.
This feature’s config.json setting is "EnableSecurityFixAlert": true with options true and false for above settings respectively. |
Mobile Push¶
Enable Push Notifications¶
True: Your Mattermost server sends mobile push notifications to the server specified in PushNotificationServer.
False: Mobile push notifications are disabled.
This feature’s config.json setting is "SendPushNotifications": false with options true and false for above settings respectively. |
Push Notification Server¶
Location of Mattermost Push Notification Service (MPNS), which re-sends push notifications from Mattermost to services like Apple Push Notification Service (APNS) and Google Cloud Messaging (GCM).
To confirm push notifications are working, connect to the Mattermost iOS App on iTunes or the Mattermost Android App on Google Play:
- For Enterprise Edition, enter
http://push.mattermost.com
- For Team Edition, enter
http://push-test.mattermost.com
Please review full documentation on push Notifications and mobile applications including guidance on compiling your own mobile apps and MPNS before deploying to production.
Note: The http://push-test.mattermost.com
provided for testing push notifications prior to compiling your own service please make sure to read about its limitations.
This feature’s config.json setting is "PushNotificationServer": "" with string input. |
Push Notification Contents¶
Send generic description with user and channel names: Selecting “Send generic description with user and channel names” provides push notifications with generic messages, including names of users and channels but no specific details from the message text.
Send full message snippet: Selecting “Send full message snippet” sends excerpts from messages triggering notifications with specifics and may include confidential information sent in messages. If your Push Notification Service is outside your firewall, it is HIGHLY RECOMMENDED this option only be used with an “https” protocol to encrypt the connection.
This feature’s config.json setting is "PushNotificationContents": "generic" with options generic and full for above settings respectively. |
Troubleshooting Push Notifications
To confirm push notifications are working:
- Set System Console > Email Settings > Send Push Notifications to true.
- Set System Console > Email Settings > Send Push Notifications to true (if using Mattermost 1.4 or earlier).
- Set System Console > Email Settings > Push Notification Server to
http://push.mattermost.com
if using Enterprise Edition or if using Team Edition, set the value to http://push-test.mattermost.com. - Download and install the Mattermost iOS app from iTunes on your iPhone or iPad and log in to your team site.
- Close the app on your device, and close any other connections to your team site.
- Wait 5 minutes and have another team member send you a direct messages, which should trigger a push notification to the Mattermost app on your mobile device.
- You should receive a push notification on your device alerting you of the direct message.
If you did not receive an alert:
- Set System Console > Log Settings > File Log Level to DEBUG (make sure to set this back to INFO after troubleshooting to save disk space).
- Repeat the above steps
- Go to System Console > OTHER > Logs and copy the log output into a file
- For Enterprise Edition customers, submit a support request with the file attached. For Team Edition users, please start a thread in the Troubleshooting forum for peer-to-peer support.
Integrations¶
Settings to configure webhooks, slash commands and external integration services.
Custom Integrations¶
Enable Incoming Webhooks¶
Developers building integrations can create webhook URLs for channels and private groups. Please see our documentation page to learn about creating webhooks, view samples, and to let the community know about integrations you have built.
True: Incoming webhooks will be allowed. To manage incoming webhooks, go to Account Settings > Integrations. The webhook URLs created in Account Settings can be used by external applications to create posts in any channels or private groups that you have access to.
False: The Integrations > Incoming Webhooks section of Account Settings is hidden and all incoming webhooks are disabled.
Security note: By enabling this feature, users may be able to perform phishing attacks by attempting to impersonate other users. To combat these attacks, a BOT tag appears next to all posts from a webhook. Enable at your own risk.
This feature’s config.json setting is "EnableIncomingWebhooks": true with options true and false for above settings respectively. |
Enable Outgoing Webhooks¶
Developers building integrations can create webhook tokens for public channels. Trigger words are used to fire new message events to external integrations. For security reasons, outgoing webhooks are only available in public channels. Please see our documentation page to learn about creating webhooks and view samples.
True: Outgoing webhooks will be allowed. To manage outgoing webhooks, go to Account Settings > Integrations.
False: The Integrations > Outgoing Webhooks section of Account Settings is hidden and all outgoing webhooks are disabled.
Security note: By enabling this feature, users may be able to perform phishing attacks by attempting to impersonate other users. To combat these attacks, a BOT tag appears next to all posts from a webhook. Enable at your own risk.
This feature’s config.json setting is "EnableOutgoingWebhooks": true with options true and false for above settings respectively. |
Enable Custom Slash Commands¶
Slash commands send events to external integrations that send a response back to Mattermost.
True: Allow users to create custom slash commands from Main Menu > Integrations > Commands.
False: Slash Commands are hidden in the Integrations user interface.
This feature’s config.json setting is "EnableCommands": false with options true and false for above settings respectively. |
Enable OAuth 2.0 Service Provider¶
True: Mattermost acts as an OAuth 2.0 service provider allowing Mattermost to authorize API requests from external applications.
False: Mattermost does not function as an OAuth 2.0 service provider.
This feature’s config.json setting is "EnableOAuthServiceProvider": false with options true and false for above settings respectively. |
Restrict managing integrations to Admins¶
True: When true, webhooks and slash commands can only be created, edited and viewed by Team and System Admins, and OAuth 2.0 applications by System Admins. Integrations are available to all users after they have been created by the Admin.
False: Any team members can create webhooks, slash commands and OAuth 2.0 applications from Main Menu > Integrations.
Note: OAuth 2.0 applications can be authorized by all users if they have the Client ID and Client Secret for an app setup on the server.
This feature’s config.json setting is "EnableOnlyAdminIntegrations": true with options true and false for above settings respectively. |
Enable integrations to override usernames¶
True: Webhooks, slash commands and other integrations, such as Zapier, will be allowed to change the username they are posting as.
False: Webhooks, slash commands and OAuth 2.0 apps can only post as the username of the account they were set up with. See http://mattermost.org/webhooks for more details.
This feature’s config.json setting is "EnablePostUsernameOverride": false with options true and false for above settings respectively. |
Enable integrations to override profile picture icons¶
True: Webhooks, slash commands and other integrations, such as Zapier, will be allowed to change the profile picture they post with.
False: Webhooks, slash commands and OAuth 2.0 apps can only post with the profile picture of the account they were set up with. See http://mattermost.org/webhooks for more details.
This feature’s config.json setting is "EnablePostIconOverride": false with options true and false for above settings respectively. |
WebRTC (Beta)¶
Enable Mattermost WebRTC¶
True: Mattermost will allow making one-on-one video calls on Chrome, Firefox and Mattermost Desktop Apps on a server running in SSL mode.
False: Mattermost doesn’t allow one-on-one video calls.
Note: To enable the Mattermost WebRTC service, the System Administrator agrees to the Terms of Service and Privacy Policy.
This feature’s config.json setting is "Enable": false with options true and false for above settings respectively. |
Gateway Websocket URL¶
This is the websocket used to signal and establish communication between the peers. Enter wss://<mattermost-webrtc-gateway-url>:<port>
. Make sure you use WS or WSS in your URL depending on your server configuration.
This feature’s config.json setting is "GatewayWebsocketUrl": "" with string input |
Gateway Admin URL¶
Mattermost WebRTC uses this URL to obtain valid tokens for each peer to establish the connection. Enter https://<mattermost-webrtc-gateway-url>:<port>/admin
. Make sure you use HTTP or HTTPS in your URL depending on your server configuration.
This feature’s config.json setting is "GatewayAdminUrl": "" with string input |
Gateway Admin Secret¶
Enter your admin secret password to access the Gateway Admin URL.
This feature’s config.json setting is "GatewayAdminSecret": "" with string input |
STUN URI¶
Enter your STUN URI as stun:<your-stun-url>:<port>
. STUN is a standardized network protocol to allow an end host to assist devices to access its public IP address if it is located behind a NAT.
This feature’s config.json setting is "StunURI": "" with string input |
TURN URI¶
Enter your TURN URI as turn:<your-turn-url>:<port>
. TURN is a standardized network protocol to allow an end host to assist devices to establish a connection by using a relay public IP address if it is located behind a symmetric NAT.
This feature’s config.json setting is "TurnURI": "" with string input |
TURN Username¶
Enter your TURN Server Username.
This feature’s config.json setting is "TurnUsername": "" with string input |
External Services¶
Google API Key¶
Mattermost offers the ability to embed YouTube videos from URLs shared by end users. Set this key to enable the display of titles for embedded YouTube video previews. Without the key, YouTube previews will still be created based on hyperlinks appearing in messages or comments but they will not show the video title. If Google detects the number of views is exceedingly high, they may throttle embed access. Should this occur, you can remove the throttle by registering for a Google Developer Key and entering it in this field following these instructions: https://www.youtube.com/watch?v=Im69kzhpR3I. Your Google Developer Key is used in client-side Javascript.
Using a Google API Key allows Mattermost to detect when a video is no longer available and display the post with a Video not found label.
This feature’s config.json setting is "GoogleDeveloperKey": "" with string input. |
Files¶
Settings to configure files storage and image handling.
Storage¶
File Storage System¶
Storage system where files and image attachments are saved.
Local File System: Files and images are stored in the specified local file directory.
Amazon S3: Files and images are stored on Amazon S3 based on the provided access key, bucket and region fields. The amazons3
driver is compatible with Minio (Beta) based on the provided access key, bucket and region fields.
This feature’s config.json setting is "DriverName": "local" with options local and amazons3 for above settings respectively. |
Local Storage Directory¶
Directory to which files are written. If blank, directory will be set to ./data/.
This feature’s config.json setting is "Directory": "./data/" with string input. |
Amazon S3 Access Key ID¶
Obtain this credential from your Amazon AWS administrator.
This feature’s config.json setting is "AmazonS3AccessKeyId": "" with string input. |
Amazon S3 Secret Access Key¶
Obtain this credential from your Amazon AWS administrator.
This feature’s config.json setting is "AmazonS3SecretAccessKey": "" with string input. |
Amazon S3 Bucket¶
Name you selected for your S3 bucket in AWS.
This feature’s config.json setting is "AmazonS3Bucket": "" with string input. |
Amazon S3 Region¶
AWS region you selected for creating your S3 bucket. Refer to AWS Reference Documentation and choose this variable from the Region column.
This feature’s config.json setting is "AmazonS3Region": "" with string input. |
Secure Amazon S3 Connections¶
True: Enables only secure Amazon S3 Connections.
False: Allows insecure connections to Amazon S3.
This feature’s config.json setting is "AmazonS3SSL": true with options true and false for above settings respectively. |
Maximum File Size¶
Maximum file size for message attachments entered in megabytes in the System Console UI. Converted to bytes in config.json
at 1048576 bytes per megabyte.
This feature’s config.json setting is "MaxFileSize": 52428800 with whole number input. |
Warning
Verify server memory can support your setting choice. Large file sizes increase the risk of server crashes and failed uploads due to network disruptions.
Images¶
Attachment Thumbnail Width¶
Width of thumbnails generated from uploaded images. Updating this value changes how thumbnail images render in future, but does not change images created in the past.
This feature’s config.json setting is "ThumbnailWidth": 120 with whole number input. |
Attachment Thumbnail Height¶
Height of thumbnails generated from uploaded images. Updating this value changes how thumbnail images render in future, but does not change images created in the past.
This feature’s config.json setting is "ThumbnailHeight": 100 with whole number input. |
Image Preview Width¶
Maximum width of preview image. Updating this value changes how preview images render in future, but does not change images created in the past.
This feature’s config.json setting is "PreviewWidth": 1024 with whole number input. |
Image Preview Height¶
Maximum height of preview image (“0”: Sets to auto-size). Updating this value changes how preview images render in future, but does not change images created in the past.
This feature’s config.json setting is "PreviewHeight": 0 with whole number input. |
Profile Picture Width¶
The width to which profile pictures are resized after being uploaded via Account Settings.
This feature’s config.json setting is "ProfileWidth": 128 with whole number input. |
Profile Picture Height¶
The height to which profile pictures are resized after being uploaded via Account Settings.
This feature’s config.json setting is "ProfileHeight": 128 with whole number input. |
Customization¶
Settings to customize your deployment with custom branding and legal and support links.
Custom Branding¶
Site Name¶
Name of service shown in login screens and UI. Maximum 30 characters.
This feature’s config.json setting is "SiteName": "Mattermost" with string input. |
Enable Custom Branding¶
Available in Enterprise Edition E10 and higher
True: Enables custom branding to show a JPG image some custom text on the server login page.
False: Custom branding is disabled.
This feature’s config.json setting is "EnableCustomBrand": false with options true and false for above settings respectively. |
Custom Brand Image¶
Available in Enterprise Edition E10 and higher
Custom JPG image is displayed on left side of server login page. Recommended maximum image size is less than 2 MB because image will be loaded for every user who logs in.
This features has no config.json setting and must be set in the System Console user interface. |
Custom Brand Text¶
Available in Enterprise Edition E10 and higher
Custom text will be shown below custom brand image on left side of server login page. Maximum 500 characters allowed. You can format this text using the same Markdown formatting codes as using in Mattermost messages.
This feature’s config.json setting is "CustomBrandText": "" with string input. |
Site Description¶
Available in Enterprise Edition E10 and higher Description of service shown in login screens and UI. When not specified, “All team communication in one place, searchable and accessible anywhere” is displayed.
This feature’s config.json setting is "CustomDescriptionText": "" with string input. |
Custom Emoji¶
Enable Custom Emoji¶
True: Enables a Custom Emoji option in the Main Menu, where users can go to create customized emoji.
False: Custom emojis are disabled.
This feature’s config.json setting is "EnableCustomEmoji": false with options true and false for above settings respectively. |
Restrict Custom Emoji Creation¶
Available in Enterprise Edition E10 and higher
Allow everyone to create custom emoji: Allows everyone to create custom emoji from the Main Menu > Custom Emoji.
Allow System and Team Admins to create custom emoji: The Custom Emoji option is hidden from the Main Menu for users who are not System or Team Admins.
Only allow System Admins to create custom emoji: The Custom Emoji option is hidden from the Main Menu for users who are not System or Team Admins.
This feature’s config.json setting is "RestrictCustomEmojiCreation": "all" with options all , admin and system_admin for above settings respectively. |
Legal and Support¶
Legal and Support links will be hidden in the user interface if these fields are left blank.
Terms of Service link¶
Configurable link to Terms of Service your organization may provide to end users. By default, links to a Terms of Service page hosted on about.mattermost.com. If changing the link to a different Terms of Service, make sure to include the “Mattermost Conditions of Use” notice to end users that must also be shown to users from the “Terms of Service” link.
This feature’s config.json setting is "TermsOfServiceLink": "https://about.mattermost.com/default-terms/" with string input. |
Privacy Policy link¶
Configurable link to Privacy Policy your organization may provide to end users. By default, links to a Privacy Policy page hosted on about.mattermost.com.
This feature’s config.json setting is "PrivacyPolicyLink": "https://about.mattermost.com/default-privacy-policy/" with string input. |
About link¶
Configurable link to an About page describing your organization may provide to end users. By default, links to an About page hosted on about.mattermost.com.
This feature’s config.json setting is "AboutLink": "https://about.mattermost.com/default-about/" with string input. |
Help link¶
Configurable link to a Help page your organization may provide to end users. By default, links to Mattermost help documentation hosted on docs.mattermost.com .
This feature’s config.json setting is "HelpLink": "https://about.mattermost.com/default-help/" with string input. |
Report a Problem link¶
Set the link for the support website.
This feature’s config.json setting is "ReportAProblemLink": "https://about.mattermost.com/default-report-a-problem/" with string input. |
Support Email¶
Set an email for feedback or support requests.
So you don’t miss messages, please make sure to change this value to an email your system administrator receives, example: support@yourcompany.com.
This feature’s config.json setting is "SupportEmail":"feedback@mattermost.com" with string input. |
Mattermost App Links¶
Mattermost Apps Download Page Link¶
Configurable link to a download page for Mattermost Apps. When a link is present, an option to “Download Apps” will be added in the Main Menu so users can find the download page. Leave this field blank to hide the option from the Main Menu. Defaults to a page on about.mattermost.com where users can download the iOS, Android, and Desktop clients. If you are using an Enterprise App Store for your mobile apps, change this link to point to a customized download page where users can find the correct apps.
This feature’s config.json setting is "AppDownloadLink": "https://about.mattermost.com/downloads/" with string input. |
Android App Download Link¶
Configurable link to download the Android app. When a link is present, users who access the site on a mobile web browser will be prompted with a page giving them the option to download the app. Leave this field blank to prevent the page from appearing. If you are using an Enterprise App Store for your mobile apps, change this link to point to the correct app.
This feature’s config.json setting is "AndroidAppDownloadLink": "https://about.mattermost.com/mattermost-android-app/" with string input. |
iOS App Download Link¶
Configurable link to download the iOS app. When a link is present, users who access the site on a mobile web browser will be prompted with a page giving them the option to download the app. Leave this field blank to prevent the page from appearing. If you are using an Enterprise App Store for your mobile apps, change this link to point to the correct app.
This feature’s config.json setting is "IosAppDownloadLink": "https://about.mattermost.com/mattermost-ios-app/" with string input. |
Advanced¶
Advanced settings to configure rate limiting, databases and developer options.
Rate Limiting¶
Changing properties in this section will require a server restart before taking effect.
Enable Rate Limiting¶
True: APIs are throttled at the rate specified by PerSec.
False: APIs are not throttled.
Maximum Queries per Second¶
Throttle API at this number of requests per second if rate limiting is enabled.
This feature’s config.json setting is "PerSec": 10 with whole number input. |
Maximum Burst Size¶
Maximum number of requests allowed beyond the per second query limit.
This feature’s config.json setting is "MaxBurst": 100 with whole number input. |
Memory Store Size¶
Maximum number of user sessions connected to the system as determined by VaryByRemoteAddr and VaryByHeader variables.
Typically set to the number of users in the system.
This feature’s config.json setting is "MemoryStoreSize": 10000 with whole number input. |
Vary rate limit by remote address¶
True: Rate limit API access by IP address. Recommended to set to true
if you’re using a proxy.
False: Rate limiting does not vary by IP address.
This feature’s config.json setting is "VaryByRemoteAddr": true with options true and false for above settings respectively. |
Vary rate limit by HTTP header¶
Vary rate limiting by HTTP header field specified (e.g. when configuring Ngnix set to “X-Real-IP”, when configuring AmazonELB set to “X-Forwarded-For”). Recommended to be set if you’re using a proxy.
This feature’s config.json setting is "VaryByHeader": "" with string input. |
Database¶
Changing properties in this section will require a server restart before taking effect.
Driver Name¶
This setting can only be changed from config.json file, it cannot be changed from the System Console user interface.
mysql
: enables driver to MySQL database.
postgres
: enables driver to PostgreSQL database.
This feature’s config.json setting is "DriverName": "mysql" with string input. |
Data Source¶
This is the connection string to the master database. When DriverName =”postgres” then use a connection string in the form postgres://mmuser:password@localhost:5432/mattermost_test?sslmode=disable&connect_timeout=10
. This setting can only be changed from config.json file, it cannot be changed from the System Console user interface.
This feature’s config.json setting is "DataSource": "" with string input. |
Maximum Idle Connections¶
Maximum number of idle connections held open to the database.
This feature’s config.json setting is "MaxIdleConns": 10 with whole number input. |
Maximum Open Connections¶
Maximum number of open connections held open to the database.
This feature’s config.json setting is "MaxOpenConns": 10 with whole number input. |
At Rest Encrypt Key¶
32-character (to be randomly generated via Admin Console) salt available to encrypt and decrypt sensitive fields in database.
This feature’s config.json setting is "AtRestEncryptKey": "" with string input. |
Trace¶
True: Executing SQL statements are written to the log for development.
False: SQL statements are not written to the log.
This feature’s config.json setting is "Trace": false with options true and false for above settings respectively. |
Recycle Database Connections¶
Available in Enterprise Edition E20
This button reconnects to the database listed in the configuration settings. All old connections are closed after 20s.
The workflow for failover without downing the server is to change the database line in the config.json file, click Reload Configuration from Disk in the General > Configuration section then click Recycle Database Connections.
Developer¶
Enable Testing Commands¶
True: /loadtest slash command is enabled to load test accounts and test data.
False: /loadtest slash command is disabled.
This feature’s config.json setting is "EnableTesting": false with options true and false for above settings respectively. |
Enable Developer Mode¶
True: Javascript errors are shown in a red bar at the top of the user interface. Not recommended for use in production.
False: Users are not alerted to Javascript errors.
This feature’s config.json setting is "EnableDeveloper": false with options true and false for above settings respectively. |
High Availability (Beta)¶
Available in Enterprise Edition E20
Changing properties in this section will require a server restart before taking effect. When High Availability mode is enabled, the System Console is set to read-only and can only be changed from the configuration file. Learn more about configuring high availability in our documentation.
Enable High Availability Mode¶
True: The Mattermost Server will attempt inter-node communication with the other servers in the cluster. This sets the System Console to read-only mode to keep the servers config.json
files in sync.
False: Mattemost high availability is disabled.
This feature’s config.json setting is "Enable": false with options true and false for above settings respectively. |
Inter-Node Listen Address¶
The address the Mattermost Server will listen on for inter-node communication. When setting up your network you should secure the listen address so that only machines in the cluster have access to that port. This can be done in different ways, for example, using IPsec, security groups, or routing tables.
This feature’s config.json setting is "InterNodeListenAddress": ":8075" with string input. |
Inter-Node URLs¶
A list of all the machines in the cluster, separated by commas, for example, ["http://10.10.10.2", "http://10.10.10.4"]
. It is recommended to use the internal IP addresses so all the traffic can be secured.
This feature’s config.json setting is "InterNodeUrls": [] with string input. |
Settings configurable only in config.json¶
There are a number of settings customizable in config.json
unavailable in the System Console and require updating from the file itself.
Service Settings¶
Segment Write Key¶
For deployments seeking additional tracking of system behavior using Segment.com, you can enter a Segment WRITE_KEY using this field. This value works like a tracking code and is used in client-side Javascript and will send events to Segment.com attributed to the account you used to generate the WRITE_KEY.
This feature’s config.json setting is "SegmentDeveloperKey": "" with string input. |
WebSocket Secure Port¶
(Optional) This setting defines the port on which the secured WebSocket will listen using the wss protocol. Otherwise it defaults to 443. When the client attempts to make a WebSocket connection it first checks to see if the page is loaded with HTTPS. If so, it will use the secure WebSocket connection. If not, it will use the unsecure WebSocket connection. IT IS HIGHLY RECOMMENDED PRODUCTION DEPLOYMENTS ONLY OPERATE UNDER HTTPS AND WSS.
This feature’s config.json setting is "WebsocketSecurePort" : 443 with whole number input. |
WebSocket Port¶
(Optional) this setting defines the port on which the unsecured WebSocket will listen using the ws protocol. Otherwise it defaults to 80. When the client attempts to make a WebSocket connection it first checks to see if the page is loaded with HTTPS. If so, it will use the secure WebSocket connection. If not, it will use the unsecure WebSocket connection. IT IS HIGHLY RECOMMENDED PRODUCTION DEPLOYMENTS ONLY OPERATE UNDER HTTPS AND WSS.
This feature’s config.json setting is WebsocketPort": 80 with whole number input. |
Team Settings¶
User Status Away Timeout¶
This setting defines the number of seconds after which the user’s status indicator changes to “Away”, when they are away from Mattermost.
This feature’s config.json setting is "UserStatusAwayTimeout": 300 with whole number input. |
File Settings¶
Initial Font¶
Font used in auto-generated profile pics with colored backgrounds.
This feature’s config.json setting is "InitialFont": "luximbi.ttf" with string input. |
Amazon S3 Endpoint¶
Set an endpoint URL for an Amazon S3 instance.
This feature’s config.json setting is "AmazonS3Endpoint": "" with string input. |
Amazon S3 Bucket Endpoint¶
Set an endpoint URL for Amazon S3 buckets.
This feature’s config.json setting is "AmazonS3BucketEndpoint": "" with string input. |
Amazon S3 Location Constraint¶
True: S3 region is location constrained.
False: S3 region is not location constrained.
This feature’s config.json setting is "AmazonS3LocationConstraint": false with options true and false for above settings respectively. |
Amazon S3 Lowercase Bucket¶
True: S3 bucket names are fully lowercase.
False: S3 bucket names may contain uppercase and lowercase letters.
This feature’s config.json setting is "AmazonS3LowercaseBucket": false with options true and false for above settings respectively. |
Email Settings¶
Email Batching Buffer Size¶
Specify the maximum number of notifications batched into a single email.
This feature’s config.json setting is EmailBatchingBufferSize": 256 with whole number input |
Email Batching Interval¶
Specify the maximum frequency, in seconds, which the batching job checks for new notifications. Longer batching intervals will increase performance.
This feature’s config.json setting is EmailBatchingInterval": 30 with whole number input |
GitLab Settings¶
Scope¶
Standard setting for OAuth to determine the scope of information shared with OAuth client. Not currently supported by GitLab OAuth.
This feature’s config.json setting is "Scope": "" with string input. |
Google Settings¶
Scope¶
Standard setting for OAuth to determine the scope of information shared with OAuth client. Recommended setting is profile email
.
This feature’s config.json setting is "Scope": "profile email" with string input. |