| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | # Full list of environment variables that can be used with BookStack. | 
					
						
							|  |  |  | # Selectively copy these to your '.env' file as required. | 
					
						
							|  |  |  | # Each option is shown with it's default value. | 
					
						
							|  |  |  | # Do not copy this whole file to use as your '.env' file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Application environment | 
					
						
							|  |  |  | # Can be 'production', 'development', 'testing' or 'demo' | 
					
						
							|  |  |  | APP_ENV=production | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Enable debug mode | 
					
						
							|  |  |  | # Shows advanced debug information and errors. | 
					
						
							|  |  |  | # CAN EXPOSE OTHER VARIABLES, LEAVE DISABLED | 
					
						
							|  |  |  | APP_DEBUG=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Application key | 
					
						
							|  |  |  | # Used for encryption where needed. | 
					
						
							|  |  |  | # Run `php artisan key:generate` to generate a valid key. | 
					
						
							|  |  |  | APP_KEY=SomeRandomString | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Application URL | 
					
						
							|  |  |  | # This must be the root URL that you want to host BookStack on. | 
					
						
							|  |  |  | # All URL's in BookStack will be generated using this value. | 
					
						
							|  |  |  | APP_URL=https://example.com | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Application default language | 
					
						
							|  |  |  | # The default language choice to show. | 
					
						
							|  |  |  | # May be overridden by user-preference or visitor browser settings. | 
					
						
							|  |  |  | APP_LANG=en | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Auto-detect language for public visitors. | 
					
						
							|  |  |  | # Uses browser-sent headers to infer a language. | 
					
						
							|  |  |  | # APP_LANG will be used if such a header is not provided. | 
					
						
							|  |  |  | APP_AUTO_LANG_PUBLIC=true | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-05 22:09:04 +08:00
										 |  |  | # Application timezone | 
					
						
							|  |  |  | # Used where dates are displayed such as on exported content. | 
					
						
							|  |  |  | # Valid timezone values can be found here: https://www.php.net/manual/en/timezones.php | 
					
						
							|  |  |  | APP_TIMEZONE=UTC | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-04 04:33:10 +08:00
										 |  |  | # Application theme | 
					
						
							|  |  |  | # Used to specific a themes/<APP_THEME> folder where BookStack UI | 
					
						
							|  |  |  | # overrides can be made. Defaults to disabled. | 
					
						
							|  |  |  | APP_THEME=false | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | # Database details | 
					
						
							|  |  |  | # Host can contain a port (localhost:3306) or a separate DB_PORT option can be used. | 
					
						
							|  |  |  | DB_HOST=localhost | 
					
						
							|  |  |  | DB_PORT=3306 | 
					
						
							|  |  |  | DB_DATABASE=database_database | 
					
						
							|  |  |  | DB_USERNAME=database_username | 
					
						
							|  |  |  | DB_PASSWORD=database_user_password | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Mail system to use | 
					
						
							|  |  |  | # Can be 'smtp', 'mail' or 'sendmail' | 
					
						
							|  |  |  | MAIL_DRIVER=smtp | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Mail sending options | 
					
						
							|  |  |  | MAIL_FROM=mail@bookstackapp.com | 
					
						
							|  |  |  | MAIL_FROM_NAME=BookStack | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # SMTP mail options | 
					
						
							|  |  |  | MAIL_HOST=localhost | 
					
						
							|  |  |  | MAIL_PORT=1025 | 
					
						
							|  |  |  | MAIL_USERNAME=null | 
					
						
							|  |  |  | MAIL_PASSWORD=null | 
					
						
							|  |  |  | MAIL_ENCRYPTION=null | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Cache & Session driver to use | 
					
						
							|  |  |  | # Can be 'file', 'database', 'memcached' or 'redis' | 
					
						
							|  |  |  | CACHE_DRIVER=file | 
					
						
							|  |  |  | SESSION_DRIVER=file | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Session configuration | 
					
						
							|  |  |  | SESSION_LIFETIME=120 | 
					
						
							|  |  |  | SESSION_COOKIE_NAME=bookstack_session | 
					
						
							|  |  |  | SESSION_SECURE_COOKIE=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Cache key prefix | 
					
						
							|  |  |  | # Can be used to prevent conflicts multiple BookStack instances use the same store. | 
					
						
							|  |  |  | CACHE_PREFIX=bookstack | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Memcached server configuration | 
					
						
							|  |  |  | # If using a UNIX socket path for the host, set the port to 0 | 
					
						
							|  |  |  | # This follows the following format: HOST:PORT:WEIGHT | 
					
						
							|  |  |  | # For multiple servers separate with a comma | 
					
						
							|  |  |  | MEMCACHED_SERVERS=127.0.0.1:11211:100 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-09 06:42:48 +08:00
										 |  |  | # Redis server configuration | 
					
						
							|  |  |  | # This follows the following format: HOST:PORT:DATABASE | 
					
						
							|  |  |  | # or, if using a password: HOST:PORT:DATABASE:PASSWORD | 
					
						
							|  |  |  | # For multiple servers separate with a comma. These will be clustered. | 
					
						
							|  |  |  | REDIS_SERVERS=127.0.0.1:6379:0 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | # Queue driver to use | 
					
						
							|  |  |  | # Queue not really currently used but may be configurable in the future. | 
					
						
							|  |  |  | # Would advise not to change this for now. | 
					
						
							| 
									
										
										
										
											2019-09-07 06:36:16 +08:00
										 |  |  | QUEUE_CONNECTION=sync | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Storage system to use | 
					
						
							|  |  |  | # Can be 'local', 'local_secure' or 's3' | 
					
						
							|  |  |  | STORAGE_TYPE=local | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-23 23:01:15 +08:00
										 |  |  | # Image storage system to use | 
					
						
							|  |  |  | # Defaults to the value of STORAGE_TYPE if unset. | 
					
						
							|  |  |  | # Accepts the same values as STORAGE_TYPE. | 
					
						
							|  |  |  | STORAGE_IMAGE_TYPE=local | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Attachment storage system to use | 
					
						
							|  |  |  | # Defaults to the value of STORAGE_TYPE if unset. | 
					
						
							|  |  |  | # Accepts the same values as STORAGE_TYPE although 'local' will be forced to 'local_secure'. | 
					
						
							|  |  |  | STORAGE_ATTACHMENT_TYPE=local_secure | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | # Amazon S3 storage configuration | 
					
						
							|  |  |  | STORAGE_S3_KEY=your-s3-key | 
					
						
							|  |  |  | STORAGE_S3_SECRET=your-s3-secret | 
					
						
							|  |  |  | STORAGE_S3_BUCKET=s3-bucket-name | 
					
						
							|  |  |  | STORAGE_S3_REGION=s3-bucket-region | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-20 23:23:49 +08:00
										 |  |  | # S3 endpoint to use for storage calls | 
					
						
							|  |  |  | # Only set this if using a non-Amazon s3-compatible service such as Minio | 
					
						
							|  |  |  | STORAGE_S3_ENDPOINT=https://my-custom-s3-compatible.service.com:8001 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | # Storage URL prefix | 
					
						
							|  |  |  | # Used as a base for any generated image urls. | 
					
						
							|  |  |  | # An s3-format URL will be generated if not set. | 
					
						
							|  |  |  | STORAGE_URL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Authentication method to use | 
					
						
							| 
									
										
										
										
											2020-02-02 18:59:03 +08:00
										 |  |  | # Can be 'standard', 'ldap' or 'saml2' | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | AUTH_METHOD=standard | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Social authentication configuration | 
					
						
							|  |  |  | # All disabled by default. | 
					
						
							|  |  |  | # Refer to https://www.bookstackapp.com/docs/admin/third-party-auth/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | AZURE_APP_ID=false | 
					
						
							|  |  |  | AZURE_APP_SECRET=false | 
					
						
							|  |  |  | AZURE_TENANT=false | 
					
						
							|  |  |  | AZURE_AUTO_REGISTER=false | 
					
						
							|  |  |  | AZURE_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DISCORD_APP_ID=false | 
					
						
							|  |  |  | DISCORD_APP_SECRET=false | 
					
						
							|  |  |  | DISCORD_AUTO_REGISTER=false | 
					
						
							|  |  |  | DISCORD_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | FACEBOOK_APP_ID=false | 
					
						
							|  |  |  | FACEBOOK_APP_SECRET=false | 
					
						
							|  |  |  | FACEBOOK_AUTO_REGISTER=false | 
					
						
							|  |  |  | FACEBOOK_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GITHUB_APP_ID=false | 
					
						
							|  |  |  | GITHUB_APP_SECRET=false | 
					
						
							|  |  |  | GITHUB_AUTO_REGISTER=false | 
					
						
							|  |  |  | GITHUB_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GITLAB_APP_ID=false | 
					
						
							|  |  |  | GITLAB_APP_SECRET=false | 
					
						
							|  |  |  | GITLAB_BASE_URI=false | 
					
						
							|  |  |  | GITLAB_AUTO_REGISTER=false | 
					
						
							|  |  |  | GITLAB_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GOOGLE_APP_ID=false | 
					
						
							|  |  |  | GOOGLE_APP_SECRET=false | 
					
						
							|  |  |  | GOOGLE_SELECT_ACCOUNT=false | 
					
						
							|  |  |  | GOOGLE_AUTO_REGISTER=false | 
					
						
							|  |  |  | GOOGLE_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | OKTA_BASE_URL=false | 
					
						
							|  |  |  | OKTA_APP_ID=false | 
					
						
							|  |  |  | OKTA_APP_SECRET=false | 
					
						
							|  |  |  | OKTA_AUTO_REGISTER=false | 
					
						
							|  |  |  | OKTA_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SLACK_APP_ID=false | 
					
						
							|  |  |  | SLACK_APP_SECRET=false | 
					
						
							|  |  |  | SLACK_AUTO_REGISTER=false | 
					
						
							|  |  |  | SLACK_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TWITCH_APP_ID=false | 
					
						
							|  |  |  | TWITCH_APP_SECRET=false | 
					
						
							|  |  |  | TWITCH_AUTO_REGISTER=false | 
					
						
							|  |  |  | TWITCH_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TWITTER_APP_ID=false | 
					
						
							|  |  |  | TWITTER_APP_SECRET=false | 
					
						
							|  |  |  | TWITTER_AUTO_REGISTER=false | 
					
						
							|  |  |  | TWITTER_AUTO_CONFIRM_EMAIL=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # LDAP authentication configuration | 
					
						
							|  |  |  | # Refer to https://www.bookstackapp.com/docs/admin/ldap-auth/ | 
					
						
							|  |  |  | LDAP_SERVER=false | 
					
						
							|  |  |  | LDAP_BASE_DN=false | 
					
						
							|  |  |  | LDAP_DN=false | 
					
						
							|  |  |  | LDAP_PASS=false | 
					
						
							|  |  |  | LDAP_USER_FILTER=false | 
					
						
							|  |  |  | LDAP_VERSION=false | 
					
						
							|  |  |  | LDAP_TLS_INSECURE=false | 
					
						
							| 
									
										
										
										
											2019-12-16 20:38:35 +08:00
										 |  |  | LDAP_ID_ATTRIBUTE=uid | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | LDAP_EMAIL_ATTRIBUTE=mail | 
					
						
							| 
									
										
										
										
											2019-03-09 14:08:49 +08:00
										 |  |  | LDAP_DISPLAY_NAME_ATTRIBUTE=cn | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | LDAP_FOLLOW_REFERRALS=true | 
					
						
							| 
									
										
										
										
											2020-02-16 04:31:23 +08:00
										 |  |  | LDAP_DUMP_USER_DETAILS=false | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | # LDAP group sync configuration | 
					
						
							|  |  |  | # Refer to https://www.bookstackapp.com/docs/admin/ldap-auth/ | 
					
						
							|  |  |  | LDAP_USER_TO_GROUPS=false | 
					
						
							|  |  |  | LDAP_GROUP_ATTRIBUTE="memberOf" | 
					
						
							|  |  |  | LDAP_REMOVE_FROM_GROUPS=false | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-18 00:07:06 +08:00
										 |  |  | # SAML authentication configuration | 
					
						
							|  |  |  | # Refer to https://www.bookstackapp.com/docs/admin/saml2-auth/ | 
					
						
							|  |  |  | SAML2_NAME=SSO | 
					
						
							|  |  |  | SAML2_EMAIL_ATTRIBUTE=email | 
					
						
							|  |  |  | SAML2_DISPLAY_NAME_ATTRIBUTES=username | 
					
						
							|  |  |  | SAML2_EXTERNAL_ID_ATTRIBUTE=null | 
					
						
							|  |  |  | SAML2_IDP_ENTITYID=null | 
					
						
							|  |  |  | SAML2_IDP_SSO=null | 
					
						
							|  |  |  | SAML2_IDP_SLO=null | 
					
						
							|  |  |  | SAML2_IDP_x509=null | 
					
						
							|  |  |  | SAML2_ONELOGIN_OVERRIDES=null | 
					
						
							|  |  |  | SAML2_DUMP_USER_DETAILS=false | 
					
						
							|  |  |  | SAML2_AUTOLOAD_METADATA=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # SAML group sync configuration | 
					
						
							|  |  |  | # Refer to https://www.bookstackapp.com/docs/admin/saml2-auth/ | 
					
						
							|  |  |  | SAML2_USER_TO_GROUPS=false | 
					
						
							|  |  |  | SAML2_GROUP_ATTRIBUTE=group | 
					
						
							|  |  |  | SAML2_REMOVE_FROM_GROUPS=false | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | # Disable default third-party services such as Gravatar and Draw.IO | 
					
						
							|  |  |  | # Service-specific options will override this option | 
					
						
							|  |  |  | DISABLE_EXTERNAL_SERVICES=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Use custom avatar service, Sets fetch URL | 
					
						
							|  |  |  | # Possible placeholders: ${hash} ${size} ${email} | 
					
						
							|  |  |  | # If set, Avatars will be fetched regardless of DISABLE_EXTERNAL_SERVICES option. | 
					
						
							|  |  |  | # Example: AVATAR_URL=https://seccdn.libravatar.org/avatar/${hash}?s=${size}&d=identicon | 
					
						
							|  |  |  | AVATAR_URL= | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-29 03:45:38 +08:00
										 |  |  | # Enable diagrams.net integration | 
					
						
							| 
									
										
										
										
											2020-04-06 00:27:16 +08:00
										 |  |  | # Can simply be true/false to enable/disable the integration. | 
					
						
							| 
									
										
										
										
											2020-09-29 03:45:38 +08:00
										 |  |  | # Alternatively, It can be URL to the diagrams.net instance you want to use. | 
					
						
							| 
									
										
										
										
											2020-04-06 00:27:16 +08:00
										 |  |  | # For URLs, The following URL parameters should be included: embed=1&proto=json&spin=1 | 
					
						
							| 
									
										
										
										
											2019-01-06 23:46:16 +08:00
										 |  |  | DRAWIO=true | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Default item listing view | 
					
						
							|  |  |  | # Used for public visitors and user's without a preference | 
					
						
							|  |  |  | # Can be 'list' or 'grid' | 
					
						
							|  |  |  | APP_VIEWS_BOOKS=list | 
					
						
							|  |  |  | APP_VIEWS_BOOKSHELVES=grid | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Page revision limit | 
					
						
							|  |  |  | # Number of page revisions to keep in the system before deleting old revisions. | 
					
						
							|  |  |  | # If set to 'false' a limit will not be enforced. | 
					
						
							|  |  |  | REVISION_LIMIT=50 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Allow <script> tags in page content | 
					
						
							|  |  |  | # Note, if set to 'true' the page editor may still escape scripts. | 
					
						
							|  |  |  | ALLOW_CONTENT_SCRIPTS=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Indicate if robots/crawlers should crawl your instance. | 
					
						
							|  |  |  | # Can be 'true', 'false' or 'null'. | 
					
						
							|  |  |  | # The behaviour of the default 'null' option will depend on the 'app-public' admin setting. | 
					
						
							|  |  |  | # Contents of the robots.txt file can be overridden, making this option obsolete. | 
					
						
							|  |  |  | ALLOW_ROBOTS=null | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-28 22:58:07 +08:00
										 |  |  | # The default and maximum item-counts for listing API requests. | 
					
						
							|  |  |  | API_DEFAULT_ITEM_COUNT=100 | 
					
						
							| 
									
										
										
										
											2020-01-18 23:03:28 +08:00
										 |  |  | API_MAX_ITEM_COUNT=500 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # The number of API requests that can be made per minute by a single user. | 
					
						
							| 
									
										
										
										
											2020-05-03 22:20:02 +08:00
										 |  |  | API_REQUESTS_PER_MIN=180 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-20 06:09:08 +08:00
										 |  |  | # Enable the logging of failed email+password logins with the given message. | 
					
						
							|  |  |  | # The default log channel below uses the php 'error_log' function which commonly | 
					
						
							| 
									
										
										
										
											2020-07-28 19:59:43 +08:00
										 |  |  | # results in messages being output to the webserver error logs. | 
					
						
							|  |  |  | # The message can contain a %u parameter which will be replaced with the login | 
					
						
							|  |  |  | # user identifier (Username or email). | 
					
						
							|  |  |  | LOG_FAILED_LOGIN_MESSAGE=false | 
					
						
							|  |  |  | LOG_FAILED_LOGIN_CHANNEL=errorlog_plain_webserver |