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 41KB

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