You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

app.ini.sample 36KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917
  1. ; This file lists the default values used by Gitea
  2. ; Copy required sections to your own app.ini (default is custom/conf/app.ini)
  3. ; and modify as needed.
  4. ; see https://docs.gitea.io/en-us/config-cheat-sheet/ for additional documentation.
  5. ; App name that shows in every page title
  6. APP_NAME = Gitea: Git with a cup of tea
  7. ; Change it if you run locally
  8. RUN_USER = git
  9. ; Either "dev", "prod" or "test", default is "dev"
  10. RUN_MODE = dev
  11. [repository]
  12. ROOT =
  13. SCRIPT_TYPE = bash
  14. ; Default ANSI charset
  15. ANSI_CHARSET =
  16. ; Force every new repository to be private
  17. FORCE_PRIVATE = false
  18. ; Default privacy setting when creating a new repository, allowed values: last, private, public. Default is last which means the last setting used.
  19. DEFAULT_PRIVATE = last
  20. ; Global limit of repositories per user, applied at creation time. -1 means no limit
  21. MAX_CREATION_LIMIT = -1
  22. ; Mirror sync queue length, increase if mirror syncing starts hanging
  23. MIRROR_QUEUE_LENGTH = 1000
  24. ; Patch test queue length, increase if pull request patch testing starts hanging
  25. PULL_REQUEST_QUEUE_LENGTH = 1000
  26. ; Preferred Licenses to place at the top of the List
  27. ; The name here must match the filename in conf/license or custom/conf/license
  28. PREFERRED_LICENSES = Apache License 2.0,MIT License
  29. ; Disable the ability to interact with repositories using the HTTP protocol
  30. DISABLE_HTTP_GIT = false
  31. ; Value for Access-Control-Allow-Origin header, default is not to present
  32. ; WARNING: This maybe harmful to you website if you do not give it a right value.
  33. ACCESS_CONTROL_ALLOW_ORIGIN =
  34. ; Force ssh:// clone url instead of scp-style uri when default SSH port is used
  35. USE_COMPAT_SSH_URI = false
  36. ; Close issues as long as a commit on any branch marks it as fixed
  37. DEFAULT_CLOSE_ISSUES_VIA_COMMITS_IN_ANY_BRANCH = false
  38. ; Allow users to push local repositories to Gitea and have them automatically created for a user or an org
  39. ENABLE_PUSH_CREATE_USER = false
  40. ENABLE_PUSH_CREATE_ORG = false
  41. [repository.editor]
  42. ; List of file extensions for which lines should be wrapped in the CodeMirror editor
  43. ; Separate extensions with a comma. To line wrap files without an extension, just put a comma
  44. LINE_WRAP_EXTENSIONS = .txt,.md,.markdown,.mdown,.mkd,
  45. ; Valid file modes that have a preview API associated with them, such as api/v1/markdown
  46. ; Separate the values by commas. The preview tab in edit mode won't be displayed if the file extension doesn't match
  47. PREVIEWABLE_FILE_MODES = markdown
  48. [repository.local]
  49. ; Path for local repository copy. Defaults to `tmp/local-repo`
  50. LOCAL_COPY_PATH = tmp/local-repo
  51. ; Path for local wiki copy. Defaults to `tmp/local-wiki`
  52. LOCAL_WIKI_PATH = tmp/local-wiki
  53. [repository.upload]
  54. ; Whether repository file uploads are enabled. Defaults to `true`
  55. ENABLED = true
  56. ; Path for uploads. Defaults to `data/tmp/uploads` (tmp gets deleted on gitea restart)
  57. TEMP_PATH = data/tmp/uploads
  58. ; One or more allowed types, e.g. image/jpeg|image/png. Nothing means any file type
  59. ALLOWED_TYPES =
  60. ; Max size of each file in megabytes. Defaults to 3MB
  61. FILE_MAX_SIZE = 3
  62. ; Max number of files per upload. Defaults to 5
  63. MAX_FILES = 5
  64. [repository.pull-request]
  65. ; List of prefixes used in Pull Request title to mark them as Work In Progress
  66. WORK_IN_PROGRESS_PREFIXES=WIP:,[WIP]
  67. ; List of keywords used in Pull Request comments to automatically close a related issue
  68. CLOSE_KEYWORDS=close,closes,closed,fix,fixes,fixed,resolve,resolves,resolved
  69. ; List of keywords used in Pull Request comments to automatically reopen a related issue
  70. REOPEN_KEYWORDS=reopen,reopens,reopened
  71. [repository.issue]
  72. ; List of reasons why a Pull Request or Issue can be locked
  73. LOCK_REASONS=Too heated,Off-topic,Resolved,Spam
  74. [repository.signing]
  75. ; GPG key to use to sign commits, Defaults to the default - that is the value of git config --get user.signingkey
  76. ; run in the context of the RUN_USER
  77. ; Switch to none to stop signing completely
  78. SIGNING_KEY = default
  79. ; If a SIGNING_KEY ID is provided and is not set to default, use the provided Name and Email address as the signer.
  80. ; These should match a publicized name and email address for the key. (When SIGNING_KEY is default these are set to
  81. ; the results of git config --get user.name and git config --get user.email respectively and can only be overrided
  82. ; by setting the SIGNING_KEY ID to the correct ID.)
  83. SIGNING_NAME =
  84. SIGNING_EMAIL =
  85. ; Determines when gitea should sign the initial commit when creating a repository
  86. ; Either:
  87. ; - never
  88. ; - pubkey: only sign if the user has a pubkey
  89. ; - twofa: only sign if the user has logged in with twofa
  90. ; - always
  91. ; options other than none and always can be combined as comma separated list
  92. INITIAL_COMMIT = always
  93. ; Determines when to sign for CRUD actions
  94. ; - as above
  95. ; - parentsigned: requires that the parent commit is signed.
  96. CRUD_ACTIONS = pubkey, twofa, parentsigned
  97. ; Determines when to sign Wiki commits
  98. ; - as above
  99. WIKI = never
  100. ; Determines when to sign on merges
  101. ; - basesigned: require that the parent of commit on the base repo is signed.
  102. ; - commitssigned: require that all the commits in the head branch are signed.
  103. MERGES = pubkey, twofa, basesigned, commitssigned
  104. [cors]
  105. ; More information about CORS can be found here: https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS#The_HTTP_response_headers
  106. ; enable cors headers (disabled by default)
  107. ENABLED=false
  108. ; scheme of allowed requests
  109. SCHEME=http
  110. ; list of requesting domains that are allowed
  111. ALLOW_DOMAIN=*
  112. ; allow subdomains of headers listed above to request
  113. ALLOW_SUBDOMAIN=false
  114. ; list of methods allowed to request
  115. METHODS=GET,HEAD,POST,PUT,PATCH,DELETE,OPTIONS
  116. ; max time to cache response
  117. MAX_AGE=10m
  118. ; allow request with credentials
  119. ALLOW_CREDENTIALS=false
  120. [ui]
  121. ; Number of repositories that are displayed on one explore page
  122. EXPLORE_PAGING_NUM = 20
  123. ; Number of issues that are displayed on one page
  124. ISSUE_PAGING_NUM = 10
  125. ; Number of maximum commits displayed in one activity feed
  126. FEED_MAX_COMMIT_NUM = 5
  127. ; Number of maximum commits displayed in commit graph.
  128. GRAPH_MAX_COMMIT_NUM = 100
  129. ; Number of line of codes shown for a code comment
  130. CODE_COMMENT_LINES = 4
  131. ; Value of `theme-color` meta tag, used by Android >= 5.0
  132. ; An invalid color like "none" or "disable" will have the default style
  133. ; More info: https://developers.google.com/web/updates/2014/11/Support-for-theme-color-in-Chrome-39-for-Android
  134. THEME_COLOR_META_TAG = `#6cc644`
  135. ; Max size of files to be displayed (default is 8MiB)
  136. MAX_DISPLAY_FILE_SIZE = 8388608
  137. ; Whether the email of the user should be shown in the Explore Users page
  138. SHOW_USER_EMAIL = true
  139. ; Set the default theme for the Gitea install
  140. DEFAULT_THEME = gitea
  141. ; All available themes. Allow users select personalized themes regardless of the value of `DEFAULT_THEME`.
  142. THEMES = gitea,arc-green
  143. ; All available reactions. Allow users react with different emoji's
  144. : For the whole list look at https://gitea.com/gitea/gitea.com/issues/8
  145. REACTIONS = +1, -1, laugh, hooray, confused, heart, rocket, eyes
  146. ; Whether the full name of the users should be shown where possible. If the full name isn't set, the username will be used.
  147. DEFAULT_SHOW_FULL_NAME = false
  148. ; Whether to search within description at repository search on explore page.
  149. SEARCH_REPO_DESCRIPTION = true
  150. ; Whether to enable a Service Worker to cache frontend assets
  151. USE_SERVICE_WORKER = true
  152. [ui.admin]
  153. ; Number of users that are displayed on one page
  154. USER_PAGING_NUM = 50
  155. ; Number of repos that are displayed on one page
  156. REPO_PAGING_NUM = 50
  157. ; Number of notices that are displayed on one page
  158. NOTICE_PAGING_NUM = 25
  159. ; Number of organizations that are displayed on one page
  160. ORG_PAGING_NUM = 50
  161. [ui.user]
  162. ; Number of repos that are displayed on one page
  163. REPO_PAGING_NUM = 15
  164. [ui.meta]
  165. AUTHOR = Gitea - Git with a cup of tea
  166. DESCRIPTION = Gitea (Git with a cup of tea) is a painless self-hosted Git service written in Go
  167. KEYWORDS = go,git,self-hosted,gitea
  168. [markdown]
  169. ; Enable hard line break extension
  170. ENABLE_HARD_LINE_BREAK = false
  171. ; Comma separated list of custom URL-Schemes that are allowed as links when rendering Markdown
  172. ; for example git,magnet,ftp (more at https://en.wikipedia.org/wiki/List_of_URI_schemes)
  173. ; URLs starting with http and https are always displayed, whatever is put in this entry.
  174. CUSTOM_URL_SCHEMES =
  175. ; List of file extensions that should be rendered/edited as Markdown
  176. ; Separate the extensions with a comma. To render files without any extension as markdown, just put a comma
  177. FILE_EXTENSIONS = .md,.markdown,.mdown,.mkd
  178. [server]
  179. ; The protocol the server listens on. One of 'http', 'https', 'unix' or 'fcgi'.
  180. PROTOCOL = http
  181. DOMAIN = localhost
  182. ROOT_URL = %(PROTOCOL)s://%(DOMAIN)s:%(HTTP_PORT)s/
  183. ; when STATIC_URL_PREFIX is empty it will follow APP_URL
  184. STATIC_URL_PREFIX =
  185. ; The address to listen on. Either a IPv4/IPv6 address or the path to a unix socket.
  186. HTTP_ADDR = 0.0.0.0
  187. HTTP_PORT = 3000
  188. ; If REDIRECT_OTHER_PORT is true, and PROTOCOL is set to https an http server
  189. ; will be started on PORT_TO_REDIRECT and it will redirect plain, non-secure http requests to the main
  190. ; ROOT_URL. Defaults are false for REDIRECT_OTHER_PORT and 80 for
  191. ; PORT_TO_REDIRECT.
  192. REDIRECT_OTHER_PORT = false
  193. PORT_TO_REDIRECT = 80
  194. ; Permission for unix socket
  195. UNIX_SOCKET_PERMISSION = 666
  196. ; Local (DMZ) URL for Gitea workers (such as SSH update) accessing web service.
  197. ; In most cases you do not need to change the default value.
  198. ; Alter it only if your SSH server node is not the same as HTTP node.
  199. ; Do not set this variable if PROTOCOL is set to 'unix'.
  200. LOCAL_ROOT_URL = %(PROTOCOL)s://%(HTTP_ADDR)s:%(HTTP_PORT)s/
  201. ; Disable SSH feature when not available
  202. DISABLE_SSH = false
  203. ; Whether to use the builtin SSH server or not.
  204. START_SSH_SERVER = false
  205. ; Username to use for the builtin SSH server. If blank, then it is the value of RUN_USER.
  206. BUILTIN_SSH_SERVER_USER =
  207. ; Domain name to be exposed in clone URL
  208. SSH_DOMAIN = %(DOMAIN)s
  209. ; The network interface the builtin SSH server should listen on
  210. SSH_LISTEN_HOST =
  211. ; Port number to be exposed in clone URL
  212. SSH_PORT = 22
  213. ; The port number the builtin SSH server should listen on
  214. SSH_LISTEN_PORT = %(SSH_PORT)s
  215. ; Root path of SSH directory, default is '~/.ssh', but you have to use '/home/git/.ssh'.
  216. SSH_ROOT_PATH =
  217. ; Gitea will create a authorized_keys file by default when it is not using the internal ssh server
  218. ; If you intend to use the AuthorizedKeysCommand functionality then you should turn this off.
  219. SSH_CREATE_AUTHORIZED_KEYS_FILE = true
  220. ; For the built-in SSH server, choose the ciphers to support for SSH connections,
  221. ; for system SSH this setting has no effect
  222. SSH_SERVER_CIPHERS = aes128-ctr, aes192-ctr, aes256-ctr, aes128-gcm@openssh.com, arcfour256, arcfour128
  223. ; For the built-in SSH server, choose the key exchange algorithms to support for SSH connections,
  224. ; for system SSH this setting has no effect
  225. SSH_SERVER_KEY_EXCHANGES = diffie-hellman-group1-sha1, diffie-hellman-group14-sha1, ecdh-sha2-nistp256, ecdh-sha2-nistp384, ecdh-sha2-nistp521, curve25519-sha256@libssh.org
  226. ; For the built-in SSH server, choose the MACs to support for SSH connections,
  227. ; for system SSH this setting has no effect
  228. SSH_SERVER_MACS = hmac-sha2-256-etm@openssh.com, hmac-sha2-256, hmac-sha1, hmac-sha1-96
  229. ; Directory to create temporary files in when testing public keys using ssh-keygen,
  230. ; default is the system temporary directory.
  231. SSH_KEY_TEST_PATH =
  232. ; Path to ssh-keygen, default is 'ssh-keygen' which means the shell is responsible for finding out which one to call.
  233. SSH_KEYGEN_PATH = ssh-keygen
  234. ; Enable SSH Authorized Key Backup when rewriting all keys, default is true
  235. SSH_BACKUP_AUTHORIZED_KEYS = true
  236. ; Enable exposure of SSH clone URL to anonymous visitors, default is false
  237. SSH_EXPOSE_ANONYMOUS = false
  238. ; Indicate whether to check minimum key size with corresponding type
  239. MINIMUM_KEY_SIZE_CHECK = false
  240. ; Disable CDN even in "prod" mode
  241. OFFLINE_MODE = false
  242. DISABLE_ROUTER_LOG = false
  243. ; Generate steps:
  244. ; $ ./gitea cert -ca=true -duration=8760h0m0s -host=myhost.example.com
  245. ;
  246. ; Or from a .pfx file exported from the Windows certificate store (do
  247. ; not forget to export the private key):
  248. ; $ openssl pkcs12 -in cert.pfx -out cert.pem -nokeys
  249. ; $ openssl pkcs12 -in cert.pfx -out key.pem -nocerts -nodes
  250. CERT_FILE = custom/https/cert.pem
  251. KEY_FILE = custom/https/key.pem
  252. ; Root directory containing templates and static files.
  253. ; default is the path where Gitea is executed
  254. STATIC_ROOT_PATH =
  255. ; Default path for App data
  256. APP_DATA_PATH = data
  257. ; Application level GZIP support
  258. ENABLE_GZIP = false
  259. ; Application profiling (memory and cpu)
  260. ; For "web" command it listens on localhost:6060
  261. ; For "serve" command it dumps to disk at PPROF_DATA_PATH as (cpuprofile|memprofile)_<username>_<temporary id>
  262. ENABLE_PPROF = false
  263. ; PPROF_DATA_PATH, use an absolute path when you start gitea as service
  264. PPROF_DATA_PATH = data/tmp/pprof
  265. ; Landing page, can be "home", "explore", or "organizations"
  266. LANDING_PAGE = home
  267. ; Enables git-lfs support. true or false, default is false.
  268. LFS_START_SERVER = false
  269. ; Where your lfs files reside, default is data/lfs.
  270. LFS_CONTENT_PATH = data/lfs
  271. ; LFS authentication secret, change this yourself
  272. LFS_JWT_SECRET =
  273. ; LFS authentication validity period (in time.Duration), pushes taking longer than this may fail.
  274. LFS_HTTP_AUTH_EXPIRY = 20m
  275. ; Allow graceful restarts using SIGHUP to fork
  276. ALLOW_GRACEFUL_RESTARTS = true
  277. ; After a restart the parent will finish ongoing requests before
  278. ; shutting down. Force shutdown if this process takes longer than this delay.
  279. ; set to a negative value to disable
  280. GRACEFUL_HAMMER_TIME = 60s
  281. ; Allows the setting of a startup timeout and waithint for Windows as SVC service
  282. ; 0 disables this.
  283. STARTUP_TIMEOUT = 0
  284. ; Static resources, includes resources on custom/, public/ and all uploaded avatars web browser cache time, default is 6h
  285. STATIC_CACHE_TIME = 6h
  286. ; Define allowed algorithms and their minimum key length (use -1 to disable a type)
  287. [ssh.minimum_key_sizes]
  288. ED25519 = 256
  289. ECDSA = 256
  290. RSA = 2048
  291. DSA = 1024
  292. [database]
  293. ; Either "mysql", "postgres", "mssql" or "sqlite3", it's your choice
  294. DB_TYPE = mysql
  295. HOST = 127.0.0.1:3306
  296. NAME = gitea
  297. USER = root
  298. ; Use PASSWD = `your password` for quoting if you use special characters in the password.
  299. PASSWD =
  300. ; For Postgres, either "disable" (default), "require", or "verify-full"
  301. ; For MySQL, either "false" (default), "true", or "skip-verify"
  302. SSL_MODE = disable
  303. ; For MySQL only, either "utf8" or "utf8mb4", default is "utf8".
  304. ; NOTICE: for "utf8mb4" you must use MySQL InnoDB > 5.6. Gitea is unable to check this.
  305. CHARSET = utf8
  306. ; For "sqlite3" and "tidb", use an absolute path when you start gitea as service
  307. PATH = data/gitea.db
  308. ; For "sqlite3" only. Query timeout
  309. SQLITE_TIMEOUT = 500
  310. ; For iterate buffer, default is 50
  311. ITERATE_BUFFER_SIZE = 50
  312. ; Show the database generated SQL
  313. LOG_SQL = true
  314. ; Maximum number of DB Connect retries
  315. DB_RETRIES = 10
  316. ; Backoff time per DB retry (time.Duration)
  317. DB_RETRY_BACKOFF = 3s
  318. ; Max idle database connections on connnection pool, default is 2
  319. MAX_IDLE_CONNS = 2
  320. ; Database connection max life time, default is 0 or 3s mysql (See #6804 & #7071 for reasoning)
  321. CONN_MAX_LIFETIME = 3s
  322. ; Database maximum number of open connections, default is 0 meaning no maximum
  323. MAX_OPEN_CONNS = 0
  324. [indexer]
  325. ; Issue indexer type, currently support: bleve or db, default is bleve
  326. ISSUE_INDEXER_TYPE = bleve
  327. ; Issue indexer storage path, available when ISSUE_INDEXER_TYPE is bleve
  328. ISSUE_INDEXER_PATH = indexers/issues.bleve
  329. ; Issue indexer queue, currently support: channel, levelqueue or redis, default is levelqueue
  330. ISSUE_INDEXER_QUEUE_TYPE = levelqueue
  331. ; When ISSUE_INDEXER_QUEUE_TYPE is levelqueue, this will be the queue will be saved path,
  332. ; default is indexers/issues.queue
  333. ISSUE_INDEXER_QUEUE_DIR = indexers/issues.queue
  334. ; When `ISSUE_INDEXER_QUEUE_TYPE` is `redis`, this will store the redis connection string.
  335. ISSUE_INDEXER_QUEUE_CONN_STR = "addrs=127.0.0.1:6379 db=0"
  336. ; Batch queue number, default is 20
  337. ISSUE_INDEXER_QUEUE_BATCH_NUMBER = 20
  338. ; Timeout the indexer if it takes longer than this to start.
  339. ; Set to zero to disable timeout.
  340. STARTUP_TIMEOUT=30s
  341. ; repo indexer by default disabled, since it uses a lot of disk space
  342. REPO_INDEXER_ENABLED = false
  343. REPO_INDEXER_PATH = indexers/repos.bleve
  344. UPDATE_BUFFER_LEN = 20
  345. MAX_FILE_SIZE = 1048576
  346. ; A comma separated list of glob patterns (see https://github.com/gobwas/glob) to include
  347. ; in the index; default is empty
  348. REPO_INDEXER_INCLUDE =
  349. ; A comma separated list of glob patterns to exclude from the index; ; default is empty
  350. REPO_INDEXER_EXCLUDE =
  351. [admin]
  352. ; Disallow regular (non-admin) users from creating organizations.
  353. DISABLE_REGULAR_ORG_CREATION = false
  354. ; Default configuration for email notifications for users (user configurable). Options: enabled, onmention, disabled
  355. DEFAULT_EMAIL_NOTIFICATIONS = enabled
  356. [security]
  357. ; Whether the installer is disabled
  358. INSTALL_LOCK = false
  359. ; !!CHANGE THIS TO KEEP YOUR USER DATA SAFE!!
  360. SECRET_KEY = !#@FDEWREWR&*(
  361. ; How long to remember that a user is logged in before requiring relogin (in days)
  362. LOGIN_REMEMBER_DAYS = 7
  363. COOKIE_USERNAME = gitea_awesome
  364. COOKIE_REMEMBER_NAME = gitea_incredible
  365. ; Reverse proxy authentication header name of user name
  366. REVERSE_PROXY_AUTHENTICATION_USER = X-WEBAUTH-USER
  367. REVERSE_PROXY_AUTHENTICATION_EMAIL = X-WEBAUTH-EMAIL
  368. ; The minimum password length for new Users
  369. MIN_PASSWORD_LENGTH = 6
  370. ; Set to true to allow users to import local server paths
  371. IMPORT_LOCAL_PATHS = false
  372. ; Set to true to prevent all users (including admin) from creating custom git hooks
  373. DISABLE_GIT_HOOKS = false
  374. ; Set to false to allow pushes to gitea repositories despite having an incomplete environment - NOT RECOMMENDED
  375. ONLY_ALLOW_PUSH_IF_GITEA_ENVIRONMENT_SET = true
  376. ;Comma separated list of character classes required to pass minimum complexity.
  377. ;If left empty or no valid values are specified, the default values ("lower,upper,digit,spec") will be used.
  378. ;Use "off" to disable checking.
  379. PASSWORD_COMPLEXITY = lower,upper,digit,spec
  380. ; Password Hash algorithm, either "pbkdf2", "argon2", "scrypt" or "bcrypt"
  381. PASSWORD_HASH_ALGO = pbkdf2
  382. ; Set false to allow JavaScript to read CSRF cookie
  383. CSRF_COOKIE_HTTP_ONLY = true
  384. [openid]
  385. ;
  386. ; OpenID is an open, standard and decentralized authentication protocol.
  387. ; Your identity is the address of a webpage you provide, which describes
  388. ; how to prove you are in control of that page.
  389. ;
  390. ; For more info: https://en.wikipedia.org/wiki/OpenID
  391. ;
  392. ; Current implementation supports OpenID-2.0
  393. ;
  394. ; Tested to work providers at the time of writing:
  395. ; - Any GNUSocial node (your.hostname.tld/username)
  396. ; - Any SimpleID provider (http://simpleid.koinic.net)
  397. ; - http://openid.org.cn/
  398. ; - openid.stackexchange.com
  399. ; - login.launchpad.net
  400. ; - <username>.livejournal.com
  401. ;
  402. ; Whether to allow signin in via OpenID
  403. ENABLE_OPENID_SIGNIN = true
  404. ; Whether to allow registering via OpenID
  405. ; Do not include to rely on rhw DISABLE_REGISTRATION setting
  406. ;ENABLE_OPENID_SIGNUP = true
  407. ; Allowed URI patterns (POSIX regexp).
  408. ; Space separated.
  409. ; Only these would be allowed if non-blank.
  410. ; Example value: trusted.domain.org trusted.domain.net
  411. WHITELISTED_URIS =
  412. ; Forbidden URI patterns (POSIX regexp).
  413. ; Space separated.
  414. ; Only used if WHITELISTED_URIS is blank.
  415. ; Example value: loadaverage.org/badguy stackexchange.com/.*spammer
  416. BLACKLISTED_URIS =
  417. [service]
  418. ; Time limit to confirm account/email registration
  419. ACTIVE_CODE_LIVE_MINUTES = 180
  420. ; Time limit to perform the reset of a forgotten password
  421. RESET_PASSWD_CODE_LIVE_MINUTES = 180
  422. ; Whether a new user needs to confirm their email when registering.
  423. REGISTER_EMAIL_CONFIRM = false
  424. ; List of domain names that are allowed to be used to register on a Gitea instance
  425. ; gitea.io,example.com
  426. EMAIL_DOMAIN_WHITELIST=
  427. ; Disallow registration, only allow admins to create accounts.
  428. DISABLE_REGISTRATION = false
  429. ; Allow registration only using third-party services, it works only when DISABLE_REGISTRATION is false
  430. ALLOW_ONLY_EXTERNAL_REGISTRATION = false
  431. ; User must sign in to view anything.
  432. REQUIRE_SIGNIN_VIEW = false
  433. ; Mail notification
  434. ENABLE_NOTIFY_MAIL = false
  435. ; This setting enables gitea to be signed in with HTTP BASIC Authentication using the user's password
  436. ; If you set this to false you will not be able to access the tokens endpoints on the API with your password
  437. ; Please note that setting this to false will not disable OAuth Basic or Basic authentication using a token
  438. ENABLE_BASIC_AUTHENTICATION = true
  439. ; More detail: https://github.com/gogits/gogs/issues/165
  440. ENABLE_REVERSE_PROXY_AUTHENTICATION = false
  441. ENABLE_REVERSE_PROXY_AUTO_REGISTRATION = false
  442. ENABLE_REVERSE_PROXY_EMAIL = false
  443. ; Enable captcha validation for registration
  444. ENABLE_CAPTCHA = false
  445. ; Type of captcha you want to use. Options: image, recaptcha
  446. CAPTCHA_TYPE = image
  447. ; Enable recaptcha to use Google's recaptcha service
  448. ; Go to https://www.google.com/recaptcha/admin to sign up for a key
  449. RECAPTCHA_SECRET =
  450. RECAPTCHA_SITEKEY =
  451. ; Change this to use recaptcha.net or other recaptcha service
  452. RECAPTCHA_URL = https://www.google.com/recaptcha/
  453. ; Default value for KeepEmailPrivate
  454. ; Each new user will get the value of this setting copied into their profile
  455. DEFAULT_KEEP_EMAIL_PRIVATE = false
  456. ; Default value for AllowCreateOrganization
  457. ; Every new user will have rights set to create organizations depending on this setting
  458. DEFAULT_ALLOW_CREATE_ORGANIZATION = true
  459. ; Either "public", "limited" or "private", default is "public"
  460. ; Limited is for signed user only
  461. ; Private is only for member of the organization
  462. ; Public is for everyone
  463. DEFAULT_ORG_VISIBILITY = public
  464. ; Default value for DefaultOrgMemberVisible
  465. ; True will make the membership of the users visible when added to the organisation
  466. DEFAULT_ORG_MEMBER_VISIBLE = false
  467. ; Default value for EnableDependencies
  468. ; Repositories will use dependencies by default depending on this setting
  469. DEFAULT_ENABLE_DEPENDENCIES = true
  470. ; Dependencies can be added from any repository where the user is granted access or only from the current repository depending on this setting.
  471. ALLOW_CROSS_REPOSITORY_DEPENDENCIES = true
  472. ; Enable heatmap on users profiles.
  473. ENABLE_USER_HEATMAP = true
  474. ; Enable Timetracking
  475. ENABLE_TIMETRACKING = true
  476. ; Default value for EnableTimetracking
  477. ; Repositories will use timetracking by default depending on this setting
  478. DEFAULT_ENABLE_TIMETRACKING = true
  479. ; Default value for AllowOnlyContributorsToTrackTime
  480. ; Only users with write permissions can track time if this is true
  481. DEFAULT_ALLOW_ONLY_CONTRIBUTORS_TO_TRACK_TIME = true
  482. ; Default value for the domain part of the user's email address in the git log
  483. ; if he has set KeepEmailPrivate to true. The user's email will be replaced with a
  484. ; concatenation of the user name in lower case, "@" and NO_REPLY_ADDRESS.
  485. NO_REPLY_ADDRESS = noreply.%(DOMAIN)s
  486. ; Show Registration button
  487. SHOW_REGISTRATION_BUTTON = true
  488. ; Default value for AutoWatchNewRepos
  489. ; When adding a repo to a team or creating a new repo all team members will watch the
  490. ; repo automatically if enabled
  491. AUTO_WATCH_NEW_REPOS = true
  492. ; Default value for AutoWatchOnChanges
  493. ; Make the user watch a repository When they commit for the first time
  494. AUTO_WATCH_ON_CHANGES = false
  495. [webhook]
  496. ; Hook task queue length, increase if webhook shooting starts hanging
  497. QUEUE_LENGTH = 1000
  498. ; Deliver timeout in seconds
  499. DELIVER_TIMEOUT = 5
  500. ; Allow insecure certification
  501. SKIP_TLS_VERIFY = false
  502. ; Number of history information in each page
  503. PAGING_NUM = 10
  504. ; Proxy server URL, support http://, https//, socks://, blank will follow environment http_proxy/https_proxy
  505. PROXY_URL =
  506. ; Comma separated list of host names requiring proxy. Glob patterns (*) are accepted; use ** to match all hosts.
  507. PROXY_HOSTS =
  508. [mailer]
  509. ENABLED = false
  510. ; Buffer length of channel, keep it as it is if you don't know what it is.
  511. SEND_BUFFER_LEN = 100
  512. ; Prefix displayed before subject in mail
  513. SUBJECT_PREFIX =
  514. ; Mail server
  515. ; Gmail: smtp.gmail.com:587
  516. ; QQ: smtp.qq.com:465
  517. ; Note, if the port ends with "465", SMTPS will be used. Using STARTTLS on port 587 is recommended per RFC 6409. If the server supports STARTTLS it will always be used.
  518. HOST =
  519. ; Disable HELO operation when hostnames are different.
  520. DISABLE_HELO =
  521. ; Custom hostname for HELO operation, if no value is provided, one is retrieved from system.
  522. HELO_HOSTNAME =
  523. ; Do not verify the certificate of the server. Only use this for self-signed certificates
  524. SKIP_VERIFY =
  525. ; Use client certificate
  526. USE_CERTIFICATE = false
  527. CERT_FILE = custom/mailer/cert.pem
  528. KEY_FILE = custom/mailer/key.pem
  529. ; Should SMTP connection use TLS
  530. IS_TLS_ENABLED = false
  531. ; Mail from address, RFC 5322. This can be just an email address, or the `"Name" <email@example.com>` format
  532. FROM =
  533. ; Mailer user name and password
  534. USER =
  535. ; Use PASSWD = `your password` for quoting if you use special characters in the password.
  536. PASSWD =
  537. ; Send mails as plain text
  538. SEND_AS_PLAIN_TEXT = false
  539. ; Set Mailer Type (either SMTP, sendmail or dummy to just send to the log)
  540. MAILER_TYPE = smtp
  541. ; Specify an alternative sendmail binary
  542. SENDMAIL_PATH = sendmail
  543. ; Specify any extra sendmail arguments
  544. SENDMAIL_ARGS =
  545. [cache]
  546. ; Either "memory", "redis", or "memcache", default is "memory"
  547. ADAPTER = memory
  548. ; For "memory" only, GC interval in seconds, default is 60
  549. INTERVAL = 60
  550. ; For "redis" and "memcache", connection host address
  551. ; redis: network=tcp,addr=:6379,password=macaron,db=0,pool_size=100,idle_timeout=180
  552. ; memcache: `127.0.0.1:11211`
  553. HOST =
  554. ; Time to keep items in cache if not used, default is 16 hours.
  555. ; Setting it to 0 disables caching
  556. ITEM_TTL = 16h
  557. [session]
  558. ; Either "memory", "file", or "redis", default is "memory"
  559. PROVIDER = memory
  560. ; Provider config options
  561. ; memory: doesn't have any config yet
  562. ; file: session file path, e.g. `data/sessions`
  563. ; redis: network=tcp,addr=:6379,password=macaron,db=0,pool_size=100,idle_timeout=180
  564. ; mysql: go-sql-driver/mysql dsn config string, e.g. `root:password@/session_table`
  565. PROVIDER_CONFIG = data/sessions
  566. ; Session cookie name
  567. COOKIE_NAME = i_like_gitea
  568. ; If you use session in https only, default is false
  569. COOKIE_SECURE = false
  570. ; Enable set cookie, default is true
  571. ENABLE_SET_COOKIE = true
  572. ; Session GC time interval in seconds, default is 86400 (1 day)
  573. GC_INTERVAL_TIME = 86400
  574. ; Session life time in seconds, default is 86400 (1 day)
  575. SESSION_LIFE_TIME = 86400
  576. [picture]
  577. AVATAR_UPLOAD_PATH = data/avatars
  578. REPOSITORY_AVATAR_UPLOAD_PATH = data/repo-avatars
  579. ; How Gitea deals with missing repository avatars
  580. ; none = no avatar will be displayed; random = random avatar will be displayed; image = default image will be used
  581. REPOSITORY_AVATAR_FALLBACK = none
  582. REPOSITORY_AVATAR_FALLBACK_IMAGE = /img/repo_default.png
  583. ; Max Width and Height of uploaded avatars.
  584. ; This is to limit the amount of RAM used when resizing the image.
  585. AVATAR_MAX_WIDTH = 4096
  586. AVATAR_MAX_HEIGHT = 3072
  587. ; Maximum alloved file size for uploaded avatars.
  588. ; This is to limit the amount of RAM used when resizing the image.
  589. AVATAR_MAX_FILE_SIZE = 1048576
  590. ; Chinese users can choose "duoshuo"
  591. ; or a custom avatar source, like: http://cn.gravatar.com/avatar/
  592. GRAVATAR_SOURCE = gravatar
  593. ; This value will always be true in offline mode.
  594. DISABLE_GRAVATAR = false
  595. ; Federated avatar lookup uses DNS to discover avatar associated
  596. ; with emails, see https://www.libravatar.org
  597. ; This value will always be false in offline mode or when Gravatar is disabled.
  598. ENABLE_FEDERATED_AVATAR = false
  599. [attachment]
  600. ; Whether attachments are enabled. Defaults to `true`
  601. ENABLED = true
  602. ; Path for attachments. Defaults to `data/attachments`
  603. PATH = data/attachments
  604. ; One or more allowed types, e.g. image/jpeg|image/png
  605. ALLOWED_TYPES = image/jpeg|image/png|application/zip|application/gzip
  606. ; Max size of each file. Defaults to 4MB
  607. MAX_SIZE = 4
  608. ; Max number of files per upload. Defaults to 5
  609. MAX_FILES = 5
  610. [time]
  611. ; Specifies the format for fully outputted dates. Defaults to RFC1123
  612. ; Special supported values are ANSIC, UnixDate, RubyDate, RFC822, RFC822Z, RFC850, RFC1123, RFC1123Z, RFC3339, RFC3339Nano, Kitchen, Stamp, StampMilli, StampMicro and StampNano
  613. ; For more information about the format see http://golang.org/pkg/time/#pkg-constants
  614. FORMAT =
  615. ; Location the UI time display i.e. Asia/Shanghai
  616. ; Empty means server's location setting
  617. DEFAULT_UI_LOCATION =
  618. [log]
  619. ROOT_PATH =
  620. ; Either "console", "file", "conn", "smtp" or "database", default is "console"
  621. ; Use comma to separate multiple modes, e.g. "console, file"
  622. MODE = console
  623. ; Buffer length of the channel, keep it as it is if you don't know what it is.
  624. BUFFER_LEN = 10000
  625. REDIRECT_MACARON_LOG = false
  626. MACARON = file
  627. ; Either "Trace", "Debug", "Info", "Warn", "Error", "Critical", default is "Info"
  628. ROUTER_LOG_LEVEL = Info
  629. ROUTER = console
  630. ENABLE_ACCESS_LOG = false
  631. ACCESS_LOG_TEMPLATE = {{.Ctx.RemoteAddr}} - {{.Identity}} {{.Start.Format "[02/Jan/2006:15:04:05 -0700]" }} "{{.Ctx.Req.Method}} {{.Ctx.Req.RequestURI}} {{.Ctx.Req.Proto}}" {{.ResponseWriter.Status}} {{.ResponseWriter.Size}} "{{.Ctx.Req.Referer}}\" \"{{.Ctx.Req.UserAgent}}"
  632. ACCESS = file
  633. ; Either "Trace", "Debug", "Info", "Warn", "Error", "Critical", default is "Trace"
  634. LEVEL = Info
  635. ; Either "Trace", "Debug", "Info", "Warn", "Error", "Critical", default is "None"
  636. STACKTRACE_LEVEL = None
  637. ; Generic log modes
  638. [log.x]
  639. FLAGS = stdflags
  640. EXPRESSION =
  641. PREFIX =
  642. COLORIZE = false
  643. ; For "console" mode only
  644. [log.console]
  645. LEVEL =
  646. STDERR = false
  647. ; For "file" mode only
  648. [log.file]
  649. LEVEL =
  650. ; Set the file_name for the logger. If this is a relative path this
  651. ; will be relative to ROOT_PATH
  652. FILE_NAME =
  653. ; This enables automated log rotate(switch of following options), default is true
  654. LOG_ROTATE = true
  655. ; Max number of lines in a single file, default is 1000000
  656. MAX_LINES = 1000000
  657. ; Max size shift of a single file, default is 28 means 1 << 28, 256MB
  658. MAX_SIZE_SHIFT = 28
  659. ; Segment log daily, default is true
  660. DAILY_ROTATE = true
  661. ; delete the log file after n days, default is 7
  662. MAX_DAYS = 7
  663. ; compress logs with gzip
  664. COMPRESS = true
  665. ; compression level see godoc for compress/gzip
  666. COMPRESSION_LEVEL = -1
  667. ; For "conn" mode only
  668. [log.conn]
  669. LEVEL =
  670. ; Reconnect host for every single message, default is false
  671. RECONNECT_ON_MSG = false
  672. ; Try to reconnect when connection is lost, default is false
  673. RECONNECT = false
  674. ; Either "tcp", "unix" or "udp", default is "tcp"
  675. PROTOCOL = tcp
  676. ; Host address
  677. ADDR =
  678. ; For "smtp" mode only
  679. [log.smtp]
  680. LEVEL =
  681. ; Name displayed in mail title, default is "Diagnostic message from server"
  682. SUBJECT = Diagnostic message from server
  683. ; Mail server
  684. HOST =
  685. ; Mailer user name and password
  686. USER =
  687. ; Use PASSWD = `your password` for quoting if you use special characters in the password.
  688. PASSWD =
  689. ; Receivers, can be one or more, e.g. 1@example.com,2@example.com
  690. RECEIVERS =
  691. [cron]
  692. ; Enable running cron tasks periodically.
  693. ENABLED = true
  694. ; Run cron tasks when Gitea starts.
  695. RUN_AT_START = false
  696. ; Update mirrors
  697. [cron.update_mirrors]
  698. SCHEDULE = @every 10m
  699. ; Repository health check
  700. [cron.repo_health_check]
  701. SCHEDULE = @every 24h
  702. TIMEOUT = 60s
  703. ; Arguments for command 'git fsck', e.g. "--unreachable --tags"
  704. ; see more on http://git-scm.com/docs/git-fsck
  705. ARGS =
  706. ; Check repository statistics
  707. [cron.check_repo_stats]
  708. RUN_AT_START = true
  709. SCHEDULE = @every 24h
  710. ; Clean up old repository archives
  711. [cron.archive_cleanup]
  712. ; Whether to enable the job
  713. ENABLED = true
  714. ; Whether to always run at least once at start up time (if ENABLED)
  715. RUN_AT_START = true
  716. ; Time interval for job to run
  717. SCHEDULE = @every 24h
  718. ; Archives created more than OLDER_THAN ago are subject to deletion
  719. OLDER_THAN = 24h
  720. ; Synchronize external user data (only LDAP user synchronization is supported)
  721. [cron.sync_external_users]
  722. ; Synchronize external user data when starting server (default false)
  723. RUN_AT_START = false
  724. ; Interval as a duration between each synchronization (default every 24h)
  725. SCHEDULE = @every 24h
  726. ; Create new users, update existing user data and disable users that are not in external source anymore (default)
  727. ; or only create new users if UPDATE_EXISTING is set to false
  728. UPDATE_EXISTING = true
  729. ; Update migrated repositories' issues and comments' posterid, it will always attempt synchronization when the instance starts.
  730. [cron.update_migration_post_id]
  731. ; Interval as a duration between each synchronization. (default every 24h)
  732. SCHEDULE = @every 24h
  733. [git]
  734. ; The path of git executable. If empty, Gitea searches through the PATH environment.
  735. PATH =
  736. ; Disables highlight of added and removed changes
  737. DISABLE_DIFF_HIGHLIGHT = false
  738. ; Max number of lines allowed in a single file in diff view
  739. MAX_GIT_DIFF_LINES = 1000
  740. ; Max number of allowed characters in a line in diff view
  741. MAX_GIT_DIFF_LINE_CHARACTERS = 5000
  742. ; Max number of files shown in diff view
  743. MAX_GIT_DIFF_FILES = 100
  744. ; Arguments for command 'git gc', e.g. "--aggressive --auto"
  745. ; see more on http://git-scm.com/docs/git-gc/
  746. GC_ARGS =
  747. ; If use git wire protocol version 2 when git version >= 2.18, default is true, set to false when you always want git wire protocol version 1
  748. EnableAutoGitWireProtocol = true
  749. ; Operation timeout in seconds
  750. [git.timeout]
  751. DEFAULT = 360
  752. MIGRATE = 600
  753. MIRROR = 300
  754. CLONE = 300
  755. PULL = 300
  756. GC = 60
  757. [mirror]
  758. ; Default interval as a duration between each check
  759. DEFAULT_INTERVAL = 8h
  760. ; Min interval as a duration must be > 1m
  761. MIN_INTERVAL = 10m
  762. [api]
  763. ; Enables Swagger. True or false; default is true.
  764. ENABLE_SWAGGER = true
  765. ; Max number of items in a page
  766. MAX_RESPONSE_ITEMS = 50
  767. ; Default paging number of api
  768. DEFAULT_PAGING_NUM = 30
  769. ; Default and maximum number of items per page for git trees api
  770. DEFAULT_GIT_TREES_PER_PAGE = 1000
  771. ; Default size of a blob returned by the blobs API (default is 10MiB)
  772. DEFAULT_MAX_BLOB_SIZE = 10485760
  773. [oauth2]
  774. ; Enables OAuth2 provider
  775. ENABLE = true
  776. ; Lifetime of an OAuth2 access token in seconds
  777. ACCESS_TOKEN_EXPIRATION_TIME=3600
  778. ; Lifetime of an OAuth2 access token in hours
  779. REFRESH_TOKEN_EXPIRATION_TIME=730
  780. ; Check if refresh token got already used
  781. INVALIDATE_REFRESH_TOKENS=false
  782. ; OAuth2 authentication secret for access and refresh tokens, change this to a unique string.
  783. JWT_SECRET=Bk0yK7Y9g_p56v86KaHqjSbxvNvu3SbKoOdOt2ZcXvU
  784. [i18n]
  785. LANGS = en-US,zh-CN,zh-HK,zh-TW,de-DE,fr-FR,nl-NL,lv-LV,ru-RU,uk-UA,ja-JP,es-ES,pt-BR,pl-PL,bg-BG,it-IT,fi-FI,tr-TR,cs-CZ,sr-SP,sv-SE,ko-KR
  786. NAMES = English,简体中文,繁體中文(香港),繁體中文(台灣),Deutsch,français,Nederlands,latviešu,русский,Українська,日本語,español,português do Brasil,polski,български,italiano,suomi,Türkçe,čeština,српски,svenska,한국어
  787. ; Used for datetimepicker
  788. [i18n.datelang]
  789. en-US = en
  790. zh-CN = zh
  791. zh-HK = zh-HK
  792. zh-TW = zh-TW
  793. de-DE = de
  794. fr-FR = fr
  795. nl-NL = nl
  796. lv-LV = lv
  797. ru-RU = ru
  798. uk-UA = uk
  799. ja-JP = ja
  800. es-ES = es
  801. pt-BR = pt-BR
  802. pl-PL = pl
  803. bg-BG = bg
  804. it-IT = it
  805. fi-FI = fi
  806. tr-TR = tr
  807. cs-CZ = cs-CZ
  808. sr-SP = sr
  809. sv-SE = sv
  810. ko-KR = ko
  811. [U2F]
  812. ; NOTE: THE DEFAULT VALUES HERE WILL NEED TO BE CHANGED
  813. ; Two Factor authentication with security keys
  814. ; https://developers.yubico.com/U2F/App_ID.html
  815. ;APP_ID = http://localhost:3000/
  816. ; Comma seperated list of trusted facets
  817. ;TRUSTED_FACETS = http://localhost:3000/
  818. ; Extension mapping to highlight class
  819. ; e.g. .toml=ini
  820. [highlight.mapping]
  821. [other]
  822. SHOW_FOOTER_BRANDING = false
  823. ; Show version information about Gitea and Go in the footer
  824. SHOW_FOOTER_VERSION = true
  825. ; Show template execution time in the footer
  826. SHOW_FOOTER_TEMPLATE_LOAD_TIME = true
  827. [markup.sanitizer]
  828. ; The following keys can be used multiple times to define sanitation policy rules.
  829. ;ELEMENT = span
  830. ;ALLOW_ATTR = class
  831. ;REGEXP = ^(info|warning|error)$
  832. [markup.asciidoc]
  833. ENABLED = false
  834. ; List of file extensions that should be rendered by an external command
  835. FILE_EXTENSIONS = .adoc,.asciidoc
  836. ; External command to render all matching extensions
  837. RENDER_COMMAND = "asciidoc --out-file=- -"
  838. ; Don't pass the file on STDIN, pass the filename as argument instead.
  839. IS_INPUT_FILE = false
  840. [metrics]
  841. ; Enables metrics endpoint. True or false; default is false.
  842. ENABLED = false
  843. ; If you want to add authorization, specify a token here
  844. TOKEN =
  845. [task]
  846. ; Task queue type, could be `channel` or `redis`.
  847. QUEUE_TYPE = channel
  848. ; Task queue length, available only when `QUEUE_TYPE` is `channel`.
  849. QUEUE_LENGTH = 1000
  850. ; Task queue connection string, available only when `QUEUE_TYPE` is `redis`.
  851. ; If there is a password of redis, use `addrs=127.0.0.1:6379 password=123 db=0`.
  852. QUEUE_CONN_STR = "addrs=127.0.0.1:6379 db=0"
  853. [migrations]
  854. ; Max attempts per http/https request on migrations.
  855. MAX_ATTEMPTS = 3
  856. ; Backoff time per http/https request retry (seconds)
  857. RETRY_BACKOFF = 3