Compare commits
37 Commits
forgejo
...
v1.18/forg
Author | SHA1 | Date |
---|---|---|
Loïc Dachary | 2790039d1c | |
Loïc Dachary | c3a727cdee | |
Loïc Dachary | 5038c69608 | |
Loïc Dachary | a11248d7d7 | |
Loïc Dachary | 7f61fb476c | |
Loïc Dachary | f6789b05ec | |
Gary Moon | ff4dd729aa | |
techknowlogick | 9bccc60cf5 | |
Xinyu Zhou | 16772ffde3 | |
Xinyu Zhou | c844c4ff88 | |
KN4CK3R | f4ec03a4e5 | |
KN4CK3R | b2369830bb | |
silverwind | ef08998bf6 | |
Jason Song | 7a004ad7eb | |
Gusted | af8b2250c4 | |
Jason Song | 8917af8701 | |
zeripath | 0d25292fbc | |
Jason Song | ac409fcfba | |
Gusted | df512f77b7 | |
silverwind | e4bf9cad1e | |
Jason Song | 169eeee101 | |
wxiaoguang | 3aacc9b4ac | |
wxiaoguang | 87d05d376d | |
Lunny Xiao | b9dcf991b9 | |
Xinyu Zhou | a2a42cd5de | |
Wayne Starr | 805a14cc91 | |
Xinyu Zhou | 69a54545a8 | |
Wayne Starr | e054f80fe0 | |
wxiaoguang | 89d52922d0 | |
zeripath | 3a0d000b94 | |
silverwind | fd4e7447e7 | |
Jason Song | 7a8e34b255 | |
Jason Song | e4a10f8c78 | |
silverwind | 6dba648e5d | |
KN4CK3R | 4d39fd8aae | |
wxiaoguang | 4869f9c3c8 | |
qwerty287 | 79275d9db4 |
114
.dockerignore
114
.dockerignore
|
@ -1,114 +0,0 @@
|
||||||
# Compiled Object files, Static and Dynamic libs (Shared Objects)
|
|
||||||
*.o
|
|
||||||
*.a
|
|
||||||
*.so
|
|
||||||
|
|
||||||
# Folders
|
|
||||||
_obj
|
|
||||||
_test
|
|
||||||
|
|
||||||
# IntelliJ
|
|
||||||
.idea
|
|
||||||
# Goland's output filename can not be set manually
|
|
||||||
/go_build_*
|
|
||||||
|
|
||||||
# MS VSCode
|
|
||||||
.vscode
|
|
||||||
__debug_bin
|
|
||||||
|
|
||||||
# Architecture specific extensions/prefixes
|
|
||||||
*.[568vq]
|
|
||||||
[568vq].out
|
|
||||||
|
|
||||||
*.cgo1.go
|
|
||||||
*.cgo2.c
|
|
||||||
_cgo_defun.c
|
|
||||||
_cgo_gotypes.go
|
|
||||||
_cgo_export.*
|
|
||||||
|
|
||||||
_testmain.go
|
|
||||||
|
|
||||||
*.exe
|
|
||||||
*.test
|
|
||||||
*.prof
|
|
||||||
|
|
||||||
*coverage.out
|
|
||||||
coverage.all
|
|
||||||
cpu.out
|
|
||||||
|
|
||||||
/modules/migration/bindata.go
|
|
||||||
/modules/migration/bindata.go.hash
|
|
||||||
/modules/options/bindata.go
|
|
||||||
/modules/options/bindata.go.hash
|
|
||||||
/modules/public/bindata.go
|
|
||||||
/modules/public/bindata.go.hash
|
|
||||||
/modules/templates/bindata.go
|
|
||||||
/modules/templates/bindata.go.hash
|
|
||||||
|
|
||||||
*.db
|
|
||||||
*.log
|
|
||||||
|
|
||||||
/gitea
|
|
||||||
/gitea-vet
|
|
||||||
/debug
|
|
||||||
/integrations.test
|
|
||||||
|
|
||||||
/bin
|
|
||||||
/dist
|
|
||||||
/custom/*
|
|
||||||
!/custom/conf
|
|
||||||
/custom/conf/*
|
|
||||||
!/custom/conf/app.example.ini
|
|
||||||
/data
|
|
||||||
/indexers
|
|
||||||
/log
|
|
||||||
/public/img/avatar
|
|
||||||
/tests/integration/gitea-integration-*
|
|
||||||
/tests/integration/indexers-*
|
|
||||||
/tests/e2e/gitea-e2e-*
|
|
||||||
/tests/e2e/indexers-*
|
|
||||||
/tests/e2e/reports
|
|
||||||
/tests/e2e/test-artifacts
|
|
||||||
/tests/e2e/test-snapshots
|
|
||||||
/tests/*.ini
|
|
||||||
/node_modules
|
|
||||||
/yarn.lock
|
|
||||||
/yarn-error.log
|
|
||||||
/npm-debug.log*
|
|
||||||
/public/js
|
|
||||||
/public/serviceworker.js
|
|
||||||
/public/css
|
|
||||||
/public/fonts
|
|
||||||
/public/img/webpack
|
|
||||||
/vendor
|
|
||||||
/web_src/fomantic/node_modules
|
|
||||||
/web_src/fomantic/build/*
|
|
||||||
!/web_src/fomantic/build/semantic.js
|
|
||||||
!/web_src/fomantic/build/semantic.css
|
|
||||||
!/web_src/fomantic/build/themes
|
|
||||||
/web_src/fomantic/build/themes/*
|
|
||||||
!/web_src/fomantic/build/themes/default
|
|
||||||
/web_src/fomantic/build/themes/default/assets/*
|
|
||||||
!/web_src/fomantic/build/themes/default/assets/fonts
|
|
||||||
/web_src/fomantic/build/themes/default/assets/fonts/*
|
|
||||||
!/web_src/fomantic/build/themes/default/assets/fonts/icons.woff2
|
|
||||||
!/web_src/fomantic/build/themes/default/assets/fonts/outline-icons.woff2
|
|
||||||
/VERSION
|
|
||||||
/.air
|
|
||||||
/.go-licenses
|
|
||||||
|
|
||||||
# Snapcraft
|
|
||||||
snap/.snapcraft/
|
|
||||||
parts/
|
|
||||||
stage/
|
|
||||||
prime/
|
|
||||||
*.snap
|
|
||||||
*.snap-build
|
|
||||||
*_source.tar.bz2
|
|
||||||
.DS_Store
|
|
||||||
|
|
||||||
# Make evidence files
|
|
||||||
/.make_evidence
|
|
||||||
|
|
||||||
# Manpage
|
|
||||||
/man
|
|
14
.drone.yml
14
.drone.yml
|
@ -39,6 +39,16 @@ steps:
|
||||||
- make lint-frontend
|
- make lint-frontend
|
||||||
depends_on: [deps-frontend]
|
depends_on: [deps-frontend]
|
||||||
|
|
||||||
|
- name: security-check
|
||||||
|
image: golang:1.19
|
||||||
|
pull: always
|
||||||
|
commands:
|
||||||
|
- make security-check
|
||||||
|
depends_on: [deps-backend]
|
||||||
|
volumes:
|
||||||
|
- name: deps
|
||||||
|
path: /go
|
||||||
|
|
||||||
- name: lint-backend
|
- name: lint-backend
|
||||||
image: gitea/test_env:linux-amd64 # https://gitea.com/gitea/test-env
|
image: gitea/test_env:linux-amd64 # https://gitea.com/gitea/test-env
|
||||||
pull: always
|
pull: always
|
||||||
|
@ -551,7 +561,7 @@ steps:
|
||||||
|
|
||||||
# TODO: We should probably build all dependencies into a test image
|
# TODO: We should probably build all dependencies into a test image
|
||||||
- name: test-e2e
|
- name: test-e2e
|
||||||
image: mcr.microsoft.com/playwright:v1.28.0-focal
|
image: mcr.microsoft.com/playwright:v1.27.0-focal
|
||||||
commands:
|
commands:
|
||||||
- curl -sLO https://go.dev/dl/go1.19.linux-amd64.tar.gz && tar -C /usr/local -xzf go1.19.linux-amd64.tar.gz
|
- curl -sLO https://go.dev/dl/go1.19.linux-amd64.tar.gz && tar -C /usr/local -xzf go1.19.linux-amd64.tar.gz
|
||||||
- groupadd --gid 1001 gitea && useradd -m --gid 1001 --uid 1001 gitea
|
- groupadd --gid 1001 gitea && useradd -m --gid 1001 --uid 1001 gitea
|
||||||
|
@ -600,7 +610,7 @@ steps:
|
||||||
from_secret: crowdin_key
|
from_secret: crowdin_key
|
||||||
|
|
||||||
- name: update
|
- name: update
|
||||||
image: alpine:3.17
|
image: alpine:3.13
|
||||||
pull: always
|
pull: always
|
||||||
commands:
|
commands:
|
||||||
- ./build/update-locales.sh
|
- ./build/update-locales.sh
|
||||||
|
|
|
@ -199,7 +199,7 @@ rules:
|
||||||
newline-per-chained-call: [0]
|
newline-per-chained-call: [0]
|
||||||
no-alert: [0]
|
no-alert: [0]
|
||||||
no-array-constructor: [2]
|
no-array-constructor: [2]
|
||||||
no-async-promise-executor: [0]
|
no-async-promise-executor: [2]
|
||||||
no-await-in-loop: [0]
|
no-await-in-loop: [0]
|
||||||
no-bitwise: [0]
|
no-bitwise: [0]
|
||||||
no-buffer-constructor: [0]
|
no-buffer-constructor: [0]
|
||||||
|
@ -229,7 +229,6 @@ rules:
|
||||||
no-empty-character-class: [2]
|
no-empty-character-class: [2]
|
||||||
no-empty-function: [0]
|
no-empty-function: [0]
|
||||||
no-empty-pattern: [2]
|
no-empty-pattern: [2]
|
||||||
no-empty-static-block: [2]
|
|
||||||
no-empty: [2, {allowEmptyCatch: true}]
|
no-empty: [2, {allowEmptyCatch: true}]
|
||||||
no-eq-null: [2]
|
no-eq-null: [2]
|
||||||
no-eval: [2]
|
no-eval: [2]
|
||||||
|
@ -255,7 +254,7 @@ rules:
|
||||||
no-irregular-whitespace: [2]
|
no-irregular-whitespace: [2]
|
||||||
no-iterator: [2]
|
no-iterator: [2]
|
||||||
no-label-var: [2]
|
no-label-var: [2]
|
||||||
no-labels: [0]
|
no-labels: [2]
|
||||||
no-lone-blocks: [2]
|
no-lone-blocks: [2]
|
||||||
no-lonely-if: [0]
|
no-lonely-if: [0]
|
||||||
no-loop-func: [0]
|
no-loop-func: [0]
|
||||||
|
@ -270,7 +269,6 @@ rules:
|
||||||
no-negated-condition: [0]
|
no-negated-condition: [0]
|
||||||
no-nested-ternary: [0]
|
no-nested-ternary: [0]
|
||||||
no-new-func: [2]
|
no-new-func: [2]
|
||||||
no-new-native-nonconstructor: [2]
|
|
||||||
no-new-object: [2]
|
no-new-object: [2]
|
||||||
no-new-symbol: [2]
|
no-new-symbol: [2]
|
||||||
no-new-wrappers: [2]
|
no-new-wrappers: [2]
|
||||||
|
@ -335,7 +333,7 @@ rules:
|
||||||
no-void: [2]
|
no-void: [2]
|
||||||
no-warning-comments: [0]
|
no-warning-comments: [0]
|
||||||
no-whitespace-before-property: [2]
|
no-whitespace-before-property: [2]
|
||||||
no-with: [0]
|
no-with: [2]
|
||||||
nonblock-statement-body-position: [2]
|
nonblock-statement-body-position: [2]
|
||||||
object-curly-newline: [0]
|
object-curly-newline: [0]
|
||||||
object-curly-spacing: [2, never]
|
object-curly-spacing: [2, never]
|
||||||
|
@ -380,11 +378,11 @@ rules:
|
||||||
sonarjs/no-duplicated-branches: [0]
|
sonarjs/no-duplicated-branches: [0]
|
||||||
sonarjs/no-element-overwrite: [2]
|
sonarjs/no-element-overwrite: [2]
|
||||||
sonarjs/no-empty-collection: [2]
|
sonarjs/no-empty-collection: [2]
|
||||||
sonarjs/no-extra-arguments: [2]
|
sonarjs/no-extra-arguments: [0]
|
||||||
sonarjs/no-gratuitous-expressions: [2]
|
sonarjs/no-gratuitous-expressions: [2]
|
||||||
sonarjs/no-identical-conditions: [2]
|
sonarjs/no-identical-conditions: [2]
|
||||||
sonarjs/no-identical-expressions: [2]
|
sonarjs/no-identical-expressions: [0]
|
||||||
sonarjs/no-identical-functions: [2, 5]
|
sonarjs/no-identical-functions: [0]
|
||||||
sonarjs/no-ignored-return: [2]
|
sonarjs/no-ignored-return: [2]
|
||||||
sonarjs/no-inverted-boolean-check: [2]
|
sonarjs/no-inverted-boolean-check: [2]
|
||||||
sonarjs/no-nested-switch: [0]
|
sonarjs/no-nested-switch: [0]
|
||||||
|
@ -396,7 +394,7 @@ rules:
|
||||||
sonarjs/no-small-switch: [0]
|
sonarjs/no-small-switch: [0]
|
||||||
sonarjs/no-unused-collection: [2]
|
sonarjs/no-unused-collection: [2]
|
||||||
sonarjs/no-use-of-empty-return-value: [2]
|
sonarjs/no-use-of-empty-return-value: [2]
|
||||||
sonarjs/no-useless-catch: [2]
|
sonarjs/no-useless-catch: [0]
|
||||||
sonarjs/non-existent-operator: [2]
|
sonarjs/non-existent-operator: [2]
|
||||||
sonarjs/prefer-immediate-return: [0]
|
sonarjs/prefer-immediate-return: [0]
|
||||||
sonarjs/prefer-object-literal: [0]
|
sonarjs/prefer-object-literal: [0]
|
||||||
|
@ -445,7 +443,6 @@ rules:
|
||||||
unicorn/no-invalid-remove-event-listener: [2]
|
unicorn/no-invalid-remove-event-listener: [2]
|
||||||
unicorn/no-keyword-prefix: [0]
|
unicorn/no-keyword-prefix: [0]
|
||||||
unicorn/no-lonely-if: [2]
|
unicorn/no-lonely-if: [2]
|
||||||
unicorn/no-negated-condition: [0]
|
|
||||||
unicorn/no-nested-ternary: [0]
|
unicorn/no-nested-ternary: [0]
|
||||||
unicorn/no-new-array: [0]
|
unicorn/no-new-array: [0]
|
||||||
unicorn/no-new-buffer: [0]
|
unicorn/no-new-buffer: [0]
|
||||||
|
@ -456,7 +453,6 @@ rules:
|
||||||
unicorn/no-static-only-class: [2]
|
unicorn/no-static-only-class: [2]
|
||||||
unicorn/no-thenable: [2]
|
unicorn/no-thenable: [2]
|
||||||
unicorn/no-this-assignment: [2]
|
unicorn/no-this-assignment: [2]
|
||||||
unicorn/no-typeof-undefined: [2]
|
|
||||||
unicorn/no-unnecessary-await: [2]
|
unicorn/no-unnecessary-await: [2]
|
||||||
unicorn/no-unreadable-array-destructuring: [0]
|
unicorn/no-unreadable-array-destructuring: [0]
|
||||||
unicorn/no-unreadable-iife: [2]
|
unicorn/no-unreadable-iife: [2]
|
||||||
|
@ -507,7 +503,6 @@ rules:
|
||||||
unicorn/prefer-regexp-test: [2]
|
unicorn/prefer-regexp-test: [2]
|
||||||
unicorn/prefer-replace-all: [0]
|
unicorn/prefer-replace-all: [0]
|
||||||
unicorn/prefer-set-has: [0]
|
unicorn/prefer-set-has: [0]
|
||||||
unicorn/prefer-set-size: [2]
|
|
||||||
unicorn/prefer-spread: [0]
|
unicorn/prefer-spread: [0]
|
||||||
unicorn/prefer-starts-ends-with: [2]
|
unicorn/prefer-starts-ends-with: [2]
|
||||||
unicorn/prefer-string-slice: [0]
|
unicorn/prefer-string-slice: [0]
|
||||||
|
|
|
@ -1,53 +0,0 @@
|
||||||
---
|
|
||||||
name: "Bug Report"
|
|
||||||
about: "Found something you weren't expecting? Report it here!"
|
|
||||||
title: "[BUG] "
|
|
||||||
---
|
|
||||||
<!--
|
|
||||||
NOTE: If your issue is a security concern, please email security@forgejo.org (GPG: A4676E79) instead of opening a public issue.
|
|
||||||
|
|
||||||
1. Please speak English, as this is the language all maintainers can
|
|
||||||
speak and write.
|
|
||||||
|
|
||||||
2. Please ask questions or troubleshoot configuration/deploy problems
|
|
||||||
in our Matrix space (https://matrix.to/#/#forgejo:matrix.org).
|
|
||||||
|
|
||||||
3. Please make sure you are using the latest release of Forgejo and
|
|
||||||
take a moment to check that your issue hasn't been reported before.
|
|
||||||
|
|
||||||
4. Please give all relevant information below for bug reports, because
|
|
||||||
incomplete details will be handled as an invalid report.
|
|
||||||
|
|
||||||
5. If you are using a proxy or a CDN (e.g. CloudFlare) in front of
|
|
||||||
Forgejo, please disable the proxy/CDN fully and connect to Forgejo
|
|
||||||
directly to confirm the issue still persists without those services.
|
|
||||||
-->
|
|
||||||
|
|
||||||
- Forgejo version (or commit ref):
|
|
||||||
- Git version:
|
|
||||||
- Operating system:
|
|
||||||
- Database (use `[x]`):
|
|
||||||
- [ ] PostgreSQL
|
|
||||||
- [ ] MySQL
|
|
||||||
- [ ] MSSQL
|
|
||||||
- [ ] SQLite
|
|
||||||
- How are you running Forgejo?
|
|
||||||
<!--
|
|
||||||
Please include information on whether you built Forgejo yourself, used one of our downloads, or are using some other package.
|
|
||||||
Please also tell us how you are running Forgejo, e.g. if it is being run from docker, a command-line, systemd etc.
|
|
||||||
If you are using a package or systemd tell us what distribution you are using.
|
|
||||||
-->
|
|
||||||
|
|
||||||
## Description
|
|
||||||
<!-- Please describe the issue you are having as clearly and succinctly as possible. -->
|
|
||||||
|
|
||||||
## Logs
|
|
||||||
<!--
|
|
||||||
It is really important to provide pertinent logs. We need DEBUG level logs.
|
|
||||||
Please read https://docs.gitea.io/en-us/logging-configuration/#debugging-problems
|
|
||||||
In addition, if your problem relates to git commands set `RUN_MODE=dev` at the top of `app.ini`.
|
|
||||||
Please copy and paste your logs here, with any sensitive information (e.g. API keys) removed/hidden.
|
|
||||||
-->
|
|
||||||
|
|
||||||
## Screenshots
|
|
||||||
<!-- If this issue involves the Web Interface, please provide one or more screenshots -->
|
|
|
@ -1,21 +0,0 @@
|
||||||
---
|
|
||||||
name: "Feature Request"
|
|
||||||
about: "Got an idea for a feature that Forgejo doesn't have yet? Submit it here!"
|
|
||||||
title: "[FEAT] "
|
|
||||||
---
|
|
||||||
<!--
|
|
||||||
1. Please speak English, as this is the language all maintainers can
|
|
||||||
speak and write.
|
|
||||||
|
|
||||||
2. Please ask questions or troubleshoot configuration/deploy problems
|
|
||||||
in our Matrix space (https://matrix.to/#/#forgejo:matrix.org).
|
|
||||||
|
|
||||||
3. Please make sure you are using the latest release of Forgejo and
|
|
||||||
take a moment to check that your feature hasn't already been suggested.
|
|
||||||
-->
|
|
||||||
|
|
||||||
## Feature Description
|
|
||||||
<!-- Please describe the feature you would like to see added as clearly and succinctly as possible. -->
|
|
||||||
|
|
||||||
## Screenshots
|
|
||||||
<!-- If you can, provide screenshots of an implementation on another site, e.g. GitHub. -->
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
<!-- NOTE: If your issue is a security concern, please send an email to security@gitea.io instead of opening a public issue -->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
1. Please speak English, this is the language all maintainers can speak and write.
|
||||||
|
2. Please ask questions or configuration/deploy problems on our Discord
|
||||||
|
server (https://discord.gg/gitea) or forum (https://discourse.gitea.io).
|
||||||
|
3. Please take a moment to check that your issue doesn't already exist.
|
||||||
|
4. Make sure it's not mentioned in the FAQ (https://docs.gitea.io/en-us/faq)
|
||||||
|
5. Please give all relevant information below for bug reports, because
|
||||||
|
incomplete details will be handled as an invalid report.
|
||||||
|
-->
|
||||||
|
|
||||||
|
- Gitea version (or commit ref):
|
||||||
|
- Git version:
|
||||||
|
- Operating system:
|
||||||
|
<!-- Please include information on whether you built gitea yourself, used one of our downloads or are using some other package -->
|
||||||
|
<!-- Please also tell us how you are running gitea, e.g. if it is being run from docker, a command-line, systemd etc. --->
|
||||||
|
<!-- If you are using a package or systemd tell us what distribution you are using -->
|
||||||
|
- Database (use `[x]`):
|
||||||
|
- [ ] PostgreSQL
|
||||||
|
- [ ] MySQL
|
||||||
|
- [ ] MSSQL
|
||||||
|
- [ ] SQLite
|
||||||
|
- Can you reproduce the bug at https://try.gitea.io:
|
||||||
|
- [ ] Yes (provide example URL)
|
||||||
|
- [ ] No
|
||||||
|
- Log gist:
|
||||||
|
<!-- It really is important to provide pertinent logs -->
|
||||||
|
<!-- Please read https://docs.gitea.io/en-us/logging-configuration/#debugging-problems -->
|
||||||
|
<!-- In addition, if your problem relates to git commands set `RUN_MODE=dev` at the top of app.ini -->
|
||||||
|
|
||||||
|
## Description
|
||||||
|
<!-- If using a proxy or a CDN (e.g. CloudFlare) in front of gitea, please
|
||||||
|
disable the proxy/CDN fully and connect to gitea directly to confirm
|
||||||
|
the issue still persists without those services. -->
|
||||||
|
|
||||||
|
...
|
||||||
|
|
||||||
|
|
||||||
|
## Screenshots
|
||||||
|
|
||||||
|
<!-- **If this issue involves the Web Interface, please include a screenshot** -->
|
|
@ -1,4 +0,0 @@
|
||||||
<!--
|
|
||||||
Before submitting a PR, please read the contributing guidelines:
|
|
||||||
https://codeberg.org/forgejo/forgejo/src/branch/main/CONTRIBUTING.md
|
|
||||||
-->
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
open_collective: gitea
|
||||||
|
custom: https://www.bountysource.com/teams/gitea
|
|
@ -0,0 +1,94 @@
|
||||||
|
name: Bug Report
|
||||||
|
description: Found something you weren't expecting? Report it here!
|
||||||
|
labels: kind/bug
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
NOTE: If your issue is a security concern, please send an email to security@gitea.io instead of opening a public issue.
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
1. Please speak English, this is the language all maintainers can speak and write.
|
||||||
|
2. Please ask questions or configuration/deploy problems on our Discord
|
||||||
|
server (https://discord.gg/gitea) or forum (https://discourse.gitea.io).
|
||||||
|
3. Make sure you are using the latest release and
|
||||||
|
take a moment to check that your issue hasn't been reported before.
|
||||||
|
4. Make sure it's not mentioned in the FAQ (https://docs.gitea.io/en-us/faq)
|
||||||
|
5. Please give all relevant information below for bug reports, because
|
||||||
|
incomplete details will be handled as an invalid report.
|
||||||
|
6. In particular it's really important to provide pertinent logs. You must give us DEBUG level logs.
|
||||||
|
Please read https://docs.gitea.io/en-us/logging-configuration/#debugging-problems
|
||||||
|
In addition, if your problem relates to git commands set `RUN_MODE=dev` at the top of app.ini
|
||||||
|
- type: textarea
|
||||||
|
id: description
|
||||||
|
attributes:
|
||||||
|
label: Description
|
||||||
|
description: |
|
||||||
|
Please provide a description of your issue here, with a URL if you were able to reproduce the issue (see below)
|
||||||
|
If you are using a proxy or a CDN (e.g. Cloudflare) in front of Gitea, please disable the proxy/CDN fully and access Gitea directly to confirm the issue still persists without those services.
|
||||||
|
- type: input
|
||||||
|
id: gitea-ver
|
||||||
|
attributes:
|
||||||
|
label: Gitea Version
|
||||||
|
description: Gitea version (or commit reference) of your instance
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: dropdown
|
||||||
|
id: can-reproduce
|
||||||
|
attributes:
|
||||||
|
label: Can you reproduce the bug on the Gitea demo site?
|
||||||
|
description: |
|
||||||
|
If so, please provide a URL in the Description field
|
||||||
|
URL of Gitea demo: https://try.gitea.io
|
||||||
|
options:
|
||||||
|
- "Yes"
|
||||||
|
- "No"
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
It's really important to provide pertinent logs
|
||||||
|
Please read https://docs.gitea.io/en-us/logging-configuration/#debugging-problems
|
||||||
|
In addition, if your problem relates to git commands set `RUN_MODE=dev` at the top of app.ini
|
||||||
|
- type: input
|
||||||
|
id: logs
|
||||||
|
attributes:
|
||||||
|
label: Log Gist
|
||||||
|
description: Please provide a gist URL of your logs, with any sensitive information (e.g. API keys) removed/hidden
|
||||||
|
- type: textarea
|
||||||
|
id: screenshots
|
||||||
|
attributes:
|
||||||
|
label: Screenshots
|
||||||
|
description: If this issue involves the Web Interface, please provide one or more screenshots
|
||||||
|
- type: input
|
||||||
|
id: git-ver
|
||||||
|
attributes:
|
||||||
|
label: Git Version
|
||||||
|
description: The version of git running on the server
|
||||||
|
- type: input
|
||||||
|
id: os-ver
|
||||||
|
attributes:
|
||||||
|
label: Operating System
|
||||||
|
description: The operating system you are using to run Gitea
|
||||||
|
- type: textarea
|
||||||
|
id: run-info
|
||||||
|
attributes:
|
||||||
|
label: How are you running Gitea?
|
||||||
|
description: |
|
||||||
|
Please include information on whether you built Gitea yourself, used one of our downloads, are using https://try.gitea.io or are using some other package
|
||||||
|
Please also tell us how you are running Gitea, e.g. if it is being run from docker, a command-line, systemd etc.
|
||||||
|
If you are using a package or systemd tell us what distribution you are using
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: dropdown
|
||||||
|
id: database
|
||||||
|
attributes:
|
||||||
|
label: Database
|
||||||
|
description: What database system are you running?
|
||||||
|
options:
|
||||||
|
- PostgreSQL
|
||||||
|
- MySQL
|
||||||
|
- MSSQL
|
||||||
|
- SQLite
|
|
@ -0,0 +1,17 @@
|
||||||
|
blank_issues_enabled: false
|
||||||
|
contact_links:
|
||||||
|
- name: Security Concern
|
||||||
|
url: https://tinyurl.com/security-gitea
|
||||||
|
about: For security concerns, please send a mail to security@gitea.io instead of opening a public issue.
|
||||||
|
- name: Discord Server
|
||||||
|
url: https://discord.gg/Gitea
|
||||||
|
about: Please ask questions and discuss configuration or deployment problems here.
|
||||||
|
- name: Discourse Forum
|
||||||
|
url: https://discourse.gitea.io
|
||||||
|
about: Questions and configuration or deployment problems can also be discussed on our forum.
|
||||||
|
- name: Frequently Asked Questions
|
||||||
|
url: https://docs.gitea.io/en-us/faq
|
||||||
|
about: Please check if your question isn't mentioned here.
|
||||||
|
- name: Crowdin Translations
|
||||||
|
url: https://crowdin.com/project/gitea
|
||||||
|
about: Translations are managed here.
|
|
@ -0,0 +1,24 @@
|
||||||
|
name: Feature Request
|
||||||
|
description: Got an idea for a feature that Gitea doesn't have currently? Submit your idea here!
|
||||||
|
labels: ["kind/feature", "kind/proposal"]
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
1. Please speak English, this is the language all maintainers can speak and write.
|
||||||
|
2. Please ask questions or configuration/deploy problems on our Discord
|
||||||
|
server (https://discord.gg/gitea) or forum (https://discourse.gitea.io).
|
||||||
|
3. Please take a moment to check that your feature hasn't already been suggested.
|
||||||
|
- type: textarea
|
||||||
|
id: description
|
||||||
|
attributes:
|
||||||
|
label: Feature Description
|
||||||
|
placeholder: |
|
||||||
|
I think it would be great if Gitea had...
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
id: screenshots
|
||||||
|
attributes:
|
||||||
|
label: Screenshots
|
||||||
|
description: If you can, provide screenshots of an implementation on another site e.g. GitHub
|
|
@ -0,0 +1,66 @@
|
||||||
|
name: Web Interface Bug Report
|
||||||
|
description: Something doesn't look quite as it should? Report it here!
|
||||||
|
labels: ["kind/bug", "kind/ui"]
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
NOTE: If your issue is a security concern, please send an email to security@gitea.io instead of opening a public issue.
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
1. Please speak English, this is the language all maintainers can speak and write.
|
||||||
|
2. Please ask questions or configuration/deploy problems on our Discord
|
||||||
|
server (https://discord.gg/gitea) or forum (https://discourse.gitea.io).
|
||||||
|
3. Please take a moment to check that your issue doesn't already exist.
|
||||||
|
4. Make sure it's not mentioned in the FAQ (https://docs.gitea.io/en-us/faq)
|
||||||
|
5. Please give all relevant information below for bug reports, because
|
||||||
|
incomplete details will be handled as an invalid report.
|
||||||
|
6. In particular it's really important to provide pertinent logs. If you are certain that this is a javascript
|
||||||
|
error, show us the javascript console. If the error appears to relate to Gitea the server you must also give us
|
||||||
|
DEBUG level logs. (See https://docs.gitea.io/en-us/logging-configuration/#debugging-problems)
|
||||||
|
- type: textarea
|
||||||
|
id: description
|
||||||
|
attributes:
|
||||||
|
label: Description
|
||||||
|
description: |
|
||||||
|
Please provide a description of your issue here, with a URL if you were able to reproduce the issue (see below)
|
||||||
|
If using a proxy or a CDN (e.g. CloudFlare) in front of gitea, please disable the proxy/CDN fully and connect to gitea directly to confirm the issue still persists without those services.
|
||||||
|
- type: textarea
|
||||||
|
id: screenshots
|
||||||
|
attributes:
|
||||||
|
label: Screenshots
|
||||||
|
description: Please provide at least 1 screenshot showing the issue.
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: input
|
||||||
|
id: gitea-ver
|
||||||
|
attributes:
|
||||||
|
label: Gitea Version
|
||||||
|
description: Gitea version (or commit reference) your instance is running
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: dropdown
|
||||||
|
id: can-reproduce
|
||||||
|
attributes:
|
||||||
|
label: Can you reproduce the bug on the Gitea demo site?
|
||||||
|
description: |
|
||||||
|
If so, please provide a URL in the Description field
|
||||||
|
URL of Gitea demo: https://try.gitea.io
|
||||||
|
options:
|
||||||
|
- "Yes"
|
||||||
|
- "No"
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: input
|
||||||
|
id: os-ver
|
||||||
|
attributes:
|
||||||
|
label: Operating System
|
||||||
|
description: The operating system you are using to access Gitea
|
||||||
|
- type: input
|
||||||
|
id: browser-ver
|
||||||
|
attributes:
|
||||||
|
label: Browser Version
|
||||||
|
description: The browser and version that you are using to access Gitea
|
||||||
|
validations:
|
||||||
|
required: true
|
|
@ -0,0 +1,23 @@
|
||||||
|
# Configuration for Lock Threads - https://github.com/dessant/lock-threads-app
|
||||||
|
|
||||||
|
# Number of days of inactivity before a closed issue or pull request is locked
|
||||||
|
daysUntilLock: 60
|
||||||
|
|
||||||
|
# Skip issues and pull requests created before a given timestamp. Timestamp must
|
||||||
|
# follow ISO 8601 (`YYYY-MM-DD`). `false` is disabled
|
||||||
|
skipCreatedBefore: false
|
||||||
|
|
||||||
|
# Issues and pull requests with these labels will be ignored.
|
||||||
|
exemptLabels: []
|
||||||
|
|
||||||
|
# Label to add before locking, such as `outdated`. `false` is disabled
|
||||||
|
lockLabel: false
|
||||||
|
|
||||||
|
# Comment to post before locking.
|
||||||
|
lockComment: >
|
||||||
|
This thread has been automatically locked since there has not been
|
||||||
|
any recent activity after it was closed. Please open a new issue for
|
||||||
|
related bugs and link to relevant comments in this thread.
|
||||||
|
|
||||||
|
# Assign `resolved` as the reason for locking. Set to `false` to disable
|
||||||
|
setLockReason: true
|
|
@ -0,0 +1,9 @@
|
||||||
|
<!--
|
||||||
|
|
||||||
|
Please check the following:
|
||||||
|
|
||||||
|
1. Make sure you are targeting the `main` branch, pull requests on release branches are only allowed for bug fixes.
|
||||||
|
2. Read contributing guidelines: https://github.com/go-gitea/gitea/blob/main/CONTRIBUTING.md
|
||||||
|
3. Describe what your pull request does and which issue you're targeting (if any)
|
||||||
|
|
||||||
|
-->
|
|
@ -0,0 +1,54 @@
|
||||||
|
# Configuration for probot-stale - https://github.com/probot/stale
|
||||||
|
|
||||||
|
# Number of days of inactivity before an Issue or Pull Request becomes stale
|
||||||
|
daysUntilStale: 60
|
||||||
|
|
||||||
|
# Number of days of inactivity before an Issue or Pull Request with the stale label is closed.
|
||||||
|
# Set to false to disable. If disabled, issues still need to be closed manually, but will remain marked as stale.
|
||||||
|
daysUntilClose: 14
|
||||||
|
|
||||||
|
# Issues or Pull Requests with these labels will never be considered stale. Set to `[]` to disable
|
||||||
|
exemptLabels:
|
||||||
|
- status/blocked
|
||||||
|
- kind/security
|
||||||
|
- lgtm/done
|
||||||
|
- reviewed/confirmed
|
||||||
|
- priority/critical
|
||||||
|
- kind/proposal
|
||||||
|
|
||||||
|
# Set to true to ignore issues in a project (defaults to false)
|
||||||
|
exemptProjects: false
|
||||||
|
|
||||||
|
# Set to true to ignore issues in a milestone (defaults to false)
|
||||||
|
exemptMilestones: false
|
||||||
|
|
||||||
|
# Label to use when marking as stale
|
||||||
|
staleLabel: stale
|
||||||
|
|
||||||
|
# Comment to post when marking as stale. Set to `false` to disable
|
||||||
|
markComment: >
|
||||||
|
This issue has been automatically marked as stale because it has not had recent activity.
|
||||||
|
I am here to help clear issues left open even if solved or waiting for more insight.
|
||||||
|
This issue will be closed if no further activity occurs during the next 2 weeks.
|
||||||
|
If the issue is still valid just add a comment to keep it alive.
|
||||||
|
Thank you for your contributions.
|
||||||
|
|
||||||
|
# Comment to post when closing a stale Issue or Pull Request.
|
||||||
|
closeComment: >
|
||||||
|
This issue has been automatically closed because of inactivity.
|
||||||
|
You can re-open it if needed.
|
||||||
|
|
||||||
|
# Limit the number of actions per hour, from 1-30. Default is 30
|
||||||
|
limitPerRun: 1
|
||||||
|
|
||||||
|
# Optionally, specify configuration settings that are specific to just 'issues' or 'pulls':
|
||||||
|
pulls:
|
||||||
|
daysUntilStale: 60
|
||||||
|
daysUntilClose: 60
|
||||||
|
markComment: >
|
||||||
|
This pull request has been automatically marked as stale because it has not had
|
||||||
|
recent activity. It will be closed if no further activity occurs during the next 2 months. Thank you
|
||||||
|
for your contributions.
|
||||||
|
closeComment: >
|
||||||
|
This pull request has been automatically closed because of inactivity.
|
||||||
|
You can re-open it if needed.
|
|
@ -1,19 +1,8 @@
|
||||||
extends: stylelint-config-standard
|
extends: stylelint-config-standard
|
||||||
|
|
||||||
plugins:
|
|
||||||
- stylelint-declaration-strict-value
|
|
||||||
|
|
||||||
overrides:
|
overrides:
|
||||||
- files: ["**/*.less"]
|
- files: ["**/*.less"]
|
||||||
customSyntax: postcss-less
|
customSyntax: postcss-less
|
||||||
- files: ["**/*.less"]
|
|
||||||
rules:
|
|
||||||
scale-unlimited/declaration-strict-value: [color, {
|
|
||||||
ignoreValues: /^(inherit|transparent|unset|initial)$/
|
|
||||||
}]
|
|
||||||
- files: ["**/chroma/*", "**/codemirror/*", "**/standalone/*", "**/console/*"]
|
|
||||||
rules:
|
|
||||||
scale-unlimited/declaration-strict-value: null
|
|
||||||
|
|
||||||
rules:
|
rules:
|
||||||
alpha-value-notation: null
|
alpha-value-notation: null
|
||||||
|
@ -27,7 +16,6 @@ rules:
|
||||||
declaration-empty-line-before: null
|
declaration-empty-line-before: null
|
||||||
function-no-unknown: null
|
function-no-unknown: null
|
||||||
hue-degree-notation: null
|
hue-degree-notation: null
|
||||||
import-notation: string
|
|
||||||
indentation: 2
|
indentation: 2
|
||||||
max-line-length: null
|
max-line-length: null
|
||||||
no-descending-specificity: null
|
no-descending-specificity: null
|
||||||
|
|
|
@ -52,12 +52,12 @@ pipeline:
|
||||||
commands:
|
commands:
|
||||||
- su gitea -c 'make unit-test-coverage test-check'
|
- su gitea -c 'make unit-test-coverage test-check'
|
||||||
|
|
||||||
test-sqlite:
|
# test-sqlite:
|
||||||
image: gitea/test_env:linux-amd64
|
# image: gitea/test_env:linux-amd64
|
||||||
environment:
|
# environment:
|
||||||
- USE_REPO_TEST_DIR=1
|
# - USE_REPO_TEST_DIR=1
|
||||||
- GOPROXY=off
|
# - GOPROXY=off
|
||||||
- TAGS=bindata gogit sqlite sqlite_unlock_notify
|
# - TAGS=bindata gogit sqlite sqlite_unlock_notify
|
||||||
- TEST_TAGS=bindata gogit sqlite sqlite_unlock_notify
|
# - TEST_TAGS=bindata gogit sqlite sqlite_unlock_notify
|
||||||
commands:
|
# commands:
|
||||||
- su gitea -c 'timeout -s ABRT 120m make test-sqlite-migration test-sqlite'
|
# - su gitea -c 'timeout -s ABRT 120m make test-sqlite-migration test-sqlite'
|
||||||
|
|
176
CHANGELOG.md
176
CHANGELOG.md
|
@ -4,6 +4,182 @@ This changelog goes through all the changes that have been made in each release
|
||||||
without substantial changes to our git log; to see the highlights of what has
|
without substantial changes to our git log; to see the highlights of what has
|
||||||
been added to each release, please refer to the [blog](https://blog.gitea.io).
|
been added to each release, please refer to the [blog](https://blog.gitea.io).
|
||||||
|
|
||||||
|
## [1.18.0-rc1](https://github.com/go-gitea/gitea/releases/tag/v1.18.0-rc1) - 2022-11-15
|
||||||
|
|
||||||
|
* BREAKING
|
||||||
|
* Remove U2F support (#20141)
|
||||||
|
* FEATURES
|
||||||
|
* Add color previews in markdown (#21474)
|
||||||
|
* Allow package version sorting (#21453)
|
||||||
|
* Add support for Chocolatey/NuGet v2 API (#21393)
|
||||||
|
* Add API endpoint to get changed files of a PR (#21177)
|
||||||
|
* Add filetree on left of diff view (#21012)
|
||||||
|
* Support Issue forms and PR forms (#20987)
|
||||||
|
* Add support for Vagrant packages (#20930)
|
||||||
|
* Add support for `npm unpublish` (#20688)
|
||||||
|
* Add badge capabilities to users (#20607)
|
||||||
|
* Add issue filter for Author (#20578)
|
||||||
|
* Add KaTeX rendering to Markdown. (#20571)
|
||||||
|
* Add support for Pub packages (#20560)
|
||||||
|
* Support localized README (#20508)
|
||||||
|
* Add support mCaptcha as captcha provider (#20458)
|
||||||
|
* Add team member invite by email (#20307)
|
||||||
|
* Added email notification option to receive all own messages (#20179)
|
||||||
|
* Switch Unicode Escaping to a VSCode-like system (#19990)
|
||||||
|
* Add user/organization code search (#19977)
|
||||||
|
* Only show relevant repositories on explore page (#19361)
|
||||||
|
* User keypairs and HTTP signatures for ActivityPub federation using go-ap (#19133)
|
||||||
|
* Add sitemap support (#18407)
|
||||||
|
* Allow creation of OAuth2 applications for orgs (#18084)
|
||||||
|
* Add system setting table with cache and also add cache supports for user setting (#18058)
|
||||||
|
* Add pages to view watched repos and subscribed issues/PRs (#17156)
|
||||||
|
* Support Proxy protocol (#12527)
|
||||||
|
* Implement sync push mirror on commit (#19411)
|
||||||
|
* API
|
||||||
|
* Make external issue tracker regexp configurable via API (#21338)
|
||||||
|
* Add name field for org api (#21270)
|
||||||
|
* Show teams with no members if user is admin (#21204)
|
||||||
|
* Add latest commit's SHA to content response (#20398)
|
||||||
|
* Add allow_rebase_update, default_delete_branch_after_merge to repository api response (#20079)
|
||||||
|
* Add new endpoints for push mirrors management (#19841)
|
||||||
|
* ENHANCEMENTS
|
||||||
|
* Use CSS color-scheme instead of invert (#21616) (#21623)
|
||||||
|
* Respect user's locale when rendering the date range in the repo activity page (#21410)
|
||||||
|
* Change `commits-table` column width (#21564)
|
||||||
|
* Refactor git command arguments and make all arguments to be safe to be used (#21535)
|
||||||
|
* CSS color enhancements (#21534)
|
||||||
|
* Add link to user profile in markdown mention only if user exists (#21533, #21554)
|
||||||
|
* Add option to skip index dirs (#21501)
|
||||||
|
* Diff file tree tweaks (#21446)
|
||||||
|
* Localize all timestamps (#21440)
|
||||||
|
* Add `code` highlighting in issue titles (#21432)
|
||||||
|
* Use Name instead of DisplayName in LFS Lock (#21415)
|
||||||
|
* Consolidate more CSS colors into variables (#21402)
|
||||||
|
* Redirect to new repository owner (#21398)
|
||||||
|
* Use ISO date format instead of hard-coded English date format for date range in repo activity page (#21396)
|
||||||
|
* Use weighted algorithm for string matching when finding files in repo (#21370)
|
||||||
|
* Show private data in feeds (#21369)
|
||||||
|
* Refactor parseTreeEntries, speed up tree list (#21368)
|
||||||
|
* Add GET and DELETE endpoints for Docker blob uploads (#21367)
|
||||||
|
* Add nicer error handling on template compile errors (#21350)
|
||||||
|
* Add `stat` to `ToCommit` function for speed (#21337)
|
||||||
|
* Support instance-wide OAuth2 applications (#21335)
|
||||||
|
* Record OAuth client type at registration (#21316)
|
||||||
|
* Add new CSS variables --color-accent and --color-small-accent (#21305)
|
||||||
|
* Improve error descriptions for unauthorized_client (#21292)
|
||||||
|
* Case-insensitive "find files in repo" (#21269)
|
||||||
|
* Consolidate more CSS rules, fix inline code on arc-green (#21260)
|
||||||
|
* Log real ip of requests from ssh (#21216)
|
||||||
|
* Save files in local storage as group readable (#21198)
|
||||||
|
* Enable fluid page layout on medium size viewports (#21178)
|
||||||
|
* File header tweaks (#21175)
|
||||||
|
* Added missing headers on user packages page (#21172)
|
||||||
|
* Display image digest for container packages (#21170)
|
||||||
|
* Skip dirty check for team forms (#21154)
|
||||||
|
* Keep path when creating a new branch (#21153)
|
||||||
|
* Remove fomantic image module (#21145)
|
||||||
|
* Make labels clickable in the comments section. (#21137)
|
||||||
|
* Sort branches and tags by date descending (#21136)
|
||||||
|
* Better repo API unit checks (#21130)
|
||||||
|
* Improve commit status icons (#21124)
|
||||||
|
* Limit length of repo description and repo url input fields (#21119)
|
||||||
|
* Show .editorconfig errors in frontend (#21088)
|
||||||
|
* Allow poster to choose reviewers (#21084)
|
||||||
|
* Remove black labels and CSS cleanup (#21003)
|
||||||
|
* Make e-mail sanity check more precise (#20991)
|
||||||
|
* Use native inputs in whitespace dropdown (#20980)
|
||||||
|
* Enhance package date display (#20928)
|
||||||
|
* Display total blob size of a package version (#20927)
|
||||||
|
* Show language name on hover (#20923)
|
||||||
|
* Show instructions for all generic package files (#20917)
|
||||||
|
* Refactor AssertExistsAndLoadBean to use generics (#20797)
|
||||||
|
* Move the official website link at the footer of gitea (#20777)
|
||||||
|
* Add support for full name in reverse proxy auth (#20776)
|
||||||
|
* Remove useless JS operation for relative time tooltips (#20756)
|
||||||
|
* Replace some icons with SVG (#20741)
|
||||||
|
* Change commit status icons to SVG (#20736)
|
||||||
|
* Improve single repo action for issue and pull requests (#20730)
|
||||||
|
* Allow multiple files in generic packages (#20661)
|
||||||
|
* Add option to create new issue from /issues page (#20650)
|
||||||
|
* Background color of private list-items updated (#20630)
|
||||||
|
* Added search input field to issue filter (#20623)
|
||||||
|
* Increase default item listing size `ISSUE_PAGING_NUM` to 20 (#20547)
|
||||||
|
* Modify milestone search keywords to be case insensitive again (#20513)
|
||||||
|
* Show hint to link package to repo when viewing empty repo package list (#20504)
|
||||||
|
* Add Tar ZSTD support (#20493)
|
||||||
|
* Make code review checkboxes clickable (#20481)
|
||||||
|
* Add "X-Gitea-Object-Type" header for GET `/raw/` & `/media/` API (#20438)
|
||||||
|
* Display project in issue list (#20434)
|
||||||
|
* Prepend commit message to template content when opening a new PR (#20429)
|
||||||
|
* Replace fomantic popup module with tippy.js (#20428)
|
||||||
|
* Allow to specify colors for text in markup (#20363)
|
||||||
|
* Allow access to the Public Organization Member lists with minimal permissions (#20330)
|
||||||
|
* Use default values when provided values are empty (#20318)
|
||||||
|
* Vertical align navbar avatar at middle (#20302)
|
||||||
|
* Delete cancel button in repo creation page (#21381)
|
||||||
|
* Include login_name in adminCreateUser response (#20283)
|
||||||
|
* fix: icon margin in user/settings/repos (#20281)
|
||||||
|
* Remove blue text on migrate page (#20273)
|
||||||
|
* Modify milestone search keywords to be case insensitive (#20266)
|
||||||
|
* Move some files into models' sub packages (#20262)
|
||||||
|
* Add tooltip to repo icons in explore page (#20241)
|
||||||
|
* Remove deprecated licenses (#20222)
|
||||||
|
* Webhook for Wiki changes (#20219)
|
||||||
|
* Share HTML template renderers and create a watcher framework (#20218)
|
||||||
|
* Allow enable LDAP source and disable user sync via CLI (#20206)
|
||||||
|
* Adds a checkbox to select all issues/PRs (#20177)
|
||||||
|
* Refactor `i18n` to `locale` (#20153)
|
||||||
|
* Disable status checks in template if none found (#20088)
|
||||||
|
* Allow manager logging to set SQL (#20064)
|
||||||
|
* Add order by for assignee no sort issue (#20053)
|
||||||
|
* Take a stab at porting existing components to Vue3 (#20044)
|
||||||
|
* Add doctor command to write commit-graphs (#20007)
|
||||||
|
* Add support for authentication based on reverse proxy email (#19949)
|
||||||
|
* Enable spellcheck for EasyMDE, use contenteditable mode (#19776)
|
||||||
|
* Allow specifying SECRET_KEY_URI, similar to INTERNAL_TOKEN_URI (#19663)
|
||||||
|
* Rework mailer settings (#18982)
|
||||||
|
* Add option to purge users (#18064)
|
||||||
|
* Add author search input (#21246)
|
||||||
|
* Make rss/atom identifier globally unique (#21550)
|
||||||
|
* BUGFIXES
|
||||||
|
* Prevent panic in doctor command when running default checks (#21791) (#21807)
|
||||||
|
* Load GitRepo in API before deleting issue (#21720) (#21796)
|
||||||
|
* Ignore line anchor links with leading zeroes (#21728) (#21776)
|
||||||
|
* Set last login when activating account (#21731) (#21755)
|
||||||
|
* Fix UI language switching bug (#21597) (#21749)
|
||||||
|
* Quick fixes monaco-editor error: "vs.editor.nullLanguage" (#21734) (#21738)
|
||||||
|
* Allow local package identifiers for PyPI packages (#21690) (#21727)
|
||||||
|
* Deal with markdown template without metadata (#21639) (#21654)
|
||||||
|
* Fix opaque background on mermaid diagrams (#21642) (#21652)
|
||||||
|
* Fix repository adoption on Windows (#21646) (#21650)
|
||||||
|
* Sync git hooks when config file path changed (#21619) (#21626)
|
||||||
|
* Fix 500 on PR files API (#21602) (#21607)
|
||||||
|
* Fix `Timestamp.IsZero` (#21593) (#21603)
|
||||||
|
* Fix viewing user subscriptions (#21482)
|
||||||
|
* Fix mermaid-related bugs (#21431)
|
||||||
|
* Fix branch dropdown shifting on page load (#21428)
|
||||||
|
* Fix default theme-auto selector when nologin (#21346)
|
||||||
|
* Fix and improve incorrect error messages (#21342)
|
||||||
|
* Fix formatted link for PR review notifications to matrix (#21319)
|
||||||
|
* Center-aligning content of WebAuthN page (#21127)
|
||||||
|
* Remove follow from commits by file (#20765)
|
||||||
|
* Fix commit status popup (#20737)
|
||||||
|
* Fix init mail render logic (#20704)
|
||||||
|
* Use correct page size for link header pagination (#20546)
|
||||||
|
* Preserve unix socket file (#20499)
|
||||||
|
* Use tippy.js for context popup (#20393)
|
||||||
|
* Add missing parameter for error in log message (#20144)
|
||||||
|
* Do not allow organisation owners add themselves as collaborator (#20043)
|
||||||
|
* Rework file highlight rendering and fix yaml copy-paste (#19967)
|
||||||
|
* Improve code diff highlight, fix incorrect rendered diff result (#19958)
|
||||||
|
* TESTING
|
||||||
|
* Improve OAuth integration tests (#21390)
|
||||||
|
* Add playwright tests (#20123)
|
||||||
|
* BUILD
|
||||||
|
* Switch to building with go1.19 (#20695)
|
||||||
|
* Update JS dependencies, adjust eslint (#20659)
|
||||||
|
* Add more linters to improve code readability (#19989)
|
||||||
|
|
||||||
## [1.17.3](https://github.com/go-gitea/gitea/releases/tag/v1.17.3) - 2022-10-15
|
## [1.17.3](https://github.com/go-gitea/gitea/releases/tag/v1.17.3) - 2022-10-15
|
||||||
|
|
||||||
* SECURITY
|
* SECURITY
|
||||||
|
|
454
CONTRIBUTING.md
454
CONTRIBUTING.md
|
@ -1,23 +1,449 @@
|
||||||
# Forgejo Contributor Guide
|
# Contribution Guidelines
|
||||||
|
|
||||||
The Forgejo project is run by a community of people who are expected to follow this guide when cooperating on a simple bug fix as well as when changing the governance. For more information about the project, take a look at [the documentation explaining what Forgejo provides](README.md).
|
## Table of Contents
|
||||||
|
|
||||||
Sensitive security-related issues should be reported to [security@forgejo.org](mailto:security@forgejo.org) using [encryption](https://keyoxide.org/security@forgejo.org).
|
- [Contribution Guidelines](#contribution-guidelines)
|
||||||
|
- [Table of Contents](#table-of-contents)
|
||||||
|
- [Introduction](#introduction)
|
||||||
|
- [Bug reports](#bug-reports)
|
||||||
|
- [Discuss your design](#discuss-your-design)
|
||||||
|
- [Testing redux](#testing-redux)
|
||||||
|
- [Vendoring](#vendoring)
|
||||||
|
- [Translation](#translation)
|
||||||
|
- [Building Gitea](#building-gitea)
|
||||||
|
- [Code review](#code-review)
|
||||||
|
- [Styleguide](#styleguide)
|
||||||
|
- [Design guideline](#design-guideline)
|
||||||
|
- [API v1](#api-v1)
|
||||||
|
- [Developer Certificate of Origin (DCO)](#developer-certificate-of-origin-dco)
|
||||||
|
- [Release Cycle](#release-cycle)
|
||||||
|
- [Maintainers](#maintainers)
|
||||||
|
- [Owners](#owners)
|
||||||
|
- [Versions](#versions)
|
||||||
|
- [Releasing Gitea](#releasing-gitea)
|
||||||
|
- [Copyright](#copyright)
|
||||||
|
|
||||||
## For everyone involved
|
## Introduction
|
||||||
|
|
||||||
- [Code of Conduct](CONTRIBUTING/COC.md)
|
This document explains how to contribute changes to the Gitea project.
|
||||||
- [Bugs, features, security and others discussions](CONTRIBUTING/DISCUSSIONS.md)
|
It assumes you have followed the
|
||||||
- [Governance](CONTRIBUTING/GOVERNANCE.md)
|
[installation instructions](https://docs.gitea.io/en-us/).
|
||||||
- [Funding](CONTRIBUTING/FUNDING.md)
|
Sensitive security-related issues should be reported to
|
||||||
|
[security@gitea.io](mailto:security@gitea.io).
|
||||||
|
|
||||||
## For contributors
|
For configuring IDE or code editor to develop Gitea see [IDE and code editor configuration](contrib/ide/)
|
||||||
|
|
||||||
- [Developer Certificate of Origin (DCO)](CONTRIBUTING/DCO.md)
|
## Bug reports
|
||||||
- [Development workflow](CONTRIBUTING/WORKFLOW.md)
|
|
||||||
|
|
||||||
## For maintainers
|
Please search the issues on the issue tracker with a variety of keywords
|
||||||
|
to ensure your bug is not already reported.
|
||||||
|
|
||||||
- [Release management](CONTRIBUTING/RELEASE.md)
|
If unique, [open an issue](https://github.com/go-gitea/gitea/issues/new)
|
||||||
- [Secrets](CONTRIBUTING/SECRETS.md)
|
and answer the questions so we can understand and reproduce the
|
||||||
|
problematic behavior.
|
||||||
|
|
||||||
|
To show us that the issue you are having is in Gitea itself, please
|
||||||
|
write clear, concise instructions so we can reproduce the behavior—
|
||||||
|
even if it seems obvious. The more detailed and specific you are,
|
||||||
|
the faster we can fix the issue. Check out [How to Report Bugs
|
||||||
|
Effectively](http://www.chiark.greenend.org.uk/~sgtatham/bugs.html).
|
||||||
|
|
||||||
|
Please be kind, remember that Gitea comes at no cost to you, and you're
|
||||||
|
getting free help.
|
||||||
|
|
||||||
|
## Discuss your design
|
||||||
|
|
||||||
|
The project welcomes submissions. If you want to change or add something,
|
||||||
|
please let everyone know what you're working on—[file an issue](https://github.com/go-gitea/gitea/issues/new)!
|
||||||
|
Significant changes must go through the change proposal process
|
||||||
|
before they can be accepted. To create a proposal, file an issue with
|
||||||
|
your proposed changes documented, and make sure to note in the title
|
||||||
|
of the issue that it is a proposal.
|
||||||
|
|
||||||
|
This process gives everyone a chance to validate the design, helps
|
||||||
|
prevent duplication of effort, and ensures that the idea fits inside
|
||||||
|
the goals for the project and tools. It also checks that the design is
|
||||||
|
sound before code is written; the code review tool is not the place for
|
||||||
|
high-level discussions.
|
||||||
|
|
||||||
|
## Testing redux
|
||||||
|
|
||||||
|
Before submitting a pull request, run all the tests for the whole tree
|
||||||
|
to make sure your changes don't cause regression elsewhere.
|
||||||
|
|
||||||
|
Here's how to run the test suite:
|
||||||
|
|
||||||
|
- code lint
|
||||||
|
|
||||||
|
| | |
|
||||||
|
| :-------------------- | :---------------------------------------------------------------- |
|
||||||
|
|``make lint`` | lint everything (not suggest if you only change one type code) |
|
||||||
|
|``make lint-frontend`` | lint frontend files |
|
||||||
|
|``make lint-backend`` | lint backend files |
|
||||||
|
|
||||||
|
- run test code (Suggest run in Linux)
|
||||||
|
|
||||||
|
| | |
|
||||||
|
| :------------------------------------- | :----------------------------------------------- |
|
||||||
|
|``make test[\#TestSpecificName]`` | run unit test |
|
||||||
|
|``make test-sqlite[\#TestSpecificName]``| run [integration](tests/integration) test for SQLite |
|
||||||
|
|[More details about integration tests](tests/integration/README.md) |
|
||||||
|
|``make test-e2e-sqlite[\#TestSpecificFileName]``| run [end-to-end](tests/e2e) test for SQLite |
|
||||||
|
|[More details about e2e tests](tests/e2e/README.md) |
|
||||||
|
|
||||||
|
## Vendoring
|
||||||
|
|
||||||
|
We manage dependencies via [Go Modules](https://golang.org/cmd/go/#hdr-Module_maintenance), more details: [go mod](https://go.dev/ref/mod).
|
||||||
|
|
||||||
|
Pull requests should only include `go.mod`, `go.sum` updates if they are part of
|
||||||
|
the same change, be it a bugfix or a feature addition.
|
||||||
|
|
||||||
|
The `go.mod`, `go.sum` update needs to be justified as part of the PR description,
|
||||||
|
and must be verified by the reviewers and/or merger to always reference
|
||||||
|
an existing upstream commit.
|
||||||
|
|
||||||
|
You can find more information on how to get started with it on the [Modules Wiki](https://github.com/golang/go/wiki/Modules).
|
||||||
|
|
||||||
|
## Translation
|
||||||
|
|
||||||
|
We do all translation work inside [Crowdin](https://crowdin.com/project/gitea).
|
||||||
|
The only translation that is maintained in this Git repository is
|
||||||
|
[`en_US.ini`](https://github.com/go-gitea/gitea/blob/master/options/locale/locale_en-US.ini)
|
||||||
|
and is synced regularly to Crowdin. Once a translation has reached
|
||||||
|
A SATISFACTORY PERCENTAGE it will be synced back into this repo and
|
||||||
|
included in the next released version.
|
||||||
|
|
||||||
|
## Building Gitea
|
||||||
|
|
||||||
|
See the [hacking instructions](https://docs.gitea.io/en-us/hacking-on-gitea/).
|
||||||
|
|
||||||
|
## Code review
|
||||||
|
|
||||||
|
Changes to Gitea must be reviewed before they are accepted—no matter who
|
||||||
|
makes the change, even if they are an owner or a maintainer. We use GitHub's
|
||||||
|
pull request workflow to do that. And, we also use [LGTM](http://lgtm.co)
|
||||||
|
to ensure every PR is reviewed by at least 2 maintainers.
|
||||||
|
|
||||||
|
Please try to make your pull request easy to review for us. And, please read
|
||||||
|
the *[How to get faster PR reviews](https://github.com/kubernetes/community/blob/261cb0fd089b64002c91e8eddceebf032462ccd6/contributors/guide/pull-requests.md#best-practices-for-faster-reviews)* guide;
|
||||||
|
it has lots of useful tips for any project you may want to contribute.
|
||||||
|
Some of the key points:
|
||||||
|
|
||||||
|
- Make small pull requests. The smaller, the faster to review and the
|
||||||
|
more likely it will be merged soon.
|
||||||
|
- Don't make changes unrelated to your PR. Maybe there are typos on
|
||||||
|
some comments, maybe refactoring would be welcome on a function... but
|
||||||
|
if that is not related to your PR, please make *another* PR for that.
|
||||||
|
- Split big pull requests into multiple small ones. An incremental change
|
||||||
|
will be faster to review than a huge PR.
|
||||||
|
- Use the first comment as a summary explainer of your PR and you should keep this up-to-date as the PR evolves.
|
||||||
|
|
||||||
|
If your PR could cause a breaking change you must add a BREAKING section to this comment e.g.:
|
||||||
|
|
||||||
|
```
|
||||||
|
## :warning: BREAKING :warning:
|
||||||
|
```
|
||||||
|
|
||||||
|
To explain how this could affect users and how to mitigate these changes.
|
||||||
|
|
||||||
|
Once code review starts on your PR, do not rebase nor squash your branch as it makes it
|
||||||
|
difficult to review the new changes. Only if there is a need, sync your branch by merging
|
||||||
|
the base branch into yours. Don't worry about merge commits messing up your tree as
|
||||||
|
the final merge process squashes all commits into one, with the visible commit message (first
|
||||||
|
line) being the PR title + PR index and description being the PR's first comment.
|
||||||
|
|
||||||
|
Once your PR gets the `lgtm/done` label, don't worry about keeping it up-to-date or breaking
|
||||||
|
builds (unless there's a merge conflict or a request is made by a maintainer to make
|
||||||
|
modifications). It is the maintainer team's responsibility from this point to get it merged.
|
||||||
|
|
||||||
|
## Styleguide
|
||||||
|
|
||||||
|
For imports you should use the following format (*without* the comments)
|
||||||
|
|
||||||
|
```go
|
||||||
|
import (
|
||||||
|
// stdlib
|
||||||
|
"fmt"
|
||||||
|
"math"
|
||||||
|
|
||||||
|
// local packages
|
||||||
|
"code.gitea.io/gitea/models"
|
||||||
|
"code.gitea.io/sdk/gitea"
|
||||||
|
|
||||||
|
// external packages
|
||||||
|
"github.com/foo/bar"
|
||||||
|
"gopkg.io/baz.v1"
|
||||||
|
)
|
||||||
|
```
|
||||||
|
|
||||||
|
## Design guideline
|
||||||
|
|
||||||
|
To maintain understandable code and avoid circular dependencies it is important to have a good structure of the code. The Gitea code is divided into the following parts:
|
||||||
|
|
||||||
|
- **models:** Contains the data structures used by xorm to construct database tables. It also contains supporting functions to query and update the database. Dependencies to other code in Gitea should be avoided although some modules might be needed (for example for logging).
|
||||||
|
- **models/fixtures:** Sample model data used in integration tests.
|
||||||
|
- **models/migrations:** Handling of database migrations between versions. PRs that changes a database structure shall also have a migration step.
|
||||||
|
- **modules:** Different modules to handle specific functionality in Gitea. Shall only depend on other modules but not other packages (models, services).
|
||||||
|
- **public:** Frontend files (javascript, images, css, etc.)
|
||||||
|
- **routers:** Handling of server requests. As it uses other Gitea packages to serve the request, other packages (models, modules or services) shall not depend on routers.
|
||||||
|
- **services:** Support functions for common routing operations. Uses models and modules to handle the request.
|
||||||
|
- **templates:** Golang templates for generating the html output.
|
||||||
|
- **tests/e2e:** End to end tests
|
||||||
|
- **tests/integration:** Integration tests
|
||||||
|
- **vendor:** External code that Gitea depends on.
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
If you add a new feature or change an existing aspect of Gitea, the documentation for that feature must be created or updated.
|
||||||
|
|
||||||
|
## API v1
|
||||||
|
|
||||||
|
The API is documented by [swagger](http://try.gitea.io/api/swagger) and is based on [GitHub API v3](https://developer.github.com/v3/).
|
||||||
|
|
||||||
|
Thus, Gitea´s API should use the same endpoints and fields as GitHub´s API as far as possible, unless there are good reasons to deviate.
|
||||||
|
|
||||||
|
If Gitea provides functionality that GitHub does not, a new endpoint can be created.
|
||||||
|
|
||||||
|
If information is provided by Gitea that is not provided by the GitHub API, a new field can be used that doesn't collide with any GitHub fields.
|
||||||
|
|
||||||
|
Updating an existing API should not remove existing fields unless there is a really good reason to do so.
|
||||||
|
|
||||||
|
The same applies to status responses. If you notice a problem, feel free to leave a comment in the code for future refactoring to APIv2 (which is currently not planned).
|
||||||
|
|
||||||
|
All expected results (errors, success, fail messages) should be documented
|
||||||
|
([example](https://github.com/go-gitea/gitea/blob/c620eb5b2d0d874da68ebd734d3864c5224f71f7/routers/api/v1/repo/issue.go#L319-L327)).
|
||||||
|
|
||||||
|
All JSON input types must be defined as a struct in [modules/structs/](modules/structs/)
|
||||||
|
([example](https://github.com/go-gitea/gitea/blob/c620eb5b2d0d874da68ebd734d3864c5224f71f7/modules/structs/issue.go#L76-L91))
|
||||||
|
and referenced in
|
||||||
|
[routers/api/v1/swagger/options.go](https://github.com/go-gitea/gitea/blob/c620eb5b2d0d874da68ebd734d3864c5224f71f7/routers/api/v1/swagger/options.go).
|
||||||
|
|
||||||
|
They can then be used like the following:
|
||||||
|
([example](https://github.com/go-gitea/gitea/blob/c620eb5b2d0d874da68ebd734d3864c5224f71f7/routers/api/v1/repo/issue.go#L318)).
|
||||||
|
|
||||||
|
All JSON responses must be defined as a struct in [modules/structs/](modules/structs/)
|
||||||
|
([example](https://github.com/go-gitea/gitea/blob/c620eb5b2d0d874da68ebd734d3864c5224f71f7/modules/structs/issue.go#L36-L68))
|
||||||
|
and referenced in its category in [routers/api/v1/swagger/](routers/api/v1/swagger/)
|
||||||
|
([example](https://github.com/go-gitea/gitea/blob/c620eb5b2d0d874da68ebd734d3864c5224f71f7/routers/api/v1/swagger/issue.go#L11-L16))
|
||||||
|
|
||||||
|
They can be used like the following:
|
||||||
|
([example](https://github.com/go-gitea/gitea/blob/c620eb5b2d0d874da68ebd734d3864c5224f71f7/routers/api/v1/repo/issue.go#L277-L279))
|
||||||
|
|
||||||
|
In general, HTTP methods are chosen as follows:
|
||||||
|
|
||||||
|
- **GET** endpoints return requested object and status **OK (200)**
|
||||||
|
- **DELETE** endpoints return status **No Content (204)**
|
||||||
|
- **POST** endpoints return status **Created (201)**, used to **create** new objects (e.g. a User)
|
||||||
|
- **PUT** endpoints return status **No Content (204)**, used to **add/assign** existing Objects (e.g. User) to something (e.g. Org-Team)
|
||||||
|
- **PATCH** endpoints return changed object and status **OK (200)**, used to **edit/change** an existing object
|
||||||
|
|
||||||
|
An endpoint which changes/edits an object expects all fields to be optional (except ones to identify the object, which are required).
|
||||||
|
|
||||||
|
### Endpoints returning lists should
|
||||||
|
|
||||||
|
- support pagination (`page` & `limit` options in query)
|
||||||
|
- set `X-Total-Count` header via **SetTotalCountHeader** ([example](https://github.com/go-gitea/gitea/blob/7aae98cc5d4113f1e9918b7ee7dd09f67c189e3e/routers/api/v1/repo/issue.go#L444))
|
||||||
|
|
||||||
|
## Backports and Frontports
|
||||||
|
|
||||||
|
Occasionally backports of PRs are required.
|
||||||
|
|
||||||
|
The backported PR title should be:
|
||||||
|
|
||||||
|
```
|
||||||
|
Title of backported PR (#ORIGINAL_PR_NUMBER)
|
||||||
|
```
|
||||||
|
|
||||||
|
The first two lines of the summary of the backporting PR should be:
|
||||||
|
|
||||||
|
```
|
||||||
|
Backport #ORIGINAL_PR_NUMBER
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
with the rest of the summary matching the original PR. Similarly for frontports
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
The below is a script that may be helpful in creating backports. YMMV.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
#!/bin/sh
|
||||||
|
PR="$1"
|
||||||
|
SHA="$2"
|
||||||
|
VERSION="$3"
|
||||||
|
|
||||||
|
if [ -z "$SHA" ]; then
|
||||||
|
SHA=$(gh api /repos/go-gitea/gitea/pulls/$PR -q '.merge_commit_sha')
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$VERSION" ]; then
|
||||||
|
VERSION="v1.16"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo git checkout origin/release/"$VERSION" -b backport-$PR-$VERSION
|
||||||
|
git checkout origin/release/"$VERSION" -b backport-$PR-$VERSION
|
||||||
|
git cherry-pick $SHA && git commit --amend && git push zeripath backport-$PR-$VERSION && xdg-open https://github.com/go-gitea/gitea/compare/release/"$VERSION"...zeripath:backport-$PR-$VERSION
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
## Developer Certificate of Origin (DCO)
|
||||||
|
|
||||||
|
We consider the act of contributing to the code by submitting a Pull
|
||||||
|
Request as the "Sign off" or agreement to the certifications and terms
|
||||||
|
of the [DCO](DCO) and [MIT license](LICENSE). No further action is required.
|
||||||
|
Additionally you could add a line at the end of your commit message.
|
||||||
|
|
||||||
|
```
|
||||||
|
Signed-off-by: Joe Smith <joe.smith@email.com>
|
||||||
|
```
|
||||||
|
|
||||||
|
If you set your `user.name` and `user.email` Git configs, you can add the
|
||||||
|
line to the end of your commit automatically with `git commit -s`.
|
||||||
|
|
||||||
|
We assume in good faith that the information you provide is legally binding.
|
||||||
|
|
||||||
|
## Release Cycle
|
||||||
|
|
||||||
|
We adopted a release schedule to streamline the process of working
|
||||||
|
on, finishing, and issuing releases. The overall goal is to make a
|
||||||
|
minor release every three or four months, which breaks down into two or three months of
|
||||||
|
general development followed by one month of testing and polishing
|
||||||
|
known as the release freeze. All the feature pull requests should be
|
||||||
|
merged before feature freeze. And, during the frozen period, a corresponding
|
||||||
|
release branch is open for fixes backported from main branch. Release candidates
|
||||||
|
are made during this period for user testing to
|
||||||
|
obtain a final version that is maintained in this branch. A release is
|
||||||
|
maintained by issuing patch releases to only correct critical problems
|
||||||
|
such as crashes or security issues.
|
||||||
|
|
||||||
|
Major release cycles are seasonal. They always begin on the 25th and end on
|
||||||
|
the 24th (i.e., the 25th of December to March 24th).
|
||||||
|
|
||||||
|
During a development cycle, we may also publish any necessary minor releases
|
||||||
|
for the previous version. For example, if the latest, published release is
|
||||||
|
v1.2, then minor changes for the previous release—e.g., v1.1.0 -> v1.1.1—are
|
||||||
|
still possible.
|
||||||
|
|
||||||
|
## Maintainers
|
||||||
|
|
||||||
|
To make sure every PR is checked, we have [team
|
||||||
|
maintainers](MAINTAINERS). Every PR **MUST** be reviewed by at least
|
||||||
|
two maintainers (or owners) before it can get merged. A maintainer
|
||||||
|
should be a contributor of Gitea (or Gogs) and contributed at least
|
||||||
|
4 accepted PRs. A contributor should apply as a maintainer in the
|
||||||
|
[Discord](https://discord.gg/NsatcWJ) #develop channel. The owners
|
||||||
|
or the team maintainers may invite the contributor. A maintainer
|
||||||
|
should spend some time on code reviews. If a maintainer has no
|
||||||
|
time to do that, they should apply to leave the maintainers team
|
||||||
|
and we will give them the honor of being a member of the [advisors
|
||||||
|
team](https://github.com/orgs/go-gitea/teams/advisors). Of course, if
|
||||||
|
an advisor has time to code review, we will gladly welcome them back
|
||||||
|
to the maintainers team. If a maintainer is inactive for more than 3
|
||||||
|
months and forgets to leave the maintainers team, the owners may move
|
||||||
|
him or her from the maintainers team to the advisors team.
|
||||||
|
For security reasons, Maintainers should use 2FA for their accounts and
|
||||||
|
if possible provide GPG signed commits.
|
||||||
|
https://help.github.com/articles/securing-your-account-with-two-factor-authentication-2fa/
|
||||||
|
https://help.github.com/articles/signing-commits-with-gpg/
|
||||||
|
|
||||||
|
## Owners
|
||||||
|
|
||||||
|
Since Gitea is a pure community organization without any company support,
|
||||||
|
to keep the development healthy we will elect three owners every year. All
|
||||||
|
contributors may vote to elect up to three candidates, one of which will
|
||||||
|
be the main owner, and the other two the assistant owners. When the new
|
||||||
|
owners have been elected, the old owners will give up ownership to the
|
||||||
|
newly elected owners. If an owner is unable to do so, the other owners
|
||||||
|
will assist in ceding ownership to the newly elected owners.
|
||||||
|
For security reasons, Owners or any account with write access (like a bot)
|
||||||
|
must use 2FA.
|
||||||
|
https://help.github.com/articles/securing-your-account-with-two-factor-authentication-2fa/
|
||||||
|
|
||||||
|
After the election, the new owners should proactively agree
|
||||||
|
with our [CONTRIBUTING](CONTRIBUTING.md) requirements in the
|
||||||
|
[Discord](https://discord.gg/NsatcWJ) #general channel. Below are the
|
||||||
|
words to speak:
|
||||||
|
|
||||||
|
```
|
||||||
|
I'm honored to having been elected an owner of Gitea, I agree with
|
||||||
|
[CONTRIBUTING](CONTRIBUTING.md). I will spend part of my time on Gitea
|
||||||
|
and lead the development of Gitea.
|
||||||
|
```
|
||||||
|
|
||||||
|
To honor the past owners, here's the history of the owners and the time
|
||||||
|
they served:
|
||||||
|
|
||||||
|
- 2022-01-01 ~ 2022-12-31 - https://github.com/go-gitea/gitea/issues/17872
|
||||||
|
- [Lunny Xiao](https://gitea.com/lunny) <xiaolunwen@gmail.com>
|
||||||
|
- [Matti Ranta](https://gitea.com/techknowlogick) <techknowlogick@gitea.io>
|
||||||
|
- [Andrew Thornton](https://gitea.com/zeripath) <art27@cantab.net>
|
||||||
|
|
||||||
|
- 2021-01-01 ~ 2021-12-31 - https://github.com/go-gitea/gitea/issues/13801
|
||||||
|
- [Lunny Xiao](https://gitea.com/lunny) <xiaolunwen@gmail.com>
|
||||||
|
- [Lauris Bukšis-Haberkorns](https://gitea.com/lafriks) <lauris@nix.lv>
|
||||||
|
- [Matti Ranta](https://gitea.com/techknowlogick) <techknowlogick@gitea.io>
|
||||||
|
|
||||||
|
- 2020-01-01 ~ 2020-12-31 - https://github.com/go-gitea/gitea/issues/9230
|
||||||
|
- [Lunny Xiao](https://gitea.com/lunny) <xiaolunwen@gmail.com>
|
||||||
|
- [Lauris Bukšis-Haberkorns](https://gitea.com/lafriks) <lauris@nix.lv>
|
||||||
|
- [Matti Ranta](https://gitea.com/techknowlogick) <techknowlogick@gitea.io>
|
||||||
|
|
||||||
|
- 2019-01-01 ~ 2019-12-31 - https://github.com/go-gitea/gitea/issues/5572
|
||||||
|
- [Lunny Xiao](https://github.com/lunny) <xiaolunwen@gmail.com>
|
||||||
|
- [Lauris Bukšis-Haberkorns](https://github.com/lafriks) <lauris@nix.lv>
|
||||||
|
- [Matti Ranta](https://github.com/techknowlogick) <techknowlogick@gitea.io>
|
||||||
|
|
||||||
|
- 2018-01-01 ~ 2018-12-31 - https://github.com/go-gitea/gitea/issues/3255
|
||||||
|
- [Lunny Xiao](https://github.com/lunny) <xiaolunwen@gmail.com>
|
||||||
|
- [Lauris Bukšis-Haberkorns](https://github.com/lafriks) <lauris@nix.lv>
|
||||||
|
- [Kim Carlbäcker](https://github.com/bkcsoft) <kim.carlbacker@gmail.com>
|
||||||
|
|
||||||
|
- 2016-11-04 ~ 2017-12-31
|
||||||
|
- [Lunny Xiao](https://github.com/lunny) <xiaolunwen@gmail.com>
|
||||||
|
- [Thomas Boerger](https://github.com/tboerger) <thomas@webhippie.de>
|
||||||
|
- [Kim Carlbäcker](https://github.com/bkcsoft) <kim.carlbacker@gmail.com>
|
||||||
|
|
||||||
|
## Versions
|
||||||
|
|
||||||
|
Gitea has the `main` branch as a tip branch and has version branches
|
||||||
|
such as `release/v0.9`. `release/v0.9` is a release branch and we will
|
||||||
|
tag `v0.9.0` for binary download. If `v0.9.0` has bugs, we will accept
|
||||||
|
pull requests on the `release/v0.9` branch and publish a `v0.9.1` tag,
|
||||||
|
after bringing the bug fix also to the main branch.
|
||||||
|
|
||||||
|
Since the `main` branch is a tip version, if you wish to use Gitea
|
||||||
|
in production, please download the latest release tag version. All the
|
||||||
|
branches will be protected via GitHub, all the PRs to every branch must
|
||||||
|
be reviewed by two maintainers and must pass the automatic tests.
|
||||||
|
|
||||||
|
## Releasing Gitea
|
||||||
|
|
||||||
|
- Let $vmaj, $vmin and $vpat be Major, Minor and Patch version numbers, $vpat should be rc1, rc2, 0, 1, ...... $vmaj.$vmin will be kept the same as milestones on github or gitea in future.
|
||||||
|
- Before releasing, confirm all the version's milestone issues or PRs has been resolved. Then discuss the release on Discord channel #maintainers and get agreed with almost all the owners and mergers. Or you can declare the version and if nobody against in about serval hours.
|
||||||
|
- If this is a big version first you have to create PR for changelog on branch `main` with PRs with label `changelog` and after it has been merged do following steps:
|
||||||
|
- Create `-dev` tag as `git tag -s -F release.notes v$vmaj.$vmin.0-dev` and push the tag as `git push origin v$vmaj.$vmin.0-dev`.
|
||||||
|
- When CI has finished building tag then you have to create a new branch named `release/v$vmaj.$vmin`
|
||||||
|
- If it is bugfix version create PR for changelog on branch `release/v$vmaj.$vmin` and wait till it is reviewed and merged.
|
||||||
|
- Add a tag as `git tag -s -F release.notes v$vmaj.$vmin.$`, release.notes file could be a temporary file to only include the changelog this version which you added to `CHANGELOG.md`.
|
||||||
|
- And then push the tag as `git push origin v$vmaj.$vmin.$`. Drone CI will automatically create a release and upload all the compiled binary. (But currently it doesn't add the release notes automatically. Maybe we should fix that.)
|
||||||
|
- If needed send a frontport PR for the changelog to branch `main` and update the version in `docs/config.yaml` to refer to the new version.
|
||||||
|
- Send PR to [blog repository](https://gitea.com/gitea/blog) announcing the release.
|
||||||
|
- Verify all release assets were correctly published through CI on dl.gitea.io and GitHub releases. Once ACKed:
|
||||||
|
- bump the version of https://dl.gitea.io/gitea/version.json
|
||||||
|
- merge the blog post PR
|
||||||
|
- announce the release in discord `#announcements`
|
||||||
|
|
||||||
|
## Copyright
|
||||||
|
|
||||||
|
Code that you contribute should use the standard copyright header:
|
||||||
|
|
||||||
|
```
|
||||||
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
```
|
||||||
|
|
||||||
|
Files in the repository contain copyright from the year they are added
|
||||||
|
to the year they are last changed. If the copyright author is changed,
|
||||||
|
just paste the header below the old one.
|
||||||
|
|
|
@ -1,26 +0,0 @@
|
||||||
# Code of Conduct, Well Being and Moderation teams
|
|
||||||
|
|
||||||
Forgejo strives to be an inclusive project where everyone can participate in a safe environment. The [Well Being](https://codeberg.org/org/forgejo/teams/well-being) team is doing its best to defuse tensions before they escalate and is available to answer all requests sent its way. When diplomacy fails, the [Moderation](https://codeberg.org/org/forgejo/teams/moderation) will be forced to act to put a stop to actions that are contrary to the [Code of Conduct](https://codeberg.org/forgejo/code-of-conduct).
|
|
||||||
|
|
||||||
## Well Being and Moderation teams
|
|
||||||
|
|
||||||
Temporary Well Being and Moderation teams [were appointed 10 November 2022](https://codeberg.org/forgejo/meta/issues/13).
|
|
||||||
|
|
||||||
The moderation team will rely on this [Code of Conduct](https://codeberg.org/forgejo/code-of-conduct) when diplomacy fails.
|
|
||||||
|
|
||||||
### [Well Being](https://codeberg.org/org/forgejo/teams/well-being)
|
|
||||||
|
|
||||||
Their goal is to defuse tensions.
|
|
||||||
|
|
||||||
It has no power whatsover. The members are approved by the organization and trusted to:
|
|
||||||
|
|
||||||
- Read all communications to detect tensions between people before they escalate.
|
|
||||||
- Do their best to defuse tensions.
|
|
||||||
|
|
||||||
### [Moderation](https://codeberg.org/org/forgejo/teams/moderation)
|
|
||||||
|
|
||||||
Their goal is to enforce the [Code of Conduct](https://codeberg.org/forgejo/code-of-conduct) when diplomacy fails.
|
|
||||||
|
|
||||||
It has the power to exclude people from a space.
|
|
||||||
|
|
||||||
Their decisions must be logical, fact based and transparent to the organization trusting them with the task.
|
|
|
@ -1,29 +0,0 @@
|
||||||
# Developer Certificate of Origin (DCO)
|
|
||||||
|
|
||||||
Contributions to Forgejo, in all the repositories in the [Forgejo organization](https://codeberg.org/forgejo) are accepted provided the author agrees to the following Developer Certificate of Origin (DCO).
|
|
||||||
|
|
||||||
```
|
|
||||||
By making a contribution to Forgejo, I certify that:
|
|
||||||
|
|
||||||
(a) The contribution was created in whole or in part by me and I
|
|
||||||
have the right to submit it under the Free Software
|
|
||||||
indicated in the file; or
|
|
||||||
|
|
||||||
(b) The contribution is based upon previous work that, to the best
|
|
||||||
of my knowledge, is covered under an appropriate Free Software
|
|
||||||
license and I have the right under that license to submit that
|
|
||||||
work with modifications, whether created in whole or in part
|
|
||||||
by me, under the same Free Software license (unless I am
|
|
||||||
permitted to submit under a different license), as indicated
|
|
||||||
in the file; or
|
|
||||||
|
|
||||||
(c) The contribution was provided directly to me by some other
|
|
||||||
person who certified (a), (b) or (c) and I have not modified
|
|
||||||
it.
|
|
||||||
|
|
||||||
(d) I understand and agree that this project and the contribution
|
|
||||||
are public and that a record of the contribution (including all
|
|
||||||
personal information I submit with it, including my sign-off) is
|
|
||||||
maintained indefinitely and may be redistributed consistent with
|
|
||||||
this project or the Free Software license(s) involved.
|
|
||||||
```
|
|
|
@ -1,18 +0,0 @@
|
||||||
# Bugs, features and discussions
|
|
||||||
|
|
||||||
The [Forgejo issue tracker](https://codeberg.org/forgejo/forgejo/issues) is where **bugs** should be reported and **features** requested.
|
|
||||||
|
|
||||||
Dedicated repositories in the [Forgejo organization](https://codeberg.org/forgejo) cover areas such as:
|
|
||||||
- the [website](https://codeberg.org/forgejo/website)
|
|
||||||
- the [Code of Conduct](https://codeberg.org/forgejo/code-of-conduct)
|
|
||||||
- the [funding](https://codeberg.org/forgejo/funding).
|
|
||||||
|
|
||||||
Other discussions regarding all **non technical aspects** of Forgejo, such as the governance, happen in the [meta issue tracker](https://codeberg.org/forgejo/meta/issues) and in the [matrix chatroom](https://matrix.to/#/#forgejo-chat:matrix.org).
|
|
||||||
|
|
||||||
# Security
|
|
||||||
|
|
||||||
The [security team](https://codeberg.org/org/forgejo/teams/security) handle security vulnerabilities. It handles sensitive security-related issues reported to [security@forgejo.org](mailto:security@forgejo.org) using [encryption](https://keyoxide.org/security@forgejo.org).
|
|
||||||
|
|
||||||
The security team also keeps the content of the [security.txt](https://codeberg.org/forgejo/website/src/branch/main/public/.well-known/security.txt) file up to date.
|
|
||||||
|
|
||||||
The private GPG key for `security@forgejo.org` is shared among all members of the security team and not stored online.
|
|
|
@ -1,21 +0,0 @@
|
||||||
# Funding per year
|
|
||||||
|
|
||||||
## 2022
|
|
||||||
|
|
||||||
* 50,000€ [to further forge federation](https://forum.forgefriends.org/t/nlnet-grant-application-for-federation-in-gitea-deadline-august-1st-2022/823)
|
|
||||||
* 10,000€ (1,400€ October, 5,600€ November, 2,800€ December) employee delegation from Easter-eggs (Loïc Dachary)
|
|
||||||
|
|
||||||
# Funding ideas and prospects
|
|
||||||
|
|
||||||
## Grant applications
|
|
||||||
|
|
||||||
* [Forgejo NLnet December 1st 2022](https://codeberg.org/forgejo/funding/issues/1)
|
|
||||||
* [UX/UI NLnet December 1st 2022](https://codeberg.org/forgejo/funding/issues/4)
|
|
||||||
|
|
||||||
## Discussions
|
|
||||||
|
|
||||||
* [Proposition](https://codeberg.org/forgejo/meta/issues/51) to log volunteers time so that it is accounted for at a 60€ per hour rate.
|
|
||||||
* [A solution for sustaining Free Software forge development](https://blog.dachary.org/2022/11/05/a-solution-for-sustaining-forge-development/)
|
|
||||||
* A French company delegates an employee for X month
|
|
||||||
* The employee's time is paid for by [R&D incentive](https://fr.wikipedia.org/wiki/Cr%C3%A9dit_d%27imp%C3%B4t_recherche)
|
|
||||||
* [Donations to Codeberg](https://codeberg.org/forgejo/meta/issues/26)
|
|
|
@ -1,21 +0,0 @@
|
||||||
# Governance
|
|
||||||
|
|
||||||
## Codeberg e.V. stewards of the domains
|
|
||||||
|
|
||||||
The Forgejo [domains](https://codeberg.org/forgejo/meta/issues/41) are owned by the democratic non-profit dedicated to Free Software [Codeberg e.V.](https://codeberg.org/Codeberg/org/src/branch/main/en/bylaws.md). Forgejo is therefore ultimately under the control of Codeberg e.V. and its governance. However, although Codeberg e.V. is committed to use and host Forgejo, it is expected that Forgejo defines its own governance, in a way that is compatible with the Codeberg e.V. governance.
|
|
||||||
|
|
||||||
## Interim Forgejo Governance
|
|
||||||
|
|
||||||
Although Codeberg e.V. guarantees Forgejo is ultimately under the control of a trusted organization, there was a need to establish an interim Forgejo governance for safeguarding credentials, enforcing the Code of Conduct and ensuring security vulnerabilities are handled responsibly for the Forgejo releases.
|
|
||||||
|
|
||||||
All people with a role in the interim Forgejo governance pledge to resign as soon as the Forgejo governance is in place.
|
|
||||||
|
|
||||||
* [release managers](https://codeberg.org/org/forgejo/teams/releases) safeguard the keys used to sign Forgejo releases
|
|
||||||
* [secret keepers](https://codeberg.org/org/Forgejo/teams/owners) safeguard all credentials (registrar, social accounts, etc.)
|
|
||||||
* [security team](https://codeberg.org/org/forgejo/teams/security) handle security vulnerabilities
|
|
||||||
* [Well Being](https://codeberg.org/org/forgejo/teams/well-being) and [Moderation](https://codeberg.org/org/forgejo/teams/moderation) teams help keep Forgejo an inclusive space
|
|
||||||
|
|
||||||
## Forgejo Governance
|
|
||||||
|
|
||||||
Forgejo was bootstraped in November 2022 and is [defining its governance](https://codeberg.org/forgejo/meta/issues/19). The [first meeting happened November 24th](https://codeberg.org/forgejo/meta/issues/19#issuecomment-694460) and was recorded. Everyone is welcome to participate in this fully transparent and cooperative process.
|
|
||||||
|
|
|
@ -1,62 +0,0 @@
|
||||||
# Release management
|
|
||||||
|
|
||||||
## Shared user: release-team
|
|
||||||
|
|
||||||
The [release-team](https://codeberg.org/release-team) user publishes and signs all releases. The associated email is mailto:release@forgejo.org.
|
|
||||||
|
|
||||||
The public GPG key used to sign the releases is [EB114F5E6C0DC2BCDD183550A4B61A2DC5923710](https://codeberg.org/release-team.gpg) `Forgejo Releases <release@forgejo.org>`
|
|
||||||
|
|
||||||
## Release numbering
|
|
||||||
|
|
||||||
The Forgejo release numbers are composed of the Gitea release number followed by a dash and a serial number. For instance:
|
|
||||||
|
|
||||||
* Gitea **v1.18.0** will be Forgejo **v1.18.0-0**, **v1.18.0-1**, etc
|
|
||||||
|
|
||||||
The Gitea release candidates are suffixed with **-rcN** which is handled as a special case for packaging: although **X.Y.Z** is lexicographically lower than **X.Y.Z-rc1** is is considered greater. The Forgejo serial number must therefore be inserted before the **-rcN** suffix to preserve the expected version ordering.
|
|
||||||
|
|
||||||
* Gitea **v1.18.0-rc0** will be Forgejo **v1.18.0-0-rc0**, **v1.18.0-1-rc0**
|
|
||||||
* Gitea **v1.18.0-rc1** will be Forgejo **v1.18.0-2-rc1**, **v1.18.0-3-rc1**, **v1.18.0-4-rc1**
|
|
||||||
* Gitea **v1.18.0** will be Forgejo **v1.18.0-5**, **v1.18.0-6**, **v1.18.0-7**
|
|
||||||
* etc.
|
|
||||||
|
|
||||||
## Release process
|
|
||||||
|
|
||||||
* Reset the vX.Y/forgejo-integration branch to the Gitea tag vX.Y.Z
|
|
||||||
* Merge all feature branches into the vX.Y/forgejo-integration branch
|
|
||||||
* If the CI passes reset the vX.Y/forgejo branch to the tip of vX.Y/forgejo-integration
|
|
||||||
* Set the vX.Y.Z-N tag to the tip of the vX.Y/forgejo branch
|
|
||||||
* [Binaries](https://codeberg.org/forgejo/forgejo/releases) are built, signed and uploaded by the CI.
|
|
||||||
* [Container images](https://codeberg.org/forgejo/-/packages/container/forgejo/versions) are built and uploaded by the CI.
|
|
||||||
|
|
||||||
## Release signing keys management
|
|
||||||
|
|
||||||
A GPG master key with no expiration date is created and shared with members of the Owners team via encrypted email. A subkey with a one year expiration date is created and stored in the secrets repository, to be used by the CI pipeline. The public master key is stored in the secrets repository and published where relevant.
|
|
||||||
|
|
||||||
### Master key creation
|
|
||||||
|
|
||||||
* gpg --expert --full-generate-key
|
|
||||||
* key type: ECC and ECC option with Curve 25519 as curve
|
|
||||||
* no expiration
|
|
||||||
* id: Forgejo Releases <contact@forgejo.org>
|
|
||||||
* gpg --export-secret-keys --armor EB114F5E6C0DC2BCDD183550A4B61A2DC5923710 and send via encrypted email to Owners
|
|
||||||
* gpg --export --armor EB114F5E6C0DC2BCDD183550A4B61A2DC5923710 > release-team-gpg.pub
|
|
||||||
* commit to the secret repository
|
|
||||||
|
|
||||||
### Subkey creation and renewal
|
|
||||||
|
|
||||||
* gpg --expert --edit-key EB114F5E6C0DC2BCDD183550A4B61A2DC5923710
|
|
||||||
* addkey
|
|
||||||
* key type: ECC (signature only)
|
|
||||||
* key validity: one year
|
|
||||||
* create [an issue](https://codeberg.org/forgejo/forgejo/issues) to schedule the renewal
|
|
||||||
|
|
||||||
#### 2023
|
|
||||||
|
|
||||||
* gpg --export --armor F7CBF02094E7665E17ED6C44E381BF3E50D53707 > 2023-release-team-gpg.pub
|
|
||||||
* gpg --export-secret-keys --armor F7CBF02094E7665E17ED6C44E381BF3E50D53707 > 2023-release-team-gpg
|
|
||||||
* commit to the secrets repository
|
|
||||||
* renewal issue https://codeberg.org/forgejo/forgejo/issues/58
|
|
||||||
|
|
||||||
### CI configuration
|
|
||||||
|
|
||||||
The `releaseteamgpg` secret in the Woodpecker CI configuration is set with the subkey.
|
|
|
@ -1,56 +0,0 @@
|
||||||
# Secrets
|
|
||||||
|
|
||||||
All Forgejo credentials are shared among the [secret keepers](https://codeberg.org/org/Forgejo/teams/owners) teams in a private repository with encrypted content.
|
|
||||||
|
|
||||||
## Get started
|
|
||||||
|
|
||||||
1. Make sure you have a GPG Key, or [create one](https://github.com/NicoHood/gpgit#12-key-generation)
|
|
||||||
2. Send someone else your public key and ask this person to add yourself as a recipient
|
|
||||||
```
|
|
||||||
# Commands for the other person
|
|
||||||
$ gpg --import public_key.asc
|
|
||||||
# The following command will open a prompt, with the available public keys.
|
|
||||||
# Choose the one you just added and all secrets will be re-encrypted with this new key.
|
|
||||||
$ gopass recipients add
|
|
||||||
```
|
|
||||||
3. [Install gopass](https://www.gopass.pw/#install)
|
|
||||||
> :warning: When installing on Ubuntu or Debian you can either download the deb package, install manually or build from source or use our APT repository ([github comment](https://github.com/gopasspw/gopass/issues/1849#issuecomment-802789285) with more information).
|
|
||||||
4. Clone this repo using `gopass` (the name and email are for `git config`)
|
|
||||||
```
|
|
||||||
$ gopass clone git@codeberg.org:Forgejo/gopass.git
|
|
||||||
```
|
|
||||||
5. Check the consistency of the gopass storage
|
|
||||||
```
|
|
||||||
$ gopass fsck
|
|
||||||
```
|
|
||||||
|
|
||||||
## Get a secret
|
|
||||||
|
|
||||||
Show the whole secret file:
|
|
||||||
```
|
|
||||||
$ gopass show ovh.com/manager
|
|
||||||
```
|
|
||||||
|
|
||||||
Copy the password in the clipboard:
|
|
||||||
```
|
|
||||||
$ gopass show -c ovh.com/manager
|
|
||||||
```
|
|
||||||
|
|
||||||
Copy the `user` part of the secret in the clipboard:
|
|
||||||
```
|
|
||||||
$ gopass show -c ovh.com/manager user
|
|
||||||
```
|
|
||||||
|
|
||||||
## Insert or edit a secret
|
|
||||||
```
|
|
||||||
$ gopass edit ovh.com/manager
|
|
||||||
```
|
|
||||||
In the editor, insert the password on the first line.
|
|
||||||
You may then add lines with a `key: value` syntax (`user: username` for instance).
|
|
||||||
|
|
||||||
## Debugging and manual git operations
|
|
||||||
|
|
||||||
The following command will show the location and status of the git repo (all git commands are available).
|
|
||||||
```
|
|
||||||
$ gopass git status
|
|
||||||
```
|
|
|
@ -1,79 +0,0 @@
|
||||||
# Development workflow
|
|
||||||
|
|
||||||
Forgejo is a soft fork, i.e. a set of commits applied to the Gitea development branch and the stable branches. On a regular basis those commits are rebased and modified if necessary to keep working. All Forgejo commits are merged into a branch from which binary releases and packages are created and distributed. The development workflow is a set of conventions Forgejo developers are expected to follow to work together.
|
|
||||||
|
|
||||||
Discussions on how the workflow should evolve happen [in the isssue tracker](https://codeberg.org/forgejo/forgejo/issues?type=all&state=open&labels=&milestone=0&assignee=0&q=%5BWORKFLOW%5D).
|
|
||||||
|
|
||||||
## Naming conventions
|
|
||||||
|
|
||||||
### Development
|
|
||||||
|
|
||||||
* Gitea: main
|
|
||||||
* Forgejo: forgejo
|
|
||||||
* Integration: forgejo-integration
|
|
||||||
* Feature branches: forgejo-feature-name
|
|
||||||
|
|
||||||
### Stable
|
|
||||||
|
|
||||||
* Gitea: release/vX.Y
|
|
||||||
* Forgejo: vX.Y/forgejo
|
|
||||||
* Integration: vX.Y/forgejo-integration
|
|
||||||
* Feature branches: vX.Y/forgejo-feature-name
|
|
||||||
|
|
||||||
## Rebasing
|
|
||||||
|
|
||||||
### *Feature branch*
|
|
||||||
|
|
||||||
The *Gitea* branches are mirrored with the Gitea development and stable branches.
|
|
||||||
|
|
||||||
On a regular basis, each *Feature branch* is rebased against the base *Gitea* branch.
|
|
||||||
|
|
||||||
### *Integration* and *Forgejo*
|
|
||||||
|
|
||||||
The latest *Gitea* branch resets the *Integration* branch and all *Feature branches* are merged into it.
|
|
||||||
|
|
||||||
If tests pass, the *Forgejo* branch is reset to the tip of the *Integration* branch.
|
|
||||||
|
|
||||||
If tests do not pass, an issue is filed to the *Feature branch* that fails the test. Once the issue is resolved, another round of rebasing starts.
|
|
||||||
|
|
||||||
## Releasing
|
|
||||||
|
|
||||||
When a tag is set to a *Stable* *Forgejo* branch, the CI pipeline creates and uploads binaries and packages.
|
|
||||||
|
|
||||||
## Feature branches
|
|
||||||
|
|
||||||
All *Feature branches* are based on the {vX.Y/,}forgejo-development branch which provides and other development tools and documenation.
|
|
||||||
|
|
||||||
The \*forgejo-development branch is based on the {vX.Y/,}forgejo-ci branch which provides the Woodpecker CI configuration.
|
|
||||||
|
|
||||||
The purpose of each *Feature branch* is documented below:
|
|
||||||
|
|
||||||
### General purpose
|
|
||||||
|
|
||||||
* [forgejo-ci](https://codeberg.org/forgejo/forgejo/src/branch/forgejo-ci) based on [main](https://codeberg.org/forgejo/forgejo/src/branch/main)
|
|
||||||
Woodpecker CI configuration, including the release process.
|
|
||||||
* Backports: [v1.18/forgejo-ci](https://codeberg.org/forgejo/forgejo/src/branch/v1.18/forgejo-ci)
|
|
||||||
|
|
||||||
* [forgejo-development](https://codeberg.org/forgejo/forgejo/src/branch/forgejo-development) based on [forgejo-ci](https://codeberg.org/forgejo/forgejo/src/branch/forgejo-ci)
|
|
||||||
Forgejo development tools and documentation.
|
|
||||||
* Backports: [v1.18/forgejo-development](https://codeberg.org/forgejo/forgejo/src/branch/v1.18/forgejo-development)
|
|
||||||
|
|
||||||
### [Federation](https://codeberg.org/forgejo/forgejo/issues?labels=79349)
|
|
||||||
|
|
||||||
* [forgejo-federation](https://codeberg.org/forgejo/forgejo/src/branch/forgejo-federation) based on [forgejo-development](https://codeberg.org/forgejo/forgejo/src/branch/forgejo-development)
|
|
||||||
Federation support for Forgejo
|
|
||||||
|
|
||||||
## Pull requests and feature branches
|
|
||||||
|
|
||||||
Most people who are used to contributing will be familiar with the workflow of sending a pull request against the default branch. When that happens the reviewer should change the base branch to the appropriate *Feature branch* instead. If the pull request does not fit in any *Feature branch*, the reviewer needs to make decision to either:
|
|
||||||
|
|
||||||
* Decline the pull request because it is best contributed to Gitea
|
|
||||||
* Create a new *Feature branch*
|
|
||||||
|
|
||||||
Returning contributors can figure out which *Feature branch* to base their pull request on using the list of *Feature branches*.
|
|
||||||
|
|
||||||
## Granularity
|
|
||||||
|
|
||||||
*Feature branches* can contain a number of commits grouped together, for instance for branding the documentation, the landing page and the footer. It makes it convenient for people working on that topic to get the big picture without browsing multiple branches. Creating a new *Feature branch* for each individual commit, while possible, is likely to be difficult to work with.
|
|
||||||
|
|
||||||
Observing the granularity of the existing *Feature branches* is the best way to figure out what works and what does not. It requires adjustments from time to time depending on the number of contributors and the complexity of the Forgejo codebase that sits on top of Gitea.
|
|
|
@ -1,5 +1,5 @@
|
||||||
#Build stage
|
#Build stage
|
||||||
FROM codeberg.org/forgejo/golang:1.19-alpine3.17 AS build-env
|
FROM codeberg.org/forgejo/golang:1.19-alpine3.16 AS build-env
|
||||||
|
|
||||||
ARG GOPROXY
|
ARG GOPROXY
|
||||||
ENV GOPROXY ${GOPROXY:-direct}
|
ENV GOPROXY ${GOPROXY:-direct}
|
||||||
|
@ -23,7 +23,7 @@ RUN if [ -n "${GITEA_VERSION}" ]; then git checkout "${GITEA_VERSION}"; fi \
|
||||||
# Begin env-to-ini build
|
# Begin env-to-ini build
|
||||||
RUN go build contrib/environment-to-ini/environment-to-ini.go
|
RUN go build contrib/environment-to-ini/environment-to-ini.go
|
||||||
|
|
||||||
FROM codeberg.org/forgejo/alpine:3.17.0
|
FROM codeberg.org/forgejo/alpine:3.16.3
|
||||||
LABEL maintainer="contact@forgejo.org"
|
LABEL maintainer="contact@forgejo.org"
|
||||||
|
|
||||||
EXPOSE 22 3000
|
EXPOSE 22 3000
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#Build stage
|
#Build stage
|
||||||
FROM golang:1.19-alpine3.17 AS build-env
|
FROM golang:1.19-alpine3.16 AS build-env
|
||||||
|
|
||||||
ARG GOPROXY
|
ARG GOPROXY
|
||||||
ENV GOPROXY ${GOPROXY:-direct}
|
ENV GOPROXY ${GOPROXY:-direct}
|
||||||
|
@ -23,7 +23,7 @@ RUN if [ -n "${GITEA_VERSION}" ]; then git checkout "${GITEA_VERSION}"; fi \
|
||||||
# Begin env-to-ini build
|
# Begin env-to-ini build
|
||||||
RUN go build contrib/environment-to-ini/environment-to-ini.go
|
RUN go build contrib/environment-to-ini/environment-to-ini.go
|
||||||
|
|
||||||
FROM alpine:3.17
|
FROM alpine:3.16
|
||||||
LABEL maintainer="maintainers@gitea.io"
|
LABEL maintainer="maintainers@gitea.io"
|
||||||
|
|
||||||
EXPOSE 2222 3000
|
EXPOSE 2222 3000
|
||||||
|
|
|
@ -44,6 +44,7 @@ Janis Estelmann <admin@oldschoolhack.me> (@KN4CK3R)
|
||||||
Steven Kriegler <sk.bunsenbrenner@gmail.com> (@justusbunsi)
|
Steven Kriegler <sk.bunsenbrenner@gmail.com> (@justusbunsi)
|
||||||
Jimmy Praet <jimmy.praet@telenet.be> (@jpraet)
|
Jimmy Praet <jimmy.praet@telenet.be> (@jpraet)
|
||||||
Leon Hofmeister <dev.lh@web.de> (@delvh)
|
Leon Hofmeister <dev.lh@web.de> (@delvh)
|
||||||
|
Gusted <williamzijl7@hotmail.com) (@Gusted)
|
||||||
silentcode <silentcode@senga.org> (@silentcodeg)
|
silentcode <silentcode@senga.org> (@silentcodeg)
|
||||||
Wim <wim@42.be> (@42wim)
|
Wim <wim@42.be> (@42wim)
|
||||||
xinyu <xinyu@nerv.org.cn> (@penlinux)
|
xinyu <xinyu@nerv.org.cn> (@penlinux)
|
||||||
|
|
98
Makefile
98
Makefile
|
@ -100,8 +100,7 @@ LDFLAGS := $(LDFLAGS) -X "main.MakeVersion=$(MAKE_VERSION)" -X "main.Version=$(G
|
||||||
|
|
||||||
LINUX_ARCHS ?= linux/amd64,linux/386,linux/arm-5,linux/arm-6,linux/arm64
|
LINUX_ARCHS ?= linux/amd64,linux/386,linux/arm-5,linux/arm-6,linux/arm64
|
||||||
|
|
||||||
GO_PACKAGES ?= $(filter-out code.gitea.io/gitea/tests/integration/migration-test code.gitea.io/gitea/tests code.gitea.io/gitea/tests/integration code.gitea.io/gitea/tests/e2e,$(shell $(GO) list ./... | grep -v /vendor/))
|
GO_PACKAGES ?= $(filter-out code.gitea.io/gitea/models/migrations code.gitea.io/gitea/tests/integration/migration-test code.gitea.io/gitea/tests code.gitea.io/gitea/tests/integration code.gitea.io/gitea/tests/e2e,$(shell $(GO) list ./... | grep -v /vendor/))
|
||||||
GO_TEST_PACKAGES ?= $(filter-out $(shell $(GO) list code.gitea.io/gitea/models/migrations/...) code.gitea.io/gitea/tests/integration/migration-test code.gitea.io/gitea/tests code.gitea.io/gitea/tests/integration code.gitea.io/gitea/tests/e2e,$(shell $(GO) list ./... | grep -v /vendor/))
|
|
||||||
|
|
||||||
FOMANTIC_WORK_DIR := web_src/fomantic
|
FOMANTIC_WORK_DIR := web_src/fomantic
|
||||||
|
|
||||||
|
@ -333,7 +332,7 @@ checks: checks-frontend checks-backend
|
||||||
checks-frontend: lockfile-check svg-check
|
checks-frontend: lockfile-check svg-check
|
||||||
|
|
||||||
.PHONY: checks-backend
|
.PHONY: checks-backend
|
||||||
checks-backend: tidy-check swagger-check fmt-check misspell-check swagger-validate security-check
|
checks-backend: tidy-check swagger-check fmt-check misspell-check swagger-validate
|
||||||
|
|
||||||
.PHONY: lint
|
.PHONY: lint
|
||||||
lint: lint-frontend lint-backend
|
lint: lint-frontend lint-backend
|
||||||
|
@ -367,7 +366,7 @@ test: test-frontend test-backend
|
||||||
.PHONY: test-backend
|
.PHONY: test-backend
|
||||||
test-backend:
|
test-backend:
|
||||||
@echo "Running go test with $(GOTESTFLAGS) -tags '$(TEST_TAGS)'..."
|
@echo "Running go test with $(GOTESTFLAGS) -tags '$(TEST_TAGS)'..."
|
||||||
@$(GO) test $(GOTESTFLAGS) -tags='$(TEST_TAGS)' $(GO_TEST_PACKAGES)
|
@$(GO) test $(GOTESTFLAGS) -tags='$(TEST_TAGS)' $(GO_PACKAGES)
|
||||||
|
|
||||||
.PHONY: test-frontend
|
.PHONY: test-frontend
|
||||||
test-frontend: node_modules
|
test-frontend: node_modules
|
||||||
|
@ -388,7 +387,7 @@ test-check:
|
||||||
.PHONY: test\#%
|
.PHONY: test\#%
|
||||||
test\#%:
|
test\#%:
|
||||||
@echo "Running go test with -tags '$(TEST_TAGS)'..."
|
@echo "Running go test with -tags '$(TEST_TAGS)'..."
|
||||||
@$(GO) test $(GOTESTFLAGS) -tags='$(TEST_TAGS)' -run $(subst .,/,$*) $(GO_TEST_PACKAGES)
|
@$(GO) test $(GOTESTFLAGS) -tags='$(TEST_TAGS)' -run $(subst .,/,$*) $(GO_PACKAGES)
|
||||||
|
|
||||||
.PHONY: coverage
|
.PHONY: coverage
|
||||||
coverage:
|
coverage:
|
||||||
|
@ -399,7 +398,7 @@ coverage:
|
||||||
.PHONY: unit-test-coverage
|
.PHONY: unit-test-coverage
|
||||||
unit-test-coverage:
|
unit-test-coverage:
|
||||||
@echo "Running unit-test-coverage $(GOTESTFLAGS) -tags '$(TEST_TAGS)'..."
|
@echo "Running unit-test-coverage $(GOTESTFLAGS) -tags '$(TEST_TAGS)'..."
|
||||||
@$(GO) test $(GOTESTFLAGS) -timeout=20m -tags='$(TEST_TAGS)' -cover -coverprofile coverage.out $(GO_TEST_PACKAGES) && echo "\n==>\033[32m Ok\033[m\n" || exit 1
|
@$(GO) test $(GOTESTFLAGS) -timeout=20m -tags='$(TEST_TAGS)' -cover -coverprofile coverage.out $(GO_PACKAGES) && echo "\n==>\033[32m Ok\033[m\n" || exit 1
|
||||||
|
|
||||||
.PHONY: tidy
|
.PHONY: tidy
|
||||||
tidy:
|
tidy:
|
||||||
|
@ -443,7 +442,14 @@ test-sqlite\#%: integrations.sqlite.test generate-ini-sqlite
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini ./integrations.sqlite.test -test.run $(subst .,/,$*)
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini ./integrations.sqlite.test -test.run $(subst .,/,$*)
|
||||||
|
|
||||||
.PHONY: test-sqlite-migration
|
.PHONY: test-sqlite-migration
|
||||||
test-sqlite-migration: migrations.sqlite.test migrations.individual.sqlite.test
|
test-sqlite-migration: migrations.sqlite.test migrations.individual.sqlite.test generate-ini-sqlite
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini ./migrations.sqlite.test
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini ./migrations.individual.sqlite.test
|
||||||
|
|
||||||
|
.PHONY: test-sqlite-migration\#%
|
||||||
|
test-sqlite-migration\#%: migrations.sqlite.test migrations.individual.sqlite.test generate-ini-sqlite
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini ./migrations.individual.sqlite.test -test.run $(subst .,/,$*)
|
||||||
|
|
||||||
|
|
||||||
generate-ini-mysql:
|
generate-ini-mysql:
|
||||||
sed -e 's|{{TEST_MYSQL_HOST}}|${TEST_MYSQL_HOST}|g' \
|
sed -e 's|{{TEST_MYSQL_HOST}}|${TEST_MYSQL_HOST}|g' \
|
||||||
|
@ -464,7 +470,9 @@ test-mysql\#%: integrations.mysql.test generate-ini-mysql
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql.ini ./integrations.mysql.test -test.run $(subst .,/,$*)
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql.ini ./integrations.mysql.test -test.run $(subst .,/,$*)
|
||||||
|
|
||||||
.PHONY: test-mysql-migration
|
.PHONY: test-mysql-migration
|
||||||
test-mysql-migration: migrations.mysql.test migrations.individual.mysql.test
|
test-mysql-migration: migrations.mysql.test migrations.individual.mysql.test generate-ini-mysql
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql.ini ./migrations.mysql.test
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql.ini ./migrations.individual.mysql.test
|
||||||
|
|
||||||
generate-ini-mysql8:
|
generate-ini-mysql8:
|
||||||
sed -e 's|{{TEST_MYSQL8_HOST}}|${TEST_MYSQL8_HOST}|g' \
|
sed -e 's|{{TEST_MYSQL8_HOST}}|${TEST_MYSQL8_HOST}|g' \
|
||||||
|
@ -485,7 +493,9 @@ test-mysql8\#%: integrations.mysql8.test generate-ini-mysql8
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql8.ini ./integrations.mysql8.test -test.run $(subst .,/,$*)
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql8.ini ./integrations.mysql8.test -test.run $(subst .,/,$*)
|
||||||
|
|
||||||
.PHONY: test-mysql8-migration
|
.PHONY: test-mysql8-migration
|
||||||
test-mysql8-migration: migrations.mysql8.test migrations.individual.mysql8.test
|
test-mysql8-migration: migrations.mysql8.test migrations.individual.mysql8.test generate-ini-mysql8
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql8.ini ./migrations.mysql8.test
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql8.ini ./migrations.individual.mysql8.test
|
||||||
|
|
||||||
generate-ini-pgsql:
|
generate-ini-pgsql:
|
||||||
sed -e 's|{{TEST_PGSQL_HOST}}|${TEST_PGSQL_HOST}|g' \
|
sed -e 's|{{TEST_PGSQL_HOST}}|${TEST_PGSQL_HOST}|g' \
|
||||||
|
@ -507,7 +517,9 @@ test-pgsql\#%: integrations.pgsql.test generate-ini-pgsql
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/pgsql.ini ./integrations.pgsql.test -test.run $(subst .,/,$*)
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/pgsql.ini ./integrations.pgsql.test -test.run $(subst .,/,$*)
|
||||||
|
|
||||||
.PHONY: test-pgsql-migration
|
.PHONY: test-pgsql-migration
|
||||||
test-pgsql-migration: migrations.pgsql.test migrations.individual.pgsql.test
|
test-pgsql-migration: migrations.pgsql.test migrations.individual.pgsql.test generate-ini-pgsql
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/pgsql.ini ./migrations.pgsql.test
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/pgsql.ini ./migrations.individual.pgsql.test
|
||||||
|
|
||||||
generate-ini-mssql:
|
generate-ini-mssql:
|
||||||
sed -e 's|{{TEST_MSSQL_HOST}}|${TEST_MSSQL_HOST}|g' \
|
sed -e 's|{{TEST_MSSQL_HOST}}|${TEST_MSSQL_HOST}|g' \
|
||||||
|
@ -528,7 +540,9 @@ test-mssql\#%: integrations.mssql.test generate-ini-mssql
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mssql.ini ./integrations.mssql.test -test.run $(subst .,/,$*)
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mssql.ini ./integrations.mssql.test -test.run $(subst .,/,$*)
|
||||||
|
|
||||||
.PHONY: test-mssql-migration
|
.PHONY: test-mssql-migration
|
||||||
test-mssql-migration: migrations.mssql.test migrations.individual.mssql.test
|
test-mssql-migration: migrations.mssql.test migrations.individual.mssql.test generate-ini-mssql
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mssql.ini ./migrations.mssql.test -test.failfast
|
||||||
|
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mssql.ini ./migrations.individual.mssql.test -test.failfast
|
||||||
|
|
||||||
.PHONY: playwright
|
.PHONY: playwright
|
||||||
playwright: $(PLAYWRIGHT_DIR)
|
playwright: $(PLAYWRIGHT_DIR)
|
||||||
|
@ -623,82 +637,50 @@ integrations.sqlite.test: git-check $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration -o integrations.sqlite.test -tags '$(TEST_TAGS)'
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration -o integrations.sqlite.test -tags '$(TEST_TAGS)'
|
||||||
|
|
||||||
integrations.cover.test: git-check $(GO_SOURCES)
|
integrations.cover.test: git-check $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration -coverpkg $(shell echo $(GO_TEST_PACKAGES) | tr ' ' ',') -o integrations.cover.test
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration -coverpkg $(shell echo $(GO_PACKAGES) | tr ' ' ',') -o integrations.cover.test
|
||||||
|
|
||||||
integrations.cover.sqlite.test: git-check $(GO_SOURCES)
|
integrations.cover.sqlite.test: git-check $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration -coverpkg $(shell echo $(GO_TEST_PACKAGES) | tr ' ' ',') -o integrations.cover.sqlite.test -tags '$(TEST_TAGS)'
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration -coverpkg $(shell echo $(GO_PACKAGES) | tr ' ' ',') -o integrations.cover.sqlite.test -tags '$(TEST_TAGS)'
|
||||||
|
|
||||||
.PHONY: migrations.mysql.test
|
.PHONY: migrations.mysql.test
|
||||||
migrations.mysql.test: $(GO_SOURCES) generate-ini-mysql
|
migrations.mysql.test: $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.mysql.test
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.mysql.test
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql.ini ./migrations.mysql.test
|
|
||||||
|
|
||||||
.PHONY: migrations.mysql8.test
|
.PHONY: migrations.mysql8.test
|
||||||
migrations.mysql8.test: $(GO_SOURCES) generate-ini-mysql8
|
migrations.mysql8.test: $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.mysql8.test
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.mysql8.test
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql8.ini ./migrations.mysql8.test
|
|
||||||
|
|
||||||
.PHONY: migrations.pgsql.test
|
.PHONY: migrations.pgsql.test
|
||||||
migrations.pgsql.test: $(GO_SOURCES) generate-ini-pgsql
|
migrations.pgsql.test: $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.pgsql.test
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.pgsql.test
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/pgsql.ini ./migrations.pgsql.test
|
|
||||||
|
|
||||||
.PHONY: migrations.mssql.test
|
.PHONY: migrations.mssql.test
|
||||||
migrations.mssql.test: $(GO_SOURCES) generate-ini-mssql
|
migrations.mssql.test: $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.mssql.test
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.mssql.test
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mssql.ini ./migrations.mssql.test
|
|
||||||
|
|
||||||
.PHONY: migrations.sqlite.test
|
.PHONY: migrations.sqlite.test
|
||||||
migrations.sqlite.test: $(GO_SOURCES) generate-ini-sqlite
|
migrations.sqlite.test: $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.sqlite.test -tags '$(TEST_TAGS)'
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/integration/migration-test -o migrations.sqlite.test -tags '$(TEST_TAGS)'
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini ./migrations.sqlite.test
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.mysql.test
|
.PHONY: migrations.individual.mysql.test
|
||||||
migrations.individual.mysql.test: $(GO_SOURCES)
|
migrations.individual.mysql.test: $(GO_SOURCES)
|
||||||
for pkg in $(shell $(GO) list code.gitea.io/gitea/models/migrations/...); do \
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/models/migrations -o migrations.individual.mysql.test
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' $$pkg; \
|
|
||||||
done
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.mysql8.test
|
.PHONY: migrations.individual.mysql8.test
|
||||||
migrations.individual.mysql8.test: $(GO_SOURCES)
|
migrations.individual.mysql8.test: $(GO_SOURCES)
|
||||||
for pkg in $(shell $(GO) list code.gitea.io/gitea/models/migrations/...); do \
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/models/migrations -o migrations.individual.mysql8.test
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mysql8.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' $$pkg; \
|
|
||||||
done
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.mysql8.test\#%
|
|
||||||
migrations.individual.sqlite.test\#%: $(GO_SOURCES) generate-ini-sqlite
|
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' code.gitea.io/gitea/models/migrations/$*
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.pgsql.test
|
.PHONY: migrations.individual.pgsql.test
|
||||||
migrations.individual.pgsql.test: $(GO_SOURCES)
|
migrations.individual.pgsql.test: $(GO_SOURCES)
|
||||||
for pkg in $(shell $(GO) list code.gitea.io/gitea/models/migrations/...); do \
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/models/migrations -o migrations.individual.pgsql.test
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/pgsql.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' $$pkg; \
|
|
||||||
done
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.pgsql.test\#%
|
|
||||||
migrations.individual.pgsql.test\#%: $(GO_SOURCES) generate-ini-pgsql
|
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/pgsql.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' code.gitea.io/gitea/models/migrations/$*
|
|
||||||
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.mssql.test
|
.PHONY: migrations.individual.mssql.test
|
||||||
migrations.individual.mssql.test: $(GO_SOURCES) generate-ini-mssql
|
migrations.individual.mssql.test: $(GO_SOURCES)
|
||||||
for pkg in $(shell $(GO) list code.gitea.io/gitea/models/migrations/...); do \
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/models/migrations -o migrations.individual.mssql.test
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mssql.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' $$pkg -test.failfast; \
|
|
||||||
done
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.mssql.test\#%
|
|
||||||
migrations.individual.mssql.test\#%: $(GO_SOURCES) generate-ini-mssql
|
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/mssql.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' code.gitea.io/gitea/models/migrations/$*
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.sqlite.test
|
.PHONY: migrations.individual.sqlite.test
|
||||||
migrations.individual.sqlite.test: $(GO_SOURCES) generate-ini-sqlite
|
migrations.individual.sqlite.test: $(GO_SOURCES)
|
||||||
for pkg in $(shell $(GO) list code.gitea.io/gitea/models/migrations/...); do \
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/models/migrations -o migrations.individual.sqlite.test -tags '$(TEST_TAGS)'
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' $$pkg; \
|
|
||||||
done
|
|
||||||
|
|
||||||
.PHONY: migrations.individual.sqlite.test\#%
|
|
||||||
migrations.individual.sqlite.test\#%: $(GO_SOURCES) generate-ini-sqlite
|
|
||||||
GITEA_ROOT="$(CURDIR)" GITEA_CONF=tests/sqlite.ini $(GO) test $(GOTESTFLAGS) -tags '$(TEST_TAGS)' code.gitea.io/gitea/models/migrations/$*
|
|
||||||
|
|
||||||
e2e.mysql.test: $(GO_SOURCES)
|
e2e.mysql.test: $(GO_SOURCES)
|
||||||
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/e2e -o e2e.mysql.test
|
$(GO) test $(GOTESTFLAGS) -c code.gitea.io/gitea/tests/e2e -o e2e.mysql.test
|
||||||
|
@ -745,7 +727,7 @@ generate-go: $(TAGS_PREREQ)
|
||||||
|
|
||||||
.PHONY: security-check
|
.PHONY: security-check
|
||||||
security-check:
|
security-check:
|
||||||
go run $(GOVULNCHECK_PACKAGE) -v ./...
|
govulncheck -v ./...
|
||||||
|
|
||||||
$(EXECUTABLE): $(GO_SOURCES) $(TAGS_PREREQ)
|
$(EXECUTABLE): $(GO_SOURCES) $(TAGS_PREREQ)
|
||||||
CGO_CFLAGS="$(CGO_CFLAGS)" $(GO) build $(GOFLAGS) $(EXTRA_GOFLAGS) -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' -o $@
|
CGO_CFLAGS="$(CGO_CFLAGS)" $(GO) build $(GOFLAGS) $(EXTRA_GOFLAGS) -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' -o $@
|
||||||
|
|
202
README.md
202
README.md
|
@ -1,46 +1,180 @@
|
||||||
# Welcome to Forgejo
|
<p align="center">
|
||||||
|
<a href="https://gitea.io/">
|
||||||
|
<img alt="Gitea" src="https://raw.githubusercontent.com/go-gitea/gitea/main/public/img/gitea.svg" width="220"/>
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
|
<h1 align="center">Gitea - Git with a cup of tea</h1>
|
||||||
|
|
||||||
Hi there! Tired of big platforms playing monopoly?
|
<p align="center">
|
||||||
Providing Git hosting for your project, friends, company or community?
|
<a href="https://drone.gitea.io/go-gitea/gitea" title="Build Status">
|
||||||
**Forgejo** (inspired by forĝejo \ˈfor.d͡ʒe.jo\ – the Esperanto word for *forge*) has you covered with its intuitive interface,
|
<img src="https://drone.gitea.io/api/badges/go-gitea/gitea/status.svg?ref=refs/heads/main">
|
||||||
light and easy hosting and a lot of builtin functionality.
|
</a>
|
||||||
|
<a href="https://discord.gg/Gitea" title="Join the Discord chat at https://discord.gg/Gitea">
|
||||||
|
<img src="https://img.shields.io/discord/322538954119184384.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://codecov.io/gh/go-gitea/gitea" title="Codecov">
|
||||||
|
<img src="https://codecov.io/gh/go-gitea/gitea/branch/main/graph/badge.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://goreportcard.com/report/code.gitea.io/gitea" title="Go Report Card">
|
||||||
|
<img src="https://goreportcard.com/badge/code.gitea.io/gitea">
|
||||||
|
</a>
|
||||||
|
<a href="https://godoc.org/code.gitea.io/gitea" title="GoDoc">
|
||||||
|
<img src="https://godoc.org/code.gitea.io/gitea?status.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://github.com/go-gitea/gitea/releases/latest" title="GitHub release">
|
||||||
|
<img src="https://img.shields.io/github/release/go-gitea/gitea.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://www.codetriage.com/go-gitea/gitea" title="Help Contribute to Open Source">
|
||||||
|
<img src="https://www.codetriage.com/go-gitea/gitea/badges/users.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://opencollective.com/gitea" title="Become a backer/sponsor of gitea">
|
||||||
|
<img src="https://opencollective.com/gitea/tiers/backers/badge.svg?label=backers&color=brightgreen">
|
||||||
|
</a>
|
||||||
|
<a href="https://opensource.org/licenses/MIT" title="License: MIT">
|
||||||
|
<img src="https://img.shields.io/badge/License-MIT-blue.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://gitpod.io/#https://github.com/go-gitea/gitea">
|
||||||
|
<img
|
||||||
|
src="https://img.shields.io/badge/Contribute%20with-Gitpod-908a85?logo=gitpod"
|
||||||
|
alt="Contribute with Gitpod"
|
||||||
|
/>
|
||||||
|
</a>
|
||||||
|
<a href="https://crowdin.com/project/gitea" title="Crowdin">
|
||||||
|
<img src="https://badges.crowdin.net/gitea/localized.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://www.tickgit.com/browse?repo=github.com/go-gitea/gitea&branch=main" title="TODOs">
|
||||||
|
<img src="https://badgen.net/https/api.tickgit.com/badgen/github.com/go-gitea/gitea/main">
|
||||||
|
</a>
|
||||||
|
<a href="https://www.bountysource.com/teams/gitea" title="Bountysource">
|
||||||
|
<img src="https://img.shields.io/bountysource/team/gitea/activity">
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
|
|
||||||
Forgejo was forked from the well-known [Gitea](https://gitea.io) project in 2022,
|
<p align="center">
|
||||||
because we think that the project should be owned by an independent community instead of a for-profit company.
|
<a href="README_ZH.md">View this document in Chinese</a>
|
||||||
If you second that, then Forgejo is for you!
|
</p>
|
||||||
Our promise: **Independent Free/Libre Software forever!**
|
|
||||||
|
|
||||||
|
## Purpose
|
||||||
|
|
||||||
## What does Forgejo offer?
|
The goal of this project is to make the easiest, fastest, and most
|
||||||
|
painless way of setting up a self-hosted Git service.
|
||||||
|
|
||||||
If you want to know what Forgejo is like,
|
As Gitea is written in Go, it works across **all** the platforms and
|
||||||
you can check out public instances<!-- could become link to list -->,
|
architectures that are supported by Go, including Linux, macOS, and
|
||||||
e.g. [Codeberg.org](https://codeberg.org).
|
Windows on x86, amd64, ARM and PowerPC architectures.
|
||||||
|
You can try it out using [the online demo](https://try.gitea.io/).
|
||||||
|
This project has been
|
||||||
|
[forked](https://blog.gitea.io/2016/12/welcome-to-gitea/) from
|
||||||
|
[Gogs](https://gogs.io) since November of 2016, but a lot has changed.
|
||||||
|
|
||||||
If you like any of the following, Forgejo is literally meant for you:
|
## Building
|
||||||
|
|
||||||
- Lightweight: Forgejo can easily be hosted on nearly **every machine**.
|
From the root of the source tree, run:
|
||||||
Running on a Raspberry? Small cloud instance? No problem!
|
|
||||||
- Intuitive: We aim for a user experience that is **friendly** to newcomers and **productive** for power users.
|
|
||||||
- Project management: Besides Git hosting, Forgejo offers issues,
|
|
||||||
pull requests, wikis, kanban boards and much more to **coordinate with your team**.
|
|
||||||
- Publishing: Have something to share? Use **releases** to host your software for download,
|
|
||||||
or use the **package registry** to publish it for docker, npm and many other package managers.
|
|
||||||
- Customizable: Want to change your look? Change some settings?
|
|
||||||
There are many **config switches** to make Forgejo work exactly like you want.
|
|
||||||
- Powerful: Organizations & team permissions, CI integration, Code Search, LDAP, OAuth and much more.
|
|
||||||
If you have **advanced needs**, Forgejo has you covered.
|
|
||||||
- Privacy: From update checker to default settings: Forgejo is built to be **privacy first** for you and your crew.
|
|
||||||
- Federation: (WIP) We are actively working to connect software forges with each other through **ActivityPub**,
|
|
||||||
and create a collaborative network of personal instances.
|
|
||||||
Interested? [Read more below](#Status-of-federation)
|
|
||||||
|
|
||||||
## Learn more
|
TAGS="bindata" make build
|
||||||
|
|
||||||
We're still working on our website.
|
or if SQLite support is required:
|
||||||
In the meantime, you can <a href="https://floss.social/@Forgejo" rel="me">find us on the Fediverse</a> or hop into [our Matrix room](https://matrix.to/#/#Forgejo-chat:matrix.org) if you have any questions or want to get involved.
|
|
||||||
|
|
||||||
|
TAGS="bindata sqlite sqlite_unlock_notify" make build
|
||||||
|
|
||||||
## Get involved
|
The `build` target is split into two sub-targets:
|
||||||
|
|
||||||
If you are interested in making Forgejo better, either by reporting a bug or by changing the governance, please [take a look at the contribution guide](CONTRIBUTING.md).
|
- `make backend` which requires [Go Stable](https://go.dev/dl/), required version is defined in [go.mod](/go.mod).
|
||||||
|
- `make frontend` which requires [Node.js LTS](https://nodejs.org/en/download/) or greater and Internet connectivity to download npm dependencies.
|
||||||
|
|
||||||
|
When building from the official source tarballs which include pre-built frontend files, the `frontend` target will not be triggered, making it possible to build without Node.js and Internet connectivity.
|
||||||
|
|
||||||
|
Parallelism (`make -j <num>`) is not supported.
|
||||||
|
|
||||||
|
More info: https://docs.gitea.io/en-us/install-from-source/
|
||||||
|
|
||||||
|
## Using
|
||||||
|
|
||||||
|
./gitea web
|
||||||
|
|
||||||
|
NOTE: If you're interested in using our APIs, we have experimental
|
||||||
|
support with [documentation](https://try.gitea.io/api/swagger).
|
||||||
|
|
||||||
|
## Contributing
|
||||||
|
|
||||||
|
Expected workflow is: Fork -> Patch -> Push -> Pull Request
|
||||||
|
|
||||||
|
NOTES:
|
||||||
|
|
||||||
|
1. **YOU MUST READ THE [CONTRIBUTORS GUIDE](CONTRIBUTING.md) BEFORE STARTING TO WORK ON A PULL REQUEST.**
|
||||||
|
2. If you have found a vulnerability in the project, please write privately to **security@gitea.io**. Thanks!
|
||||||
|
|
||||||
|
## Translating
|
||||||
|
|
||||||
|
Translations are done through Crowdin. If you want to translate to a new language ask one of the managers in the Crowdin project to add a new language there.
|
||||||
|
|
||||||
|
You can also just create an issue for adding a language or ask on discord on the #translation channel. If you need context or find some translation issues, you can leave a comment on the string or ask on Discord. For general translation questions there is a section in the docs. Currently a bit empty but we hope to fill it as questions pop up.
|
||||||
|
|
||||||
|
https://docs.gitea.io/en-us/translation-guidelines/
|
||||||
|
|
||||||
|
[![Crowdin](https://badges.crowdin.net/gitea/localized.svg)](https://crowdin.com/project/gitea)
|
||||||
|
|
||||||
|
## Further information
|
||||||
|
|
||||||
|
For more information and instructions about how to install Gitea, please look at our [documentation](https://docs.gitea.io/en-us/).
|
||||||
|
If you have questions that are not covered by the documentation, you can get in contact with us on our [Discord server](https://discord.gg/Gitea) or create a post in the [discourse forum](https://discourse.gitea.io/).
|
||||||
|
|
||||||
|
We maintain a list of Gitea-related projects at [gitea/awesome-gitea](https://gitea.com/gitea/awesome-gitea).
|
||||||
|
|
||||||
|
The Hugo-based documentation theme is hosted at [gitea/theme](https://gitea.com/gitea/theme).
|
||||||
|
|
||||||
|
The official Gitea CLI is developed at [gitea/tea](https://gitea.com/gitea/tea).
|
||||||
|
|
||||||
|
## Authors
|
||||||
|
|
||||||
|
- [Maintainers](https://github.com/orgs/go-gitea/people)
|
||||||
|
- [Contributors](https://github.com/go-gitea/gitea/graphs/contributors)
|
||||||
|
- [Translators](options/locale/TRANSLATORS)
|
||||||
|
|
||||||
|
## Backers
|
||||||
|
|
||||||
|
Thank you to all our backers! 🙏 [[Become a backer](https://opencollective.com/gitea#backer)]
|
||||||
|
|
||||||
|
<a href="https://opencollective.com/gitea#backers" target="_blank"><img src="https://opencollective.com/gitea/backers.svg?width=890"></a>
|
||||||
|
|
||||||
|
## Sponsors
|
||||||
|
|
||||||
|
Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [[Become a sponsor](https://opencollective.com/gitea#sponsor)]
|
||||||
|
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/0/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/0/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/1/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/1/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/2/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/2/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/3/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/3/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/4/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/4/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/5/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/5/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/6/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/6/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/7/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/7/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/8/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/8/avatar.svg"></a>
|
||||||
|
<a href="https://opencollective.com/gitea/sponsor/9/website" target="_blank"><img src="https://opencollective.com/gitea/sponsor/9/avatar.svg"></a>
|
||||||
|
<a href="https://cynkra.com/" target="_blank"><img src="https://images.opencollective.com/cynkra/logo/square/64/192.png"></a>
|
||||||
|
|
||||||
|
## FAQ
|
||||||
|
|
||||||
|
**How do you pronounce Gitea?**
|
||||||
|
|
||||||
|
Gitea is pronounced [/ɡɪ’ti:/](https://youtu.be/EM71-2uDAoY) as in "gi-tea" with a hard g.
|
||||||
|
|
||||||
|
**Why is this not hosted on a Gitea instance?**
|
||||||
|
|
||||||
|
We're [working on it](https://github.com/go-gitea/gitea/issues/1029).
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
This project is licensed under the MIT License.
|
||||||
|
See the [LICENSE](https://github.com/go-gitea/gitea/blob/main/LICENSE) file
|
||||||
|
for the full license text.
|
||||||
|
|
||||||
|
## Screenshots
|
||||||
|
|
||||||
|
Looking for an overview of the interface? Check it out!
|
||||||
|
|
||||||
|
|![Dashboard](https://dl.gitea.io/screenshots/home_timeline.png)|![User Profile](https://dl.gitea.io/screenshots/user_profile.png)|![Global Issues](https://dl.gitea.io/screenshots/global_issues.png)|
|
||||||
|
|:---:|:---:|:---:|
|
||||||
|
|![Branches](https://dl.gitea.io/screenshots/branches.png)|![Web Editor](https://dl.gitea.io/screenshots/web_editor.png)|![Activity](https://dl.gitea.io/screenshots/activity.png)|
|
||||||
|
|![New Migration](https://dl.gitea.io/screenshots/migration.png)|![Migrating](https://dl.gitea.io/screenshots/migration.gif)|![Pull Request View](https://image.ibb.co/e02dSb/6.png)
|
||||||
|
![Pull Request Dark](https://dl.gitea.io/screenshots/pull_requests_dark.png)|![Diff Review Dark](https://dl.gitea.io/screenshots/review_dark.png)|![Diff Dark](https://dl.gitea.io/screenshots/diff_dark.png)|
|
||||||
|
|
|
@ -0,0 +1,98 @@
|
||||||
|
<p align="center">
|
||||||
|
<a href="https://gitea.io/">
|
||||||
|
<img alt="Gitea" src="https://raw.githubusercontent.com/go-gitea/gitea/main/public/img/gitea.svg" width="220"/>
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
|
<h1 align="center">Gitea - Git with a cup of tea</h1>
|
||||||
|
|
||||||
|
<p align="center">
|
||||||
|
<a href="https://drone.gitea.io/go-gitea/gitea" title="Build Status">
|
||||||
|
<img src="https://drone.gitea.io/api/badges/go-gitea/gitea/status.svg?ref=refs/heads/main">
|
||||||
|
</a>
|
||||||
|
<a href="https://discord.gg/Gitea" title="Join the Discord chat at https://discord.gg/Gitea">
|
||||||
|
<img src="https://img.shields.io/discord/322538954119184384.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://codecov.io/gh/go-gitea/gitea" title="Codecov">
|
||||||
|
<img src="https://codecov.io/gh/go-gitea/gitea/branch/main/graph/badge.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://goreportcard.com/report/code.gitea.io/gitea" title="Go Report Card">
|
||||||
|
<img src="https://goreportcard.com/badge/code.gitea.io/gitea">
|
||||||
|
</a>
|
||||||
|
<a href="https://godoc.org/code.gitea.io/gitea" title="GoDoc">
|
||||||
|
<img src="https://godoc.org/code.gitea.io/gitea?status.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://github.com/go-gitea/gitea/releases/latest" title="GitHub release">
|
||||||
|
<img src="https://img.shields.io/github/release/go-gitea/gitea.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://www.codetriage.com/go-gitea/gitea" title="Help Contribute to Open Source">
|
||||||
|
<img src="https://www.codetriage.com/go-gitea/gitea/badges/users.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://opencollective.com/gitea" title="Become a backer/sponsor of gitea">
|
||||||
|
<img src="https://opencollective.com/gitea/tiers/backers/badge.svg?label=backers&color=brightgreen">
|
||||||
|
</a>
|
||||||
|
<a href="https://opensource.org/licenses/MIT" title="License: MIT">
|
||||||
|
<img src="https://img.shields.io/badge/License-MIT-blue.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://gitpod.io/#https://github.com/go-gitea/gitea">
|
||||||
|
<img
|
||||||
|
src="https://img.shields.io/badge/Contribute%20with-Gitpod-908a85?logo=gitpod"
|
||||||
|
alt="Contribute with Gitpod"
|
||||||
|
/>
|
||||||
|
</a>
|
||||||
|
<a href="https://crowdin.com/project/gitea" title="Crowdin">
|
||||||
|
<img src="https://badges.crowdin.net/gitea/localized.svg">
|
||||||
|
</a>
|
||||||
|
<a href="https://www.tickgit.com/browse?repo=github.com/go-gitea/gitea&branch=main" title="TODOs">
|
||||||
|
<img src="https://badgen.net/https/api.tickgit.com/badgen/github.com/go-gitea/gitea/main">
|
||||||
|
</a>
|
||||||
|
<a href="https://img.shields.io/bountysource/team/gitea" title="Bountysource">
|
||||||
|
<img src="https://img.shields.io/bountysource/team/gitea/activity">
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p align="center">
|
||||||
|
<a href="README.md">View this document in English</a>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
## 目标
|
||||||
|
|
||||||
|
Gitea 的首要目标是创建一个极易安装,运行非常快速,安装和使用体验良好的自建 Git 服务。我们采用 Go 作为后端语言,这使我们只要生成一个可执行程序即可。并且他还支持跨平台,支持 Linux, macOS 和 Windows 以及各种架构,除了 x86,amd64,还包括 ARM 和 PowerPC。
|
||||||
|
|
||||||
|
如果您想试用一下,请访问 [在线Demo](https://try.gitea.io/)!
|
||||||
|
|
||||||
|
## 提示
|
||||||
|
|
||||||
|
1. **开始贡献代码之前请确保你已经看过了 [贡献者向导(英文)](CONTRIBUTING.md)**.
|
||||||
|
2. 所有的安全问题,请私下发送邮件给 **security@gitea.io**。谢谢!
|
||||||
|
3. 如果你要使用API,请参见 [API 文档](https://godoc.org/code.gitea.io/sdk/gitea).
|
||||||
|
|
||||||
|
## 文档
|
||||||
|
|
||||||
|
关于如何安装请访问我们的 [文档站](https://docs.gitea.io/zh-cn/),如果没有找到对应的文档,你也可以通过 [Discord - 英文](https://discord.gg/gitea) 和 QQ群 328432459 来和我们交流。
|
||||||
|
|
||||||
|
## 贡献流程
|
||||||
|
|
||||||
|
Fork -> Patch -> Push -> Pull Request
|
||||||
|
|
||||||
|
## 翻译
|
||||||
|
|
||||||
|
多语言翻译是基于Crowdin进行的.
|
||||||
|
[![Crowdin](https://badges.crowdin.net/gitea/localized.svg)](https://crowdin.com/project/gitea)
|
||||||
|
|
||||||
|
## 作者
|
||||||
|
|
||||||
|
* [Maintainers](https://github.com/orgs/go-gitea/people)
|
||||||
|
* [Contributors](https://github.com/go-gitea/gitea/graphs/contributors)
|
||||||
|
* [Translators](options/locale/TRANSLATORS)
|
||||||
|
|
||||||
|
## 授权许可
|
||||||
|
|
||||||
|
本项目采用 MIT 开源授权许可证,完整的授权说明已放置在 [LICENSE](https://github.com/go-gitea/gitea/blob/main/LICENSE) 文件中。
|
||||||
|
|
||||||
|
## 截图
|
||||||
|
|
||||||
|
|![Dashboard](https://dl.gitea.io/screenshots/home_timeline.png)|![User Profile](https://dl.gitea.io/screenshots/user_profile.png)|![Global Issues](https://dl.gitea.io/screenshots/global_issues.png)|
|
||||||
|
|:---:|:---:|:---:|
|
||||||
|
|![Branches](https://dl.gitea.io/screenshots/branches.png)|![Web Editor](https://dl.gitea.io/screenshots/web_editor.png)|![Activity](https://dl.gitea.io/screenshots/activity.png)|
|
||||||
|
|![New Migration](https://dl.gitea.io/screenshots/migration.png)|![Migrating](https://dl.gitea.io/screenshots/migration.gif)|![Pull Request View](https://image.ibb.co/e02dSb/6.png)
|
||||||
|
![Pull Request Dark](https://dl.gitea.io/screenshots/pull_requests_dark.png)|![Diff Review Dark](https://dl.gitea.io/screenshots/review_dark.png)|![Diff Dark](https://dl.gitea.io/screenshots/diff_dark.png)|
|
|
@ -0,0 +1,83 @@
|
||||||
|
# Reporting security issues
|
||||||
|
|
||||||
|
The Gitea maintainers take security seriously.
|
||||||
|
|
||||||
|
If you discover a security issue, please bring it to their attention right away!
|
||||||
|
|
||||||
|
## Reporting a Vulnerability
|
||||||
|
|
||||||
|
Please **DO NOT** file a public issue, instead send your report privately to `security@gitea.io`.
|
||||||
|
|
||||||
|
## Protecting Security Information
|
||||||
|
|
||||||
|
Due to the sensitive nature of security information, you can use below GPG public key encrypt your mail body.
|
||||||
|
|
||||||
|
The PGP key is valid until June 24, 2024.
|
||||||
|
|
||||||
|
```
|
||||||
|
Key ID: 6FCD2D5B
|
||||||
|
Key Type: RSA
|
||||||
|
Expires: 6/24/2024
|
||||||
|
Key Size: 4096/4096
|
||||||
|
Fingerprint: 3DE0 3D1E 144A 7F06 9359 99DC AAFD 2381 6FCD 2D5B
|
||||||
|
```
|
||||||
|
|
||||||
|
UserID: Gitea Security <security@gitea.io>
|
||||||
|
|
||||||
|
```
|
||||||
|
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
||||||
|
|
||||||
|
mQINBGK1Z/4BEADFMqXA9DeeChmSxUjF0Be5sq99ZUhgrZjcN/wOzz0wuCJZC0l8
|
||||||
|
4uC+d6mfv7JpJYlzYzOK97/x5UguKHkYNZ6mm1G9KHaXmoIBDLKDzfPdJopVNv2r
|
||||||
|
OajijaE0uMCnMjadlg5pbhMLRQG8a9J32yyaz7ZEAw72Ab31fvvcA53NkuqO4j2w
|
||||||
|
k7dtFQzhbNOYV0VffQT90WDZdalYHB1JHyEQ+70U9OjVD5ggNYSzX98Eu3Hjn7V7
|
||||||
|
kqFrcAxr5TE1elf0IXJcuBJtFzQSTUGlQldKOHtGTGgGjj9r/FFAE5ioBgVD05bV
|
||||||
|
rEEgIMM/GqYaG/nbNpWE6P3mEc2Mnn3pZaRJL0LuF26TLjnqEcMMDp5iIhLdFzXR
|
||||||
|
3tMdtKgQFu+Mtzs3ipwWARYgHyU09RJsI2HeBx7RmZO/Xqrec763Z7zdJ7SpCn0Z
|
||||||
|
q+pHZl24JYR0Kf3T/ZiOC0cGd2QJqpJtg5J6S/OqfX9NH6MsCczO8pUC1N/aHH2X
|
||||||
|
CTme2nF56izORqDWKoiICteL3GpYsCV9nyCidcCmoQsS+DKvE86YhIhVIVWGRY2F
|
||||||
|
lzpAjnN9/KLtQroutrm+Ft0mdjDiJUeFVl1cOHDhoyfCsQh62HumoyZoZvqzQd6e
|
||||||
|
AbN11nq6aViMe2Q3je1AbiBnRnQSHxt1Tc8X4IshO3MQK1Sk7oPI6LA5oQARAQAB
|
||||||
|
tCJHaXRlYSBTZWN1cml0eSA8c2VjdXJpdHlAZ2l0ZWEuaW8+iQJXBBMBCABBFiEE
|
||||||
|
PeA9HhRKfwaTWZncqv0jgW/NLVsFAmK1Z/4CGwMFCQPCZwAFCwkIBwICIgIGFQoJ
|
||||||
|
CAsCBBYCAwECHgcCF4AACgkQqv0jgW/NLVvnyxAAhxyNnWzw/rQO2qhzqicmZM94
|
||||||
|
njSbOg+U2qMBvCdaqCQQeC+uaMmMzkDPanUUmLcyCkWqfCjPNjeSXAkE9npepVJI
|
||||||
|
4HtmgxZQ94OU/h3CLbft+9GVRzUkVI29TSYGdvNtV2/BkNGoFFnKWQr119um0o6A
|
||||||
|
bgha2Uy5uY8o3ZIoiKkiHRaEoWIjjeBxJxYAojsZY4YElUmsQ3ik2joG6rhFesTa
|
||||||
|
ofVt/bL8G2xzpOG26WGIxBbqf2qjV6OtZ0hu/vtTPHeIWMLq0Mz0V3PEDQWfkGPE
|
||||||
|
i2RYxxYDs2xzJhSQWqTNVLSq0m5xTJnbHhQPfdCX4C2jvFKgLdfmytQq49S7jiJb
|
||||||
|
Z03HVOZ/PsyBlQfH9xJi06R5yQCMEA8h8Z5r3/NXW09kQ6OFRe6xshoTcxZGRPTo
|
||||||
|
srhwr3uPbmCRh+YEl7qBLU6+BC5k8IRTZXqhrj/aPJu3MxgbgwV8u3vLoFSXM2lb
|
||||||
|
a61FgeCQ0O7lkgVswwF0RppCaH9Ul3ZDapet/vCRg4NVwm9zOI/8q/Vj0FKA1GDR
|
||||||
|
JhRu8+Ce8zlFL65D34t+PprAzSeTlbv9um3x/ZIjCco7EEKSBylt+AZj/VyA6+e5
|
||||||
|
kjOQwRRc6dFJWBcorsSI2dG+H+QMF7ZabzmeCcz1v9HjLOPzYHoZAHhCmSppWTvX
|
||||||
|
AJy6+lhfW2OUTqQeYSi5Ag0EYrVn/gEQALrFLQjCR3GjuHSindz0rd3Fnx/t7Sen
|
||||||
|
T+p07yCSSoSlmnJHCQmwh4vfg1blyz0zZ4vkIhtpHsEgc+ZAG+WQXSsJ2iRz+eSN
|
||||||
|
GwoOQl4XC3n+QWkc1ws+btr48+6UqXIQU+F8TPQyx/PIgi2nZXJB7f5+mjCqsk46
|
||||||
|
XvH4nTr4kJjuqMSR/++wvre2qNQRa/q/dTsK0OaN/mJsdX6Oi+aGNaQJUhIG7F+E
|
||||||
|
ZDMkn/O6xnwWNzy/+bpg43qH/Gk0eakOmz5NmQLRkV58SZLiJvuCUtkttf6CyhnX
|
||||||
|
03OcWaajv5W8qA39dBYQgDrrPbBWUnwfO3yMveqhwV4JjDoe8sPAyn1NwzakNYqP
|
||||||
|
RzsWyLrLS7R7J9s3FkZXhQw/QQcsaSMcGNQO047dm1P83N8JY5aEpiRo9zSWjoiw
|
||||||
|
qoExANj5lUTZPe8M50lI182FrcjAN7dClO3QI6pg7wy0erMxfFly3j8UQ91ysS9T
|
||||||
|
s+GsP9I3cmWWQcKYxWHtE8xTXnNCVPFZQj2nwhJzae8ypfOtulBRA3dUKWGKuDH/
|
||||||
|
axFENhUsT397aOU3qkP/od4a64JyNIEo4CTTSPVeWd7njsGqli2U3A4xL2CcyYvt
|
||||||
|
D/MWcMBGEoLSNTswwKdom4FaJpn5KThnK/T0bQcmJblJhoCtppXisbexZnCpuS0x
|
||||||
|
Zdlm2T14KJ3LABEBAAGJAjwEGAEIACYWIQQ94D0eFEp/BpNZmdyq/SOBb80tWwUC
|
||||||
|
YrVn/gIbDAUJA8JnAAAKCRCq/SOBb80tWyTBD/9AGpW6QoDF7zYjHAozH9S5RGCA
|
||||||
|
Y7E82dG/0xmFUwPprAG0BKmmgU6TiipyVGmKIXGYYYU92pMnbvXkYQMoa+WJNncN
|
||||||
|
D3fY52UeXeffTf4cFpStlzi9xgYtOLhFamzYu/4xhkjOX+xhOSXscCiFRyT8cF3B
|
||||||
|
O6c5BHU+Zj0/rGPgOyPUbx7l7B9MubB/41nNX35k08e+8T3wtWDb4XF+15HnRfva
|
||||||
|
6fblO8wgU25Orv2Rm1jnKGa9DxJ8nE40IMrqDapENtDuL+zKJsvR0+ptWvEyL56U
|
||||||
|
GtJJG5un6mXiLKuRQT0DEv4MdZRHDgDstDnqcbEiazVEbUuvhZZob6lRY2A19m1+
|
||||||
|
7zfnDxkhqCA1RCnv4fdvcPdCMMFHwLpdhjgW0aI/uwgwrvsEz5+JRlnLvdQHlPAg
|
||||||
|
q7l2fGcBSpz9U0ayyfRPjPntsNCtZl1UDxGLeciPkZhyG84zEWQbk/j52ZpRN+Ik
|
||||||
|
ALpRLa8RBFmFSmXDUmwQrmm1EmARyQXwweKU31hf8ZGbCp2lPuRYm1LuGiirXSVP
|
||||||
|
GysjRAJgW+VRpBKOzFQoUAUbReVWSaCwT8s17THzf71DdDb6CTj31jMLLYWwBpA/
|
||||||
|
i73DgobDZMIGEZZC1EKqza8eh11xfyHFzGec03tbh+lIen+5IiRtWiEWkDS9ll0G
|
||||||
|
zgS/ZdziCvdAutqnGA==
|
||||||
|
=gZWO
|
||||||
|
-----END PGP PUBLIC KEY BLOCK-----
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
Security reports are greatly appreciated and we will publicly thank you for it, although we keep your name confidential if you request it.
|
File diff suppressed because one or more lines are too long
4
build.go
4
build.go
|
@ -1,6 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
//go:build vendor
|
//go:build vendor
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2021 The Gitea Authors. All rights reserved.
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
//go:build ignore
|
//go:build ignore
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2021 The Gitea Authors. All rights reserved.
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package codeformat
|
package codeformat
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2021 The Gitea Authors. All rights reserved.
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package codeformat
|
package codeformat
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
//go:build ignore
|
//go:build ignore
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// Copyright 2015 Kenneth Shaw
|
// Copyright 2015 Kenneth Shaw
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
//go:build ignore
|
//go:build ignore
|
||||||
|
|
||||||
|
@ -208,8 +209,8 @@ func generate() ([]byte, error) {
|
||||||
|
|
||||||
const hdr = `
|
const hdr = `
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package emoji
|
package emoji
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2022 The Gitea Authors. All rights reserved.
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
//go:build ignore
|
//go:build ignore
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// Copyright (c) 2015, Wade Simmons
|
// Copyright (c) 2015, Wade Simmons
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
// gocovmerge takes the results from multiple `go test -coverprofile` runs and
|
// gocovmerge takes the results from multiple `go test -coverprofile` runs and
|
||||||
// merges them into one profile
|
// merges them into one profile
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Copyright 2016 The Gogs Authors. All rights reserved.
|
// Copyright 2016 The Gogs Authors. All rights reserved.
|
||||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
@ -665,7 +666,7 @@ func runDeleteUser(c *cli.Context) error {
|
||||||
} else if c.IsSet("username") {
|
} else if c.IsSet("username") {
|
||||||
user, err = user_model.GetUserByName(ctx, c.String("username"))
|
user, err = user_model.GetUserByName(ctx, c.String("username"))
|
||||||
} else {
|
} else {
|
||||||
user, err = user_model.GetUserByID(ctx, c.Int64("id"))
|
user, err = user_model.GetUserByID(c.Int64("id"))
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -726,7 +727,7 @@ func runRepoSyncReleases(_ *cli.Context) error {
|
||||||
|
|
||||||
log.Trace("Synchronizing repository releases (this may take a while)")
|
log.Trace("Synchronizing repository releases (this may take a while)")
|
||||||
for page := 1; ; page++ {
|
for page := 1; ; page++ {
|
||||||
repos, count, err := repo_model.SearchRepositoryByName(ctx, &repo_model.SearchRepoOptions{
|
repos, count, err := repo_model.SearchRepositoryByName(&repo_model.SearchRepoOptions{
|
||||||
ListOptions: db.ListOptions{
|
ListOptions: db.ListOptions{
|
||||||
PageSize: repo_model.RepositoryListDefaultPageSize,
|
PageSize: repo_model.RepositoryListDefaultPageSize,
|
||||||
Page: page,
|
Page: page,
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2019 The Gitea Authors. All rights reserved.
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2019 The Gitea Authors. All rights reserved.
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
// Copyright 2009 The Go Authors. All rights reserved.
|
// Copyright 2009 The Go Authors. All rights reserved.
|
||||||
// Copyright 2014 The Gogs Authors. All rights reserved.
|
// Copyright 2014 The Gogs Authors. All rights reserved.
|
||||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2018 The Gitea Authors. All rights reserved.
|
// Copyright 2018 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
// Package cmd provides subcommands to the gitea binary - such as "web" or
|
// Package cmd provides subcommands to the gitea binary - such as "web" or
|
||||||
// "admin".
|
// "admin".
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2019 The Gitea Authors. All rights reserved.
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2019 The Gitea Authors. All rights reserved.
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
@ -13,7 +14,6 @@ import (
|
||||||
|
|
||||||
"code.gitea.io/gitea/models/db"
|
"code.gitea.io/gitea/models/db"
|
||||||
"code.gitea.io/gitea/models/migrations"
|
"code.gitea.io/gitea/models/migrations"
|
||||||
migrate_base "code.gitea.io/gitea/models/migrations/base"
|
|
||||||
"code.gitea.io/gitea/modules/doctor"
|
"code.gitea.io/gitea/modules/doctor"
|
||||||
"code.gitea.io/gitea/modules/log"
|
"code.gitea.io/gitea/modules/log"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
@ -114,7 +114,7 @@ func runRecreateTable(ctx *cli.Context) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
recreateTables := migrate_base.RecreateTables(beans...)
|
recreateTables := migrations.RecreateTables(beans...)
|
||||||
|
|
||||||
return db.InitEngineWithMigration(stdCtx, func(x *xorm.Engine) error {
|
return db.InitEngineWithMigration(stdCtx, func(x *xorm.Engine) error {
|
||||||
if err := migrations.EnsureUpToDate(x); err != nil {
|
if err := migrations.EnsureUpToDate(x); err != nil {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Copyright 2014 The Gogs Authors. All rights reserved.
|
// Copyright 2014 The Gogs Authors. All rights reserved.
|
||||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
//go:build bindata
|
//go:build bindata
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
//go:build !bindata
|
//go:build !bindata
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Copyright 2016 The Gogs Authors. All rights reserved.
|
// Copyright 2016 The Gogs Authors. All rights reserved.
|
||||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
11
cmd/hook.go
11
cmd/hook.go
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2017 The Gitea Authors. All rights reserved.
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
@ -217,9 +218,9 @@ Gitea or set your environment appropriately.`, "")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
supportProcReceive := false
|
supportProcRecive := false
|
||||||
if git.CheckGitVersionAtLeast("2.29") == nil {
|
if git.CheckGitVersionAtLeast("2.29") == nil {
|
||||||
supportProcReceive = true
|
supportProcRecive = true
|
||||||
}
|
}
|
||||||
|
|
||||||
for scanner.Scan() {
|
for scanner.Scan() {
|
||||||
|
@ -240,9 +241,9 @@ Gitea or set your environment appropriately.`, "")
|
||||||
lastline++
|
lastline++
|
||||||
|
|
||||||
// If the ref is a branch or tag, check if it's protected
|
// If the ref is a branch or tag, check if it's protected
|
||||||
// if supportProcReceive all ref should be checked because
|
// if supportProcRecive all ref should be checked because
|
||||||
// permission check was delayed
|
// permission check was delayed
|
||||||
if supportProcReceive || strings.HasPrefix(refFullName, git.BranchPrefix) || strings.HasPrefix(refFullName, git.TagPrefix) {
|
if supportProcRecive || strings.HasPrefix(refFullName, git.BranchPrefix) || strings.HasPrefix(refFullName, git.TagPrefix) {
|
||||||
oldCommitIDs[count] = oldCommitID
|
oldCommitIDs[count] = oldCommitID
|
||||||
newCommitIDs[count] = newCommitID
|
newCommitIDs[count] = newCommitID
|
||||||
refFullNames[count] = refFullName
|
refFullNames[count] = refFullName
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2021 The Gitea Authors. All rights reserved.
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2018 The Gitea Authors. All rights reserved.
|
// Copyright 2018 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2022 The Gitea Authors. All rights reserved.
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2022 The Gitea Authors. All rights reserved.
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2018 The Gitea Authors. All rights reserved.
|
// Copyright 2018 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
@ -82,35 +83,35 @@ var CmdMigrateStorage = cli.Command{
|
||||||
}
|
}
|
||||||
|
|
||||||
func migrateAttachments(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
func migrateAttachments(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
||||||
return db.Iterate(ctx, nil, func(ctx context.Context, attach *repo_model.Attachment) error {
|
return db.IterateObjects(ctx, func(attach *repo_model.Attachment) error {
|
||||||
_, err := storage.Copy(dstStorage, attach.RelativePath(), storage.Attachments, attach.RelativePath())
|
_, err := storage.Copy(dstStorage, attach.RelativePath(), storage.Attachments, attach.RelativePath())
|
||||||
return err
|
return err
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func migrateLFS(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
func migrateLFS(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
||||||
return db.Iterate(ctx, nil, func(ctx context.Context, mo *git_model.LFSMetaObject) error {
|
return db.IterateObjects(ctx, func(mo *git_model.LFSMetaObject) error {
|
||||||
_, err := storage.Copy(dstStorage, mo.RelativePath(), storage.LFS, mo.RelativePath())
|
_, err := storage.Copy(dstStorage, mo.RelativePath(), storage.LFS, mo.RelativePath())
|
||||||
return err
|
return err
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func migrateAvatars(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
func migrateAvatars(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
||||||
return db.Iterate(ctx, nil, func(ctx context.Context, user *user_model.User) error {
|
return db.IterateObjects(ctx, func(user *user_model.User) error {
|
||||||
_, err := storage.Copy(dstStorage, user.CustomAvatarRelativePath(), storage.Avatars, user.CustomAvatarRelativePath())
|
_, err := storage.Copy(dstStorage, user.CustomAvatarRelativePath(), storage.Avatars, user.CustomAvatarRelativePath())
|
||||||
return err
|
return err
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func migrateRepoAvatars(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
func migrateRepoAvatars(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
||||||
return db.Iterate(ctx, nil, func(ctx context.Context, repo *repo_model.Repository) error {
|
return db.IterateObjects(ctx, func(repo *repo_model.Repository) error {
|
||||||
_, err := storage.Copy(dstStorage, repo.CustomAvatarRelativePath(), storage.RepoAvatars, repo.CustomAvatarRelativePath())
|
_, err := storage.Copy(dstStorage, repo.CustomAvatarRelativePath(), storage.RepoAvatars, repo.CustomAvatarRelativePath())
|
||||||
return err
|
return err
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func migrateRepoArchivers(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
func migrateRepoArchivers(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
||||||
return db.Iterate(ctx, nil, func(ctx context.Context, archiver *repo_model.RepoArchiver) error {
|
return db.IterateObjects(ctx, func(archiver *repo_model.RepoArchiver) error {
|
||||||
p := archiver.RelativePath()
|
p := archiver.RelativePath()
|
||||||
_, err := storage.Copy(dstStorage, p, storage.RepoArchives, p)
|
_, err := storage.Copy(dstStorage, p, storage.RepoArchives, p)
|
||||||
return err
|
return err
|
||||||
|
@ -118,7 +119,7 @@ func migrateRepoArchivers(ctx context.Context, dstStorage storage.ObjectStorage)
|
||||||
}
|
}
|
||||||
|
|
||||||
func migratePackages(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
func migratePackages(ctx context.Context, dstStorage storage.ObjectStorage) error {
|
||||||
return db.Iterate(ctx, nil, func(ctx context.Context, pb *packages_model.PackageBlob) error {
|
return db.IterateObjects(ctx, func(pb *packages_model.PackageBlob) error {
|
||||||
p := packages_module.KeyToRelativePath(packages_module.BlobHash256Key(pb.HashSHA256))
|
p := packages_module.KeyToRelativePath(packages_module.BlobHash256Key(pb.HashSHA256))
|
||||||
_, err := storage.Copy(dstStorage, p, storage.Packages, p)
|
_, err := storage.Copy(dstStorage, p, storage.Packages, p)
|
||||||
return err
|
return err
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2022 The Gitea Authors. All rights reserved.
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
@ -43,9 +44,8 @@ func TestMigratePackages(t *testing.T) {
|
||||||
PackageFileInfo: packages_service.PackageFileInfo{
|
PackageFileInfo: packages_service.PackageFileInfo{
|
||||||
Filename: "a.go",
|
Filename: "a.go",
|
||||||
},
|
},
|
||||||
Creator: creator,
|
Data: buf,
|
||||||
Data: buf,
|
IsLead: true,
|
||||||
IsLead: true,
|
|
||||||
})
|
})
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.NotNil(t, v)
|
assert.NotNil(t, v)
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// Copyright 2014 The Gogs Authors. All rights reserved.
|
// Copyright 2014 The Gogs Authors. All rights reserved.
|
||||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2014 The Gogs Authors. All rights reserved.
|
// Copyright 2014 The Gogs Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2021 The Gitea Authors. All rights reserved.
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2019 The Gitea Authors. All rights reserved.
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package main
|
package main
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package main
|
package main
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Copyright 2020 The Gitea Authors. All rights reserved.
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
// SPDX-License-Identifier: MIT
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
package main
|
package main
|
||||||
|
|
||||||
|
|
|
@ -7,38 +7,6 @@
|
||||||
;; see https://docs.gitea.io/en-us/config-cheat-sheet/ for additional documentation.
|
;; see https://docs.gitea.io/en-us/config-cheat-sheet/ for additional documentation.
|
||||||
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
||||||
;; Default Configuration (non-`app.ini` configuration)
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
||||||
;;
|
|
||||||
;; These values are environment-dependent but form the basis of a lot of values. They will be
|
|
||||||
;; reported as part of the default configuration when running `gitea --help` or on start-up. The order they are emitted there is slightly different but we will list them here in the order they are set-up.
|
|
||||||
;;
|
|
||||||
;; - _`AppPath`_: This is the absolute path of the running gitea binary.
|
|
||||||
;; - _`AppWorkPath`_: This refers to "working path" of the `gitea` binary. It is determined by using the first set thing in the following hierarchy:
|
|
||||||
;; - The `--work-path` flag passed to the binary
|
|
||||||
;; - The environment variable `$GITEA_WORK_DIR`
|
|
||||||
;; - A built-in value set at build time (see building from source)
|
|
||||||
;; - Otherwise it defaults to the directory of the _`AppPath`_
|
|
||||||
;; - If any of the above are relative paths then they are made absolute against the
|
|
||||||
;; the directory of the _`AppPath`_
|
|
||||||
;; - _`CustomPath`_: This is the base directory for custom templates and other options.
|
|
||||||
;; It is determined by using the first set thing in the following hierarchy:
|
|
||||||
;; - The `--custom-path` flag passed to the binary
|
|
||||||
;; - The environment variable `$GITEA_CUSTOM`
|
|
||||||
;; - A built-in value set at build time (see building from source)
|
|
||||||
;; - Otherwise it defaults to _`AppWorkPath`_`/custom`
|
|
||||||
;; - If any of the above are relative paths then they are made absolute against the
|
|
||||||
;; the directory of the _`AppWorkPath`_
|
|
||||||
;; - _`CustomConf`_: This is the path to the `app.ini` file.
|
|
||||||
;; - The `--config` flag passed to the binary
|
|
||||||
;; - A built-in value set at build time (see building from source)
|
|
||||||
;; - Otherwise it defaults to _`CustomPath`_`/conf/app.ini`
|
|
||||||
;; - If any of the above are relative paths then they are made absolute against the
|
|
||||||
;; the directory of the _`CustomPath`_
|
|
||||||
;;
|
|
||||||
;; In addition there is _`StaticRootPath`_ which can be set as a built-in at build time, but will otherwise default to _`AppWorkPath`_
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;; General Settings
|
;; General Settings
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
@ -58,7 +26,7 @@ RUN_MODE = ; prod
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;;
|
;;
|
||||||
;; The protocol the server listens on. One of 'http', 'https', 'http+unix', 'fcgi' or 'fcgi+unix'. Defaults to 'http'
|
;; The protocol the server listens on. One of 'http', 'https', 'unix' or 'fcgi'. Defaults to 'http'
|
||||||
;PROTOCOL = http
|
;PROTOCOL = http
|
||||||
;;
|
;;
|
||||||
;; Expect PROXY protocol headers on connections
|
;; Expect PROXY protocol headers on connections
|
||||||
|
@ -83,8 +51,6 @@ RUN_MODE = ; prod
|
||||||
;STATIC_URL_PREFIX =
|
;STATIC_URL_PREFIX =
|
||||||
;;
|
;;
|
||||||
;; The address to listen on. Either a IPv4/IPv6 address or the path to a unix socket.
|
;; The address to listen on. Either a IPv4/IPv6 address or the path to a unix socket.
|
||||||
;; If PROTOCOL is set to `http+unix` or `fcgi+unix`, this should be the name of the Unix socket file to use.
|
|
||||||
;; Relative paths will be made absolute against the _`AppWorkPath`_.
|
|
||||||
;HTTP_ADDR = 0.0.0.0
|
;HTTP_ADDR = 0.0.0.0
|
||||||
;;
|
;;
|
||||||
;; The port to listen on. Leave empty when using a unix socket.
|
;; The port to listen on. Leave empty when using a unix socket.
|
||||||
|
@ -98,7 +64,7 @@ RUN_MODE = ; prod
|
||||||
;PORT_TO_REDIRECT = 80
|
;PORT_TO_REDIRECT = 80
|
||||||
;;
|
;;
|
||||||
;; expect PROXY protocol header on connections to https redirector.
|
;; expect PROXY protocol header on connections to https redirector.
|
||||||
;REDIRECTOR_USE_PROXY_PROTOCOL = %(USE_PROXY_PROTOCOL)s
|
;REDIRECTOR_USE_PROXY_PROTOCOL = %(USE_PROXY_PROTOCOL)
|
||||||
;; Minimum and maximum supported TLS versions
|
;; Minimum and maximum supported TLS versions
|
||||||
;SSL_MIN_VERSION=TLSv1.2
|
;SSL_MIN_VERSION=TLSv1.2
|
||||||
;SSL_MAX_VERSION=
|
;SSL_MAX_VERSION=
|
||||||
|
@ -125,7 +91,7 @@ RUN_MODE = ; prod
|
||||||
;LOCAL_ROOT_URL = %(PROTOCOL)s://%(HTTP_ADDR)s:%(HTTP_PORT)s/
|
;LOCAL_ROOT_URL = %(PROTOCOL)s://%(HTTP_ADDR)s:%(HTTP_PORT)s/
|
||||||
;;
|
;;
|
||||||
;; When making local connections pass the PROXY protocol header.
|
;; When making local connections pass the PROXY protocol header.
|
||||||
;LOCAL_USE_PROXY_PROTOCOL = %(USE_PROXY_PROTOCOL)s
|
;LOCAL_USE_PROXY_PROTOCOL = %(USE_PROXY_PROTOCOL)
|
||||||
;;
|
;;
|
||||||
;; Disable SSH feature when not available
|
;; Disable SSH feature when not available
|
||||||
;DISABLE_SSH = false
|
;DISABLE_SSH = false
|
||||||
|
@ -179,7 +145,7 @@ RUN_MODE = ; prod
|
||||||
;;
|
;;
|
||||||
;; For the built-in SSH server, choose the keypair to offer as the host key
|
;; For the built-in SSH server, choose the keypair to offer as the host key
|
||||||
;; The private key should be at SSH_SERVER_HOST_KEY and the public SSH_SERVER_HOST_KEY.pub
|
;; The private key should be at SSH_SERVER_HOST_KEY and the public SSH_SERVER_HOST_KEY.pub
|
||||||
;; relative paths are made absolute relative to the %(APP_DATA_PATH)s
|
;; relative paths are made absolute relative to the APP_DATA_PATH
|
||||||
;SSH_SERVER_HOST_KEYS=ssh/gitea.rsa, ssh/gogs.rsa
|
;SSH_SERVER_HOST_KEYS=ssh/gitea.rsa, ssh/gogs.rsa
|
||||||
;;
|
;;
|
||||||
;; Directory to create temporary files in when testing public keys using ssh-keygen,
|
;; Directory to create temporary files in when testing public keys using ssh-keygen,
|
||||||
|
@ -275,10 +241,10 @@ RUN_MODE = ; prod
|
||||||
;;
|
;;
|
||||||
;; Root directory containing templates and static files.
|
;; Root directory containing templates and static files.
|
||||||
;; default is the path where Gitea is executed
|
;; default is the path where Gitea is executed
|
||||||
;STATIC_ROOT_PATH = ; Will default to the built-in value _`StaticRootPath`_
|
;STATIC_ROOT_PATH =
|
||||||
;;
|
;;
|
||||||
;; Default path for App data
|
;; Default path for App data
|
||||||
;APP_DATA_PATH = data ; relative paths will be made absolute with _`AppWorkPath`_
|
;APP_DATA_PATH = data
|
||||||
;;
|
;;
|
||||||
;; Enable gzip compression for runtime-generated content, static resources excluded
|
;; Enable gzip compression for runtime-generated content, static resources excluded
|
||||||
;ENABLE_GZIP = false
|
;ENABLE_GZIP = false
|
||||||
|
@ -289,7 +255,7 @@ RUN_MODE = ; prod
|
||||||
;ENABLE_PPROF = false
|
;ENABLE_PPROF = false
|
||||||
;;
|
;;
|
||||||
;; PPROF_DATA_PATH, use an absolute path when you start gitea as service
|
;; PPROF_DATA_PATH, use an absolute path when you start gitea as service
|
||||||
;PPROF_DATA_PATH = data/tmp/pprof ; Path is relative to _`AppWorkPath`_
|
;PPROF_DATA_PATH = data/tmp/pprof
|
||||||
;;
|
;;
|
||||||
;; Landing page, can be "home", "explore", "organizations", "login", or any URL such as "/org/repo" or even "https://anotherwebsite.com"
|
;; Landing page, can be "home", "explore", "organizations", "login", or any URL such as "/org/repo" or even "https://anotherwebsite.com"
|
||||||
;; The "login" choice is not a security measure but just a UI flow change, use REQUIRE_SIGNIN_VIEW to force users to log in.
|
;; The "login" choice is not a security measure but just a UI flow change, use REQUIRE_SIGNIN_VIEW to force users to log in.
|
||||||
|
@ -667,7 +633,7 @@ ROUTER = console
|
||||||
;PATH =
|
;PATH =
|
||||||
;;
|
;;
|
||||||
;; The HOME directory for Git
|
;; The HOME directory for Git
|
||||||
;HOME_PATH = %(APP_DATA_PATH)s/home
|
;HOME_PATH = %(APP_DATA_PATH)/home
|
||||||
;;
|
;;
|
||||||
;; Disables highlight of added and removed changes
|
;; Disables highlight of added and removed changes
|
||||||
;DISABLE_DIFF_HIGHLIGHT = false
|
;DISABLE_DIFF_HIGHLIGHT = false
|
||||||
|
@ -759,9 +725,6 @@ ROUTER = console
|
||||||
;; Enable captcha validation for registration
|
;; Enable captcha validation for registration
|
||||||
;ENABLE_CAPTCHA = false
|
;ENABLE_CAPTCHA = false
|
||||||
;;
|
;;
|
||||||
;; Enable this to require captcha validation for login
|
|
||||||
;REQUIRE_CAPTCHA_FOR_LOGIN = false
|
|
||||||
;;
|
|
||||||
;; Type of captcha you want to use. Options: image, recaptcha, hcaptcha, mcaptcha.
|
;; Type of captcha you want to use. Options: image, recaptcha, hcaptcha, mcaptcha.
|
||||||
;CAPTCHA_TYPE = image
|
;CAPTCHA_TYPE = image
|
||||||
;;
|
;;
|
||||||
|
@ -875,8 +838,8 @@ ROUTER = console
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;[repository]
|
;[repository]
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;; Root path for storing all repository data. By default, it is set to %(APP_DATA_PATH)s/gitea-repositories.
|
;; Root path for storing all repository data. By default, it is set to %(APP_DATA_PATH)/gitea-repositories.
|
||||||
;; A relative path is interpreted as _`AppWorkPath`_/%(ROOT)s
|
;; A relative path is interpreted as %(GITEA_WORK_DIR)/%(ROOT)
|
||||||
;ROOT =
|
;ROOT =
|
||||||
;;
|
;;
|
||||||
;; The script type this server supports. Usually this is `bash`, but some users report that only `sh` is available.
|
;; The script type this server supports. Usually this is `bash`, but some users report that only `sh` is available.
|
||||||
|
@ -1141,9 +1104,6 @@ ROUTER = console
|
||||||
;; allow request with credentials
|
;; allow request with credentials
|
||||||
;ALLOW_CREDENTIALS = false
|
;ALLOW_CREDENTIALS = false
|
||||||
;;
|
;;
|
||||||
;; headers to permit
|
|
||||||
;HEADERS = Content-Type,User-Agent
|
|
||||||
;;
|
|
||||||
;; set X-FRAME-OPTIONS header
|
;; set X-FRAME-OPTIONS header
|
||||||
;X_FRAME_OPTIONS = SAMEORIGIN
|
;X_FRAME_OPTIONS = SAMEORIGIN
|
||||||
|
|
||||||
|
@ -1336,7 +1296,7 @@ ROUTER = console
|
||||||
;ISSUE_INDEXER_TYPE = bleve
|
;ISSUE_INDEXER_TYPE = bleve
|
||||||
;;
|
;;
|
||||||
;; Issue indexer storage path, available when ISSUE_INDEXER_TYPE is bleve
|
;; Issue indexer storage path, available when ISSUE_INDEXER_TYPE is bleve
|
||||||
;ISSUE_INDEXER_PATH = indexers/issues.bleve ; Relative paths will be made absolute against _`AppWorkPath`_.
|
;ISSUE_INDEXER_PATH = indexers/issues.bleve
|
||||||
;;
|
;;
|
||||||
;; Issue indexer connection string, available when ISSUE_INDEXER_TYPE is elasticsearch
|
;; Issue indexer connection string, available when ISSUE_INDEXER_TYPE is elasticsearch
|
||||||
;ISSUE_INDEXER_CONN_STR = http://elastic:changeme@localhost:9200
|
;ISSUE_INDEXER_CONN_STR = http://elastic:changeme@localhost:9200
|
||||||
|
@ -1354,7 +1314,7 @@ ROUTER = console
|
||||||
;; When ISSUE_INDEXER_QUEUE_TYPE is levelqueue, this will be the path where the queue will be saved.
|
;; When ISSUE_INDEXER_QUEUE_TYPE is levelqueue, this will be the path where the queue will be saved.
|
||||||
;; This can be overridden by `ISSUE_INDEXER_QUEUE_CONN_STR`.
|
;; This can be overridden by `ISSUE_INDEXER_QUEUE_CONN_STR`.
|
||||||
;; default is queues/common
|
;; default is queues/common
|
||||||
;ISSUE_INDEXER_QUEUE_DIR = queues/common; **DEPRECATED** use settings in `[queue.issue_indexer]`. Relative paths will be made absolute against `%(APP_DATA_PATH)s`.
|
;ISSUE_INDEXER_QUEUE_DIR = queues/common; **DEPRECATED** use settings in `[queue.issue_indexer]`.
|
||||||
;;
|
;;
|
||||||
;; When `ISSUE_INDEXER_QUEUE_TYPE` is `redis`, this will store the redis connection string.
|
;; When `ISSUE_INDEXER_QUEUE_TYPE` is `redis`, this will store the redis connection string.
|
||||||
;; When `ISSUE_INDEXER_QUEUE_TYPE` is `levelqueue`, this is a directory or additional options of
|
;; When `ISSUE_INDEXER_QUEUE_TYPE` is `levelqueue`, this is a directory or additional options of
|
||||||
|
@ -1410,7 +1370,7 @@ ROUTER = console
|
||||||
;TYPE = persistable-channel
|
;TYPE = persistable-channel
|
||||||
;;
|
;;
|
||||||
;; data-dir for storing persistable queues and level queues, individual queues will default to `queues/common` meaning the queue is shared.
|
;; data-dir for storing persistable queues and level queues, individual queues will default to `queues/common` meaning the queue is shared.
|
||||||
;DATADIR = queues/ ; Relative paths will be made absolute against `%(APP_DATA_PATH)s`.
|
;DATADIR = queues/
|
||||||
;;
|
;;
|
||||||
;; Default queue length before a channel queue will block
|
;; Default queue length before a channel queue will block
|
||||||
;LENGTH = 20
|
;LENGTH = 20
|
||||||
|
@ -1590,7 +1550,7 @@ ROUTER = console
|
||||||
;; Prefix displayed before subject in mail
|
;; Prefix displayed before subject in mail
|
||||||
;SUBJECT_PREFIX =
|
;SUBJECT_PREFIX =
|
||||||
;;
|
;;
|
||||||
;; Mail server protocol. One of "smtp", "smtps", "smtp+starttls", "smtp+unix", "sendmail", "dummy".
|
;; Mail server protocol. One of "smtp", "smtps", "smtp+startls", "smtp+unix", "sendmail", "dummy".
|
||||||
;; - sendmail: use the operating system's `sendmail` command instead of SMTP. This is common on Linux systems.
|
;; - sendmail: use the operating system's `sendmail` command instead of SMTP. This is common on Linux systems.
|
||||||
;; - dummy: send email messages to the log as a testing phase.
|
;; - dummy: send email messages to the log as a testing phase.
|
||||||
;; If your provider does not explicitly say which protocol it uses but does provide a port,
|
;; If your provider does not explicitly say which protocol it uses but does provide a port,
|
||||||
|
@ -1712,7 +1672,7 @@ ROUTER = console
|
||||||
;; file: session file path, e.g. `data/sessions`
|
;; file: session file path, e.g. `data/sessions`
|
||||||
;; redis: network=tcp,addr=:6379,password=macaron,db=0,pool_size=100,idle_timeout=180
|
;; redis: network=tcp,addr=:6379,password=macaron,db=0,pool_size=100,idle_timeout=180
|
||||||
;; mysql: go-sql-driver/mysql dsn config string, e.g. `root:password@/session_table`
|
;; mysql: go-sql-driver/mysql dsn config string, e.g. `root:password@/session_table`
|
||||||
;PROVIDER_CONFIG = data/sessions ; Relative paths will be made absolute against _`AppWorkPath`_.
|
;PROVIDER_CONFIG = data/sessions
|
||||||
;;
|
;;
|
||||||
;; Session cookie name
|
;; Session cookie name
|
||||||
;COOKIE_NAME = i_like_gitea
|
;COOKIE_NAME = i_like_gitea
|
||||||
|
@ -2236,10 +2196,7 @@ ROUTER = console
|
||||||
;SHOW_FOOTER_VERSION = true
|
;SHOW_FOOTER_VERSION = true
|
||||||
;; Show template execution time in the footer
|
;; Show template execution time in the footer
|
||||||
;SHOW_FOOTER_TEMPLATE_LOAD_TIME = true
|
;SHOW_FOOTER_TEMPLATE_LOAD_TIME = true
|
||||||
;; Generate sitemap. Defaults to `true`.
|
|
||||||
;ENABLE_SITEMAP = true
|
|
||||||
;; Enable/Disable RSS/Atom feed
|
|
||||||
;ENABLE_FEED = true
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
@ -2377,35 +2334,6 @@ ROUTER = console
|
||||||
;;
|
;;
|
||||||
;; Path for chunked uploads. Defaults to APP_DATA_PATH + `tmp/package-upload`
|
;; Path for chunked uploads. Defaults to APP_DATA_PATH + `tmp/package-upload`
|
||||||
;CHUNKED_UPLOAD_PATH = tmp/package-upload
|
;CHUNKED_UPLOAD_PATH = tmp/package-upload
|
||||||
;;
|
|
||||||
;; Maximum count of package versions a single owner can have (`-1` means no limits)
|
|
||||||
;LIMIT_TOTAL_OWNER_COUNT = -1
|
|
||||||
;; Maximum size of packages a single owner can use (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_TOTAL_OWNER_SIZE = -1
|
|
||||||
;; Maximum size of a Composer upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_COMPOSER = -1
|
|
||||||
;; Maximum size of a Conan upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_CONAN = -1
|
|
||||||
;; Maximum size of a Container upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_CONTAINER = -1
|
|
||||||
;; Maximum size of a Generic upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_GENERIC = -1
|
|
||||||
;; Maximum size of a Helm upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_HELM = -1
|
|
||||||
;; Maximum size of a Maven upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_MAVEN = -1
|
|
||||||
;; Maximum size of a npm upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_NPM = -1
|
|
||||||
;; Maximum size of a NuGet upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_NUGET = -1
|
|
||||||
;; Maximum size of a Pub upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_PUB = -1
|
|
||||||
;; Maximum size of a PyPI upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_PYPI = -1
|
|
||||||
;; Maximum size of a RubyGems upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_RUBYGEMS = -1
|
|
||||||
;; Maximum size of a Vagrant upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
;LIMIT_SIZE_VAGRANT = -1
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
|
@ -14,6 +14,11 @@ if [ ! -f /data/ssh/ssh_host_rsa_key ]; then
|
||||||
ssh-keygen -t rsa -b 2048 -f /data/ssh/ssh_host_rsa_key -N "" > /dev/null
|
ssh-keygen -t rsa -b 2048 -f /data/ssh/ssh_host_rsa_key -N "" > /dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ ! -f /data/ssh/ssh_host_dsa_key ]; then
|
||||||
|
echo "Generating /data/ssh/ssh_host_dsa_key..."
|
||||||
|
ssh-keygen -t dsa -f /data/ssh/ssh_host_dsa_key -N "" > /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
if [ ! -f /data/ssh/ssh_host_ecdsa_key ]; then
|
if [ ! -f /data/ssh/ssh_host_ecdsa_key ]; then
|
||||||
echo "Generating /data/ssh/ssh_host_ecdsa_key..."
|
echo "Generating /data/ssh/ssh_host_ecdsa_key..."
|
||||||
ssh-keygen -t ecdsa -b 256 -f /data/ssh/ssh_host_ecdsa_key -N "" > /dev/null
|
ssh-keygen -t ecdsa -b 256 -f /data/ssh/ssh_host_ecdsa_key -N "" > /dev/null
|
||||||
|
@ -31,12 +36,17 @@ if [ -e /data/ssh/ssh_host_ecdsa_cert ]; then
|
||||||
SSH_ECDSA_CERT=${SSH_ECDSA_CERT:-"/data/ssh/ssh_host_ecdsa_cert"}
|
SSH_ECDSA_CERT=${SSH_ECDSA_CERT:-"/data/ssh/ssh_host_ecdsa_cert"}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -e /data/ssh/ssh_host_dsa_cert ]; then
|
||||||
|
SSH_DSA_CERT=${SSH_DSA_CERT:-"/data/ssh/ssh_host_dsa_cert"}
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -d /etc/ssh ]; then
|
if [ -d /etc/ssh ]; then
|
||||||
SSH_PORT=${SSH_PORT:-"22"} \
|
SSH_PORT=${SSH_PORT:-"22"} \
|
||||||
SSH_LISTEN_PORT=${SSH_LISTEN_PORT:-"${SSH_PORT}"} \
|
SSH_LISTEN_PORT=${SSH_LISTEN_PORT:-"${SSH_PORT}"} \
|
||||||
SSH_ED25519_CERT="${SSH_ED25519_CERT:+"HostCertificate "}${SSH_ED25519_CERT}" \
|
SSH_ED25519_CERT="${SSH_ED25519_CERT:+"HostCertificate "}${SSH_ED25519_CERT}" \
|
||||||
SSH_RSA_CERT="${SSH_RSA_CERT:+"HostCertificate "}${SSH_RSA_CERT}" \
|
SSH_RSA_CERT="${SSH_RSA_CERT:+"HostCertificate "}${SSH_RSA_CERT}" \
|
||||||
SSH_ECDSA_CERT="${SSH_ECDSA_CERT:+"HostCertificate "}${SSH_ECDSA_CERT}" \
|
SSH_ECDSA_CERT="${SSH_ECDSA_CERT:+"HostCertificate "}${SSH_ECDSA_CERT}" \
|
||||||
|
SSH_DSA_CERT="${SSH_DSA_CERT:+"HostCertificate "}${SSH_DSA_CERT}" \
|
||||||
SSH_MAX_STARTUPS="${SSH_MAX_STARTUPS:+"MaxStartups "}${SSH_MAX_STARTUPS}" \
|
SSH_MAX_STARTUPS="${SSH_MAX_STARTUPS:+"MaxStartups "}${SSH_MAX_STARTUPS}" \
|
||||||
SSH_MAX_SESSIONS="${SSH_MAX_SESSIONS:+"MaxSessions "}${SSH_MAX_SESSIONS}" \
|
SSH_MAX_SESSIONS="${SSH_MAX_SESSIONS:+"MaxSessions "}${SSH_MAX_SESSIONS}" \
|
||||||
SSH_INCLUDE_FILE="${SSH_INCLUDE_FILE:+"Include "}${SSH_INCLUDE_FILE}" \
|
SSH_INCLUDE_FILE="${SSH_INCLUDE_FILE:+"Include "}${SSH_INCLUDE_FILE}" \
|
||||||
|
|
|
@ -16,6 +16,8 @@ HostKey /data/ssh/ssh_host_rsa_key
|
||||||
${SSH_RSA_CERT}
|
${SSH_RSA_CERT}
|
||||||
HostKey /data/ssh/ssh_host_ecdsa_key
|
HostKey /data/ssh/ssh_host_ecdsa_key
|
||||||
${SSH_ECDSA_CERT}
|
${SSH_ECDSA_CERT}
|
||||||
|
HostKey /data/ssh/ssh_host_dsa_key
|
||||||
|
${SSH_DSA_CERT}
|
||||||
|
|
||||||
AuthorizedKeysFile .ssh/authorized_keys
|
AuthorizedKeysFile .ssh/authorized_keys
|
||||||
AuthorizedPrincipalsFile .ssh/authorized_principals
|
AuthorizedPrincipalsFile .ssh/authorized_principals
|
||||||
|
|
|
@ -27,56 +27,23 @@ accurately recorded in [app.example.ini](https://github.com/go-gitea/gitea/blob/
|
||||||
(s/main/\<tag|release\>). Any string in the format `%(X)s` is a feature powered
|
(s/main/\<tag|release\>). Any string in the format `%(X)s` is a feature powered
|
||||||
by [ini](https://github.com/go-ini/ini/#recursive-values), for reading values recursively.
|
by [ini](https://github.com/go-ini/ini/#recursive-values), for reading values recursively.
|
||||||
|
|
||||||
In the default values below, a value in the form `$XYZ` refers to an environment variable. (However, see `environment-to-ini`.) Values in the form _`XxYyZz`_ refer to values listed as part of the default configuration. These notation forms will not work in your own `app.ini` file and are only listed here as documentation.
|
|
||||||
|
|
||||||
Values containing `#` or `;` must be quoted using `` ` `` or `"""`.
|
Values containing `#` or `;` must be quoted using `` ` `` or `"""`.
|
||||||
|
|
||||||
**Note:** A full restart is required for Gitea configuration changes to take effect.
|
**Note:** A full restart is required for Gitea configuration changes to take effect.
|
||||||
|
|
||||||
{{< toc >}}
|
{{< toc >}}
|
||||||
|
|
||||||
## Default Configuration (non-`app.ini` configuration)
|
|
||||||
|
|
||||||
These values are environment-dependent but form the basis of a lot of values. They will be
|
|
||||||
reported as part of the default configuration when running `gitea --help` or on start-up. The order they are emitted there is slightly different but we will list them here in the order they are set-up.
|
|
||||||
|
|
||||||
- _`AppPath`_: This is the absolute path of the running gitea binary.
|
|
||||||
- _`AppWorkPath`_: This refers to "working path" of the `gitea` binary. It is determined by using the first set thing in the following hierarchy:
|
|
||||||
- The `--work-path` flag passed to the binary
|
|
||||||
- The environment variable `$GITEA_WORK_DIR`
|
|
||||||
- A built-in value set at build time (see building from source)
|
|
||||||
- Otherwise it defaults to the directory of the _`AppPath`_
|
|
||||||
- If any of the above are relative paths then they are made absolute against the
|
|
||||||
the directory of the _`AppPath`_
|
|
||||||
- _`CustomPath`_: This is the base directory for custom templates and other options.
|
|
||||||
It is determined by using the first set thing in the following hierarchy:
|
|
||||||
- The `--custom-path` flag passed to the binary
|
|
||||||
- The environment variable `$GITEA_CUSTOM`
|
|
||||||
- A built-in value set at build time (see building from source)
|
|
||||||
- Otherwise it defaults to _`AppWorkPath`_`/custom`
|
|
||||||
- If any of the above are relative paths then they are made absolute against the
|
|
||||||
the directory of the _`AppWorkPath`_
|
|
||||||
- _`CustomConf`_: This is the path to the `app.ini` file.
|
|
||||||
- The `--config` flag passed to the binary
|
|
||||||
- A built-in value set at build time (see building from source)
|
|
||||||
- Otherwise it defaults to _`CustomPath`_`/conf/app.ini`
|
|
||||||
- If any of the above are relative paths then they are made absolute against the
|
|
||||||
the directory of the _`CustomPath`_
|
|
||||||
|
|
||||||
In addition there is _`StaticRootPath`_ which can be set as a built-in at build time, but will otherwise default to _`AppWorkPath`_
|
|
||||||
|
|
||||||
## Overall (`DEFAULT`)
|
## Overall (`DEFAULT`)
|
||||||
|
|
||||||
- `APP_NAME`: **Gitea: Git with a cup of tea**: Application name, used in the page title.
|
- `APP_NAME`: **Gitea: Git with a cup of tea**: Application name, used in the page title.
|
||||||
- `RUN_USER`: **_current OS username_/`$USER`/`$USERNAME` e.g. git**: The user Gitea will run as.
|
- `RUN_USER`: **git**: The user Gitea will run as. This should be a dedicated system
|
||||||
This should be a dedicated system (non-user) account. Setting this incorrectly will cause Gitea
|
(non-user) account. Setting this incorrectly will cause Gitea to not start.
|
||||||
to not start.
|
|
||||||
- `RUN_MODE`: **prod**: Application run mode, affects performance and debugging. Either "dev", "prod" or "test".
|
- `RUN_MODE`: **prod**: Application run mode, affects performance and debugging. Either "dev", "prod" or "test".
|
||||||
|
|
||||||
## Repository (`repository`)
|
## Repository (`repository`)
|
||||||
|
|
||||||
- `ROOT`: **%(APP_DATA_PATH)s/gitea-repositories**: Root path for storing all repository data.
|
- `ROOT`: **%(APP_DATA_PATH)/gitea-repositories**: Root path for storing all repository data.
|
||||||
A relative path is interpreted as **_`AppWorkPath`_/%(ROOT)s**.
|
A relative path is interpreted as **%(GITEA_WORK_DIR)/%(ROOT)**.
|
||||||
- `SCRIPT_TYPE`: **bash**: The script type this server supports. Usually this is `bash`,
|
- `SCRIPT_TYPE`: **bash**: The script type this server supports. Usually this is `bash`,
|
||||||
but some users report that only `sh` is available.
|
but some users report that only `sh` is available.
|
||||||
- `DETECTED_CHARSETS_ORDER`: **UTF-8, UTF-16BE, UTF-16LE, UTF-32BE, UTF-32LE, ISO-8859, windows-1252, ISO-8859, windows-1250, ISO-8859, ISO-8859, ISO-8859, windows-1253, ISO-8859, windows-1255, ISO-8859, windows-1251, windows-1256, KOI8-R, ISO-8859, windows-1254, Shift_JIS, GB18030, EUC-JP, EUC-KR, Big5, ISO-2022, ISO-2022, ISO-2022, IBM424_rtl, IBM424_ltr, IBM420_rtl, IBM420_ltr**: Tie-break order of detected charsets - if the detected charsets have equal confidence, charsets earlier in the list will be chosen in preference to those later. Adding `defaults` will place the unnamed charsets at that point.
|
- `DETECTED_CHARSETS_ORDER`: **UTF-8, UTF-16BE, UTF-16LE, UTF-32BE, UTF-32LE, ISO-8859, windows-1252, ISO-8859, windows-1250, ISO-8859, ISO-8859, ISO-8859, windows-1253, ISO-8859, windows-1255, ISO-8859, windows-1251, windows-1256, KOI8-R, ISO-8859, windows-1254, Shift_JIS, GB18030, EUC-JP, EUC-KR, Big5, ISO-2022, ISO-2022, ISO-2022, IBM424_rtl, IBM424_ltr, IBM420_rtl, IBM420_ltr**: Tie-break order of detected charsets - if the detected charsets have equal confidence, charsets earlier in the list will be chosen in preference to those later. Adding `defaults` will place the unnamed charsets at that point.
|
||||||
|
@ -200,7 +167,6 @@ The following configuration set `Content-Type: application/vnd.android.package-a
|
||||||
- `METHODS`: **GET,HEAD,POST,PUT,PATCH,DELETE,OPTIONS**: list of methods allowed to request
|
- `METHODS`: **GET,HEAD,POST,PUT,PATCH,DELETE,OPTIONS**: list of methods allowed to request
|
||||||
- `MAX_AGE`: **10m**: max time to cache response
|
- `MAX_AGE`: **10m**: max time to cache response
|
||||||
- `ALLOW_CREDENTIALS`: **false**: allow request with credentials
|
- `ALLOW_CREDENTIALS`: **false**: allow request with credentials
|
||||||
- `HEADERS`: **Content-Type,User-Agent**: additional headers that are permitted in requests
|
|
||||||
- `X_FRAME_OPTIONS`: **SAMEORIGIN**: Set the `X-Frame-Options` header value.
|
- `X_FRAME_OPTIONS`: **SAMEORIGIN**: Set the `X-Frame-Options` header value.
|
||||||
|
|
||||||
## UI (`ui`)
|
## UI (`ui`)
|
||||||
|
@ -274,7 +240,6 @@ The following configuration set `Content-Type: application/vnd.android.package-a
|
||||||
|
|
||||||
## Server (`server`)
|
## Server (`server`)
|
||||||
|
|
||||||
- `APP_DATA_PATH`: **_`AppWorkPath`_/data**: This is the default root path for storing data.
|
|
||||||
- `PROTOCOL`: **http**: \[http, https, fcgi, http+unix, fcgi+unix\]
|
- `PROTOCOL`: **http**: \[http, https, fcgi, http+unix, fcgi+unix\]
|
||||||
- `USE_PROXY_PROTOCOL`: **false**: Expect PROXY protocol headers on connections
|
- `USE_PROXY_PROTOCOL`: **false**: Expect PROXY protocol headers on connections
|
||||||
- `PROXY_PROTOCOL_TLS_BRIDGING`: **false**: When protocol is https, expect PROXY protocol headers after TLS negotiation.
|
- `PROXY_PROTOCOL_TLS_BRIDGING`: **false**: When protocol is https, expect PROXY protocol headers after TLS negotiation.
|
||||||
|
@ -289,17 +254,12 @@ The following configuration set `Content-Type: application/vnd.android.package-a
|
||||||
This includes CSS files, images, JS files and web fonts.
|
This includes CSS files, images, JS files and web fonts.
|
||||||
Avatar images are dynamic resources and still served by Gitea.
|
Avatar images are dynamic resources and still served by Gitea.
|
||||||
The option can be just a different path, as in `/static`, or another domain, as in `https://cdn.example.com`.
|
The option can be just a different path, as in `/static`, or another domain, as in `https://cdn.example.com`.
|
||||||
Requests are then made as `%(ROOT_URL)s/static/assets/css/index.css` or `https://cdn.example.com/assets/css/index.css` respectively.
|
Requests are then made as `%(ROOT_URL)s/static/css/index.css` and `https://cdn.example.com/css/index.css` respective.
|
||||||
The static files are located in the `public/` directory of the Gitea source repository.
|
The static files are located in the `public/` directory of the Gitea source repository.
|
||||||
You can proxy the STATIC_URL_PREFIX requests to Gitea server to serve the static
|
|
||||||
assets, or copy the manually built Gitea assets from `$GITEA_BUILD/public` to
|
|
||||||
the assets location, eg: `/var/www/assets`, make sure `$STATIC_URL_PREFIX/assets/css/index.css`
|
|
||||||
points to `/var/www/assets/css/index.css`.
|
|
||||||
|
|
||||||
- `HTTP_ADDR`: **0.0.0.0**: HTTP listen address.
|
- `HTTP_ADDR`: **0.0.0.0**: HTTP listen address.
|
||||||
- If `PROTOCOL` is set to `fcgi`, Gitea will listen for FastCGI requests on TCP socket
|
- If `PROTOCOL` is set to `fcgi`, Gitea will listen for FastCGI requests on TCP socket
|
||||||
defined by `HTTP_ADDR` and `HTTP_PORT` configuration settings.
|
defined by `HTTP_ADDR` and `HTTP_PORT` configuration settings.
|
||||||
- If `PROTOCOL` is set to `http+unix` or `fcgi+unix`, this should be the name of the Unix socket file to use. Relative paths will be made absolute against the _`AppWorkPath`_.
|
- If `PROTOCOL` is set to `http+unix` or `fcgi+unix`, this should be the name of the Unix socket file to use. Relative paths will be made absolute against the AppWorkPath.
|
||||||
- `HTTP_PORT`: **3000**: HTTP listen port.
|
- `HTTP_PORT`: **3000**: HTTP listen port.
|
||||||
- If `PROTOCOL` is set to `fcgi`, Gitea will listen for FastCGI requests on TCP socket
|
- If `PROTOCOL` is set to `fcgi`, Gitea will listen for FastCGI requests on TCP socket
|
||||||
defined by `HTTP_ADDR` and `HTTP_PORT` configuration settings.
|
defined by `HTTP_ADDR` and `HTTP_PORT` configuration settings.
|
||||||
|
@ -309,7 +269,7 @@ The following configuration set `Content-Type: application/vnd.android.package-a
|
||||||
most cases you do not need to change the default value. Alter it only if
|
most cases you do not need to change the default value. Alter it only if
|
||||||
your SSH server node is not the same as HTTP node. Do not set this variable
|
your SSH server node is not the same as HTTP node. Do not set this variable
|
||||||
if `PROTOCOL` is set to `http+unix`.
|
if `PROTOCOL` is set to `http+unix`.
|
||||||
- `LOCAL_USE_PROXY_PROTOCOL`: **%(USE_PROXY_PROTOCOL)s**: When making local connections pass the PROXY protocol header.
|
- `LOCAL_USE_PROXY_PROTOCOL`: **%(USE_PROXY_PROTOCOL)**: When making local connections pass the PROXY protocol header.
|
||||||
This should be set to false if the local connection will go through the proxy.
|
This should be set to false if the local connection will go through the proxy.
|
||||||
- `PER_WRITE_TIMEOUT`: **30s**: Timeout for any write to the connection. (Set to -1 to
|
- `PER_WRITE_TIMEOUT`: **30s**: Timeout for any write to the connection. (Set to -1 to
|
||||||
disable all timeouts.)
|
disable all timeouts.)
|
||||||
|
@ -319,7 +279,7 @@ The following configuration set `Content-Type: application/vnd.android.package-a
|
||||||
- `START_SSH_SERVER`: **false**: When enabled, use the built-in SSH server.
|
- `START_SSH_SERVER`: **false**: When enabled, use the built-in SSH server.
|
||||||
- `SSH_SERVER_USE_PROXY_PROTOCOL`: **false**: Expect PROXY protocol header on connections to the built-in SSH Server.
|
- `SSH_SERVER_USE_PROXY_PROTOCOL`: **false**: Expect PROXY protocol header on connections to the built-in SSH Server.
|
||||||
- `BUILTIN_SSH_SERVER_USER`: **%(RUN_USER)s**: Username to use for the built-in SSH Server.
|
- `BUILTIN_SSH_SERVER_USER`: **%(RUN_USER)s**: Username to use for the built-in SSH Server.
|
||||||
- `SSH_USER`: **%(BUILTIN_SSH_SERVER_USER)s**: SSH username displayed in clone URLs. This is only for people who configure the SSH server themselves; in most cases, you want to leave this blank and modify the `BUILTIN_SSH_SERVER_USER`.
|
- `SSH_USER`: **%(BUILTIN_SSH_SERVER_USER)**: SSH username displayed in clone URLs. This is only for people who configure the SSH server themselves; in most cases, you want to leave this blank and modify the `BUILTIN_SSH_SERVER_USER`.
|
||||||
- `SSH_DOMAIN`: **%(DOMAIN)s**: Domain name of this server, used for displayed clone URL.
|
- `SSH_DOMAIN`: **%(DOMAIN)s**: Domain name of this server, used for displayed clone URL.
|
||||||
- `SSH_PORT`: **22**: SSH port displayed in clone URL.
|
- `SSH_PORT`: **22**: SSH port displayed in clone URL.
|
||||||
- `SSH_LISTEN_HOST`: **0.0.0.0**: Listen address for the built-in SSH server.
|
- `SSH_LISTEN_HOST`: **0.0.0.0**: Listen address for the built-in SSH server.
|
||||||
|
@ -348,22 +308,22 @@ The following configuration set `Content-Type: application/vnd.android.package-a
|
||||||
- `OFFLINE_MODE`: **false**: Disables use of CDN for static files and Gravatar for profile pictures.
|
- `OFFLINE_MODE`: **false**: Disables use of CDN for static files and Gravatar for profile pictures.
|
||||||
- `CERT_FILE`: **https/cert.pem**: Cert file path used for HTTPS. When chaining, the server certificate must come first, then intermediate CA certificates (if any). This is ignored if `ENABLE_ACME=true`. Paths are relative to `CUSTOM_PATH`.
|
- `CERT_FILE`: **https/cert.pem**: Cert file path used for HTTPS. When chaining, the server certificate must come first, then intermediate CA certificates (if any). This is ignored if `ENABLE_ACME=true`. Paths are relative to `CUSTOM_PATH`.
|
||||||
- `KEY_FILE`: **https/key.pem**: Key file path used for HTTPS. This is ignored if `ENABLE_ACME=true`. Paths are relative to `CUSTOM_PATH`.
|
- `KEY_FILE`: **https/key.pem**: Key file path used for HTTPS. This is ignored if `ENABLE_ACME=true`. Paths are relative to `CUSTOM_PATH`.
|
||||||
- `STATIC_ROOT_PATH`: **_`StaticRootPath`_**: Upper level of template and static files path.
|
- `STATIC_ROOT_PATH`: **./**: Upper level of template and static files path.
|
||||||
- `APP_DATA_PATH`: **data** (**/data/gitea** on docker): Default path for application data. Relative paths will be made absolute against _`AppWorkPath`_.
|
- `APP_DATA_PATH`: **data** (**/data/gitea** on docker): Default path for application data.
|
||||||
- `STATIC_CACHE_TIME`: **6h**: Web browser cache time for static resources on `custom/`, `public/` and all uploaded avatars. Note that this cache is disabled when `RUN_MODE` is "dev".
|
- `STATIC_CACHE_TIME`: **6h**: Web browser cache time for static resources on `custom/`, `public/` and all uploaded avatars. Note that this cache is disabled when `RUN_MODE` is "dev".
|
||||||
- `ENABLE_GZIP`: **false**: Enable gzip compression for runtime-generated content, static resources excluded.
|
- `ENABLE_GZIP`: **false**: Enable gzip compression for runtime-generated content, static resources excluded.
|
||||||
- `ENABLE_PPROF`: **false**: Application profiling (memory and cpu). For "web" command it listens on `localhost:6060`. For "serv" command it dumps to disk at `PPROF_DATA_PATH` as `(cpuprofile|memprofile)_<username>_<temporary id>`
|
- `ENABLE_PPROF`: **false**: Application profiling (memory and cpu). For "web" command it listens on `localhost:6060`. For "serv" command it dumps to disk at `PPROF_DATA_PATH` as `(cpuprofile|memprofile)_<username>_<temporary id>`
|
||||||
- `PPROF_DATA_PATH`: **_`AppWorkPath`_/data/tmp/pprof**: `PPROF_DATA_PATH`, use an absolute path when you start Gitea as service
|
- `PPROF_DATA_PATH`: **data/tmp/pprof**: `PPROF_DATA_PATH`, use an absolute path when you start Gitea as service
|
||||||
- `LANDING_PAGE`: **home**: Landing page for unauthenticated users \[home, explore, organizations, login, **custom**\]. Where custom would instead be any URL such as "/org/repo" or even `https://anotherwebsite.com`
|
- `LANDING_PAGE`: **home**: Landing page for unauthenticated users \[home, explore, organizations, login, **custom**\]. Where custom would instead be any URL such as "/org/repo" or even `https://anotherwebsite.com`
|
||||||
- `LFS_START_SERVER`: **false**: Enables Git LFS support.
|
- `LFS_START_SERVER`: **false**: Enables Git LFS support.
|
||||||
- `LFS_CONTENT_PATH`: **%(APP_DATA_PATH)s/lfs**: Default LFS content path. (if it is on local storage.) **DEPRECATED** use settings in `[lfs]`.
|
- `LFS_CONTENT_PATH`: **%(APP_DATA_PATH)/lfs**: Default LFS content path. (if it is on local storage.) **DEPRECATED** use settings in `[lfs]`.
|
||||||
- `LFS_JWT_SECRET`: **\<empty\>**: LFS authentication secret, change this a unique string.
|
- `LFS_JWT_SECRET`: **\<empty\>**: LFS authentication secret, change this a unique string.
|
||||||
- `LFS_HTTP_AUTH_EXPIRY`: **20m**: LFS authentication validity period in time.Duration, pushes taking longer than this may fail.
|
- `LFS_HTTP_AUTH_EXPIRY`: **20m**: LFS authentication validity period in time.Duration, pushes taking longer than this may fail.
|
||||||
- `LFS_MAX_FILE_SIZE`: **0**: Maximum allowed LFS file size in bytes (Set to 0 for no limit).
|
- `LFS_MAX_FILE_SIZE`: **0**: Maximum allowed LFS file size in bytes (Set to 0 for no limit).
|
||||||
- `LFS_LOCKS_PAGING_NUM`: **50**: Maximum number of LFS Locks returned per page.
|
- `LFS_LOCKS_PAGING_NUM`: **50**: Maximum number of LFS Locks returned per page.
|
||||||
|
|
||||||
- `REDIRECT_OTHER_PORT`: **false**: If true and `PROTOCOL` is https, allows redirecting http requests on `PORT_TO_REDIRECT` to the https port Gitea listens on.
|
- `REDIRECT_OTHER_PORT`: **false**: If true and `PROTOCOL` is https, allows redirecting http requests on `PORT_TO_REDIRECT` to the https port Gitea listens on.
|
||||||
- `REDIRECTOR_USE_PROXY_PROTOCOL`: **%(USE_PROXY_PROTOCOL)s**: expect PROXY protocol header on connections to https redirector.
|
- `REDIRECTOR_USE_PROXY_PROTOCOL`: **%(USE_PROXY_PROTOCOL)**: expect PROXY protocol header on connections to https redirector.
|
||||||
- `PORT_TO_REDIRECT`: **80**: Port for the http redirection service to listen on. Used when `REDIRECT_OTHER_PORT` is true.
|
- `PORT_TO_REDIRECT`: **80**: Port for the http redirection service to listen on. Used when `REDIRECT_OTHER_PORT` is true.
|
||||||
- `SSL_MIN_VERSION`: **TLSv1.2**: Set the minimum version of ssl support.
|
- `SSL_MIN_VERSION`: **TLSv1.2**: Set the minimum version of ssl support.
|
||||||
- `SSL_MAX_VERSION`: **\<empty\>**: Set the maximum version of ssl support.
|
- `SSL_MAX_VERSION`: **\<empty\>**: Set the maximum version of ssl support.
|
||||||
|
@ -453,10 +413,10 @@ relation to port exhaustion.
|
||||||
- `ISSUE_INDEXER_TYPE`: **bleve**: Issue indexer type, currently supported: `bleve`, `db` or `elasticsearch`.
|
- `ISSUE_INDEXER_TYPE`: **bleve**: Issue indexer type, currently supported: `bleve`, `db` or `elasticsearch`.
|
||||||
- `ISSUE_INDEXER_CONN_STR`: ****: Issue indexer connection string, available when ISSUE_INDEXER_TYPE is elasticsearch. i.e. http://elastic:changeme@localhost:9200
|
- `ISSUE_INDEXER_CONN_STR`: ****: Issue indexer connection string, available when ISSUE_INDEXER_TYPE is elasticsearch. i.e. http://elastic:changeme@localhost:9200
|
||||||
- `ISSUE_INDEXER_NAME`: **gitea_issues**: Issue indexer name, available when ISSUE_INDEXER_TYPE is elasticsearch
|
- `ISSUE_INDEXER_NAME`: **gitea_issues**: Issue indexer name, available when ISSUE_INDEXER_TYPE is elasticsearch
|
||||||
- `ISSUE_INDEXER_PATH`: **indexers/issues.bleve**: Index file used for issue search; available when ISSUE_INDEXER_TYPE is bleve and elasticsearch. Relative paths will be made absolute against _`AppWorkPath`_.
|
- `ISSUE_INDEXER_PATH`: **indexers/issues.bleve**: Index file used for issue search; available when ISSUE_INDEXER_TYPE is bleve and elasticsearch.
|
||||||
- The next 4 configuration values are deprecated and should be set in `queue.issue_indexer` however are kept for backwards compatibility:
|
- The next 4 configuration values are deprecated and should be set in `queue.issue_indexer` however are kept for backwards compatibility:
|
||||||
- `ISSUE_INDEXER_QUEUE_TYPE`: **levelqueue**: Issue indexer queue, currently supports:`channel`, `levelqueue`, `redis`. **DEPRECATED** use settings in `[queue.issue_indexer]`.
|
- `ISSUE_INDEXER_QUEUE_TYPE`: **levelqueue**: Issue indexer queue, currently supports:`channel`, `levelqueue`, `redis`. **DEPRECATED** use settings in `[queue.issue_indexer]`.
|
||||||
- `ISSUE_INDEXER_QUEUE_DIR`: **queues/common**: When `ISSUE_INDEXER_QUEUE_TYPE` is `levelqueue`, this will be the path where the queue will be saved. **DEPRECATED** use settings in `[queue.issue_indexer]`. Relative paths will be made absolute against `%(APP_DATA_PATH)s`.
|
- `ISSUE_INDEXER_QUEUE_DIR`: **queues/common**: When `ISSUE_INDEXER_QUEUE_TYPE` is `levelqueue`, this will be the path where the queue will be saved. **DEPRECATED** use settings in `[queue.issue_indexer]`.
|
||||||
- `ISSUE_INDEXER_QUEUE_CONN_STR`: **addrs=127.0.0.1:6379 db=0**: When `ISSUE_INDEXER_QUEUE_TYPE` is `redis`, this will store the redis connection string. When `ISSUE_INDEXER_QUEUE_TYPE` is `levelqueue`, this is a directory or additional options of the form `leveldb://path/to/db?option=value&....`, and overrides `ISSUE_INDEXER_QUEUE_DIR`. **DEPRECATED** use settings in `[queue.issue_indexer]`.
|
- `ISSUE_INDEXER_QUEUE_CONN_STR`: **addrs=127.0.0.1:6379 db=0**: When `ISSUE_INDEXER_QUEUE_TYPE` is `redis`, this will store the redis connection string. When `ISSUE_INDEXER_QUEUE_TYPE` is `levelqueue`, this is a directory or additional options of the form `leveldb://path/to/db?option=value&....`, and overrides `ISSUE_INDEXER_QUEUE_DIR`. **DEPRECATED** use settings in `[queue.issue_indexer]`.
|
||||||
- `ISSUE_INDEXER_QUEUE_BATCH_NUMBER`: **20**: Batch queue number. **DEPRECATED** use settings in `[queue.issue_indexer]`.
|
- `ISSUE_INDEXER_QUEUE_BATCH_NUMBER`: **20**: Batch queue number. **DEPRECATED** use settings in `[queue.issue_indexer]`.
|
||||||
|
|
||||||
|
@ -478,7 +438,7 @@ relation to port exhaustion.
|
||||||
Configuration at `[queue]` will set defaults for queues with overrides for individual queues at `[queue.*]`. (However see below.)
|
Configuration at `[queue]` will set defaults for queues with overrides for individual queues at `[queue.*]`. (However see below.)
|
||||||
|
|
||||||
- `TYPE`: **persistable-channel**: General queue type, currently support: `persistable-channel` (uses a LevelDB internally), `channel`, `level`, `redis`, `dummy`
|
- `TYPE`: **persistable-channel**: General queue type, currently support: `persistable-channel` (uses a LevelDB internally), `channel`, `level`, `redis`, `dummy`
|
||||||
- `DATADIR`: **queues/**: Base DataDir for storing persistent and level queues. `DATADIR` for individual queues can be set in `queue.name` sections but will default to `DATADIR/`**`common`**. (Previously each queue would default to `DATADIR/`**`name`**.) Relative paths will be made absolute against `%(APP_DATA_PATH)s`.
|
- `DATADIR`: **queues/**: Base DataDir for storing persistent and level queues. `DATADIR` for individual queues can be set in `queue.name` sections but will default to `DATADIR/`**`common`**. (Previously each queue would default to `DATADIR/`**`name`**.)
|
||||||
- `LENGTH`: **20**: Maximal queue size before channel queues block
|
- `LENGTH`: **20**: Maximal queue size before channel queues block
|
||||||
- `BATCH_LENGTH`: **20**: Batch data before passing to the handler
|
- `BATCH_LENGTH`: **20**: Batch data before passing to the handler
|
||||||
- `CONN_STR`: **redis://127.0.0.1:6379/0**: Connection string for the redis queue type. Options can be set using query params. Similarly LevelDB options can also be set using: **leveldb://relative/path?option=value** or **leveldb:///absolute/path?option=value**, and will override `DATADIR`
|
- `CONN_STR`: **redis://127.0.0.1:6379/0**: Connection string for the redis queue type. Options can be set using query params. Similarly LevelDB options can also be set using: **leveldb://relative/path?option=value** or **leveldb:///absolute/path?option=value**, and will override `DATADIR`
|
||||||
|
@ -634,7 +594,6 @@ Certain queues have defaults that override the defaults set in `[queue]` (this o
|
||||||
- `ENABLE_REVERSE_PROXY_FULL_NAME`: **false**: Enable this to allow to auto-registration with a
|
- `ENABLE_REVERSE_PROXY_FULL_NAME`: **false**: Enable this to allow to auto-registration with a
|
||||||
provided full name for the user.
|
provided full name for the user.
|
||||||
- `ENABLE_CAPTCHA`: **false**: Enable this to use captcha validation for registration.
|
- `ENABLE_CAPTCHA`: **false**: Enable this to use captcha validation for registration.
|
||||||
- `REQUIRE_CAPTCHA_FOR_LOGIN`: **false**: Enable this to require captcha validation for login. You also must enable `ENABLE_CAPTCHA`.
|
|
||||||
- `REQUIRE_EXTERNAL_REGISTRATION_CAPTCHA`: **false**: Enable this to force captcha validation
|
- `REQUIRE_EXTERNAL_REGISTRATION_CAPTCHA`: **false**: Enable this to force captcha validation
|
||||||
even for External Accounts (i.e. GitHub, OpenID Connect, etc). You also must enable `ENABLE_CAPTCHA`.
|
even for External Accounts (i.e. GitHub, OpenID Connect, etc). You also must enable `ENABLE_CAPTCHA`.
|
||||||
- `CAPTCHA_TYPE`: **image**: \[image, recaptcha, hcaptcha, mcaptcha\]
|
- `CAPTCHA_TYPE`: **image**: \[image, recaptcha, hcaptcha, mcaptcha\]
|
||||||
|
@ -713,7 +672,7 @@ and
|
||||||
[Gitea 1.17 configuration document](https://github.com/go-gitea/gitea/blob/release/v1.17/docs/content/doc/advanced/config-cheat-sheet.en-us.md)
|
[Gitea 1.17 configuration document](https://github.com/go-gitea/gitea/blob/release/v1.17/docs/content/doc/advanced/config-cheat-sheet.en-us.md)
|
||||||
|
|
||||||
- `ENABLED`: **false**: Enable to use a mail service.
|
- `ENABLED`: **false**: Enable to use a mail service.
|
||||||
- `PROTOCOL`: **\<empty\>**: Mail server protocol. One of "smtp", "smtps", "smtp+starttls", "smtp+unix", "sendmail", "dummy". _Before 1.18, this was inferred from a combination of `MAILER_TYPE` and `IS_TLS_ENABLED`._
|
- `PROTOCOL`: **\<empty\>**: Mail server protocol. One of "smtp", "smtps", "smtp+startls", "smtp+unix", "sendmail", "dummy". _Before 1.18, this was inferred from a combination of `MAILER_TYPE` and `IS_TLS_ENABLED`._
|
||||||
- SMTP family, if your provider does not explicitly say which protocol it uses but does provide a port, you can set SMTP_PORT instead and this will be inferred.
|
- SMTP family, if your provider does not explicitly say which protocol it uses but does provide a port, you can set SMTP_PORT instead and this will be inferred.
|
||||||
- **sendmail** Use the operating system's `sendmail` command instead of SMTP. This is common on Linux systems.
|
- **sendmail** Use the operating system's `sendmail` command instead of SMTP. This is common on Linux systems.
|
||||||
- **dummy** Send email messages to the log as a testing phase.
|
- **dummy** Send email messages to the log as a testing phase.
|
||||||
|
@ -763,7 +722,7 @@ and
|
||||||
## Session (`session`)
|
## Session (`session`)
|
||||||
|
|
||||||
- `PROVIDER`: **memory**: Session engine provider \[memory, file, redis, db, mysql, couchbase, memcache, postgres\]. Setting `db` will reuse the configuration in `[database]`
|
- `PROVIDER`: **memory**: Session engine provider \[memory, file, redis, db, mysql, couchbase, memcache, postgres\]. Setting `db` will reuse the configuration in `[database]`
|
||||||
- `PROVIDER_CONFIG`: **data/sessions**: For file, the root path; for db, empty (database config will be used); for others, the connection string. Relative paths will be made absolute against _`AppWorkPath`_.
|
- `PROVIDER_CONFIG`: **data/sessions**: For file, the root path; for db, empty (database config will be used); for others, the connection string.
|
||||||
- `COOKIE_SECURE`: **false**: Enable this to force using HTTPS for all session access.
|
- `COOKIE_SECURE`: **false**: Enable this to force using HTTPS for all session access.
|
||||||
- `COOKIE_NAME`: **i\_like\_gitea**: The name of the cookie used for the session ID.
|
- `COOKIE_NAME`: **i\_like\_gitea**: The name of the cookie used for the session ID.
|
||||||
- `GC_INTERVAL_TIME`: **86400**: GC interval in seconds.
|
- `GC_INTERVAL_TIME`: **86400**: GC interval in seconds.
|
||||||
|
@ -851,9 +810,9 @@ Default templates for project boards:
|
||||||
- `STACKTRACE_LEVEL`: **log.STACKTRACE_LEVEL**: Sets the log level at which to log stack traces.
|
- `STACKTRACE_LEVEL`: **log.STACKTRACE_LEVEL**: Sets the log level at which to log stack traces.
|
||||||
- `MODE`: **name**: Sets the mode of this sublogger - Defaults to the provided subsection name. This allows you to have two different file loggers at different levels.
|
- `MODE`: **name**: Sets the mode of this sublogger - Defaults to the provided subsection name. This allows you to have two different file loggers at different levels.
|
||||||
- `EXPRESSION`: **""**: A regular expression to match either the function name, file or message. Defaults to empty. Only log messages that match the expression will be saved in the logger.
|
- `EXPRESSION`: **""**: A regular expression to match either the function name, file or message. Defaults to empty. Only log messages that match the expression will be saved in the logger.
|
||||||
- `FLAGS`: **stdflags**: A comma separated string representing the log flags. Defaults to `stdflags` which represents the prefix: `2009/01/23 01:23:23 ...a/b/c/d.go:23:runtime.Caller() [I]: message`. `none` means don't prefix log lines. See `modules/log/flags.go` for more information.
|
- `FLAGS`: **stdflags**: A comma separated string representing the log flags. Defaults to `stdflags` which represents the prefix: `2009/01/23 01:23:23 ...a/b/c/d.go:23:runtime.Caller() [I]: message`. `none` means don't prefix log lines. See `modules/log/base.go` for more information.
|
||||||
- `PREFIX`: **""**: An additional prefix for every log line in this logger. Defaults to empty.
|
- `PREFIX`: **""**: An additional prefix for every log line in this logger. Defaults to empty.
|
||||||
- `COLORIZE`: **false**: Whether to colorize the log lines
|
- `COLORIZE`: **false**: Colorize the log lines by default
|
||||||
|
|
||||||
### Console log mode (`log.console`, `log.console.*`, or `MODE=console`)
|
### Console log mode (`log.console`, `log.console.*`, or `MODE=console`)
|
||||||
|
|
||||||
|
@ -1021,7 +980,7 @@ Default templates for project boards:
|
||||||
## Git (`git`)
|
## Git (`git`)
|
||||||
|
|
||||||
- `PATH`: **""**: The path of Git executable. If empty, Gitea searches through the PATH environment.
|
- `PATH`: **""**: The path of Git executable. If empty, Gitea searches through the PATH environment.
|
||||||
- `HOME_PATH`: **%(APP_DATA_PATH)s/home**: The HOME directory for Git.
|
- `HOME_PATH`: **%(APP_DATA_PATH)/home**: The HOME directory for Git.
|
||||||
This directory will be used to contain the `.gitconfig` and possible `.gnupg` directories that Gitea's git calls will use. If you can confirm Gitea is the only application running in this environment, you can set it to the normal home directory for Gitea user.
|
This directory will be used to contain the `.gitconfig` and possible `.gnupg` directories that Gitea's git calls will use. If you can confirm Gitea is the only application running in this environment, you can set it to the normal home directory for Gitea user.
|
||||||
- `DISABLE_DIFF_HIGHLIGHT`: **false**: Disables highlight of added and removed changes.
|
- `DISABLE_DIFF_HIGHLIGHT`: **false**: Disables highlight of added and removed changes.
|
||||||
- `MAX_GIT_DIFF_LINES`: **1000**: Max number of lines allowed of a single file in diff view.
|
- `MAX_GIT_DIFF_LINES`: **1000**: Max number of lines allowed of a single file in diff view.
|
||||||
|
@ -1179,20 +1138,6 @@ Task queue configuration has been moved to `queue.task`. However, the below conf
|
||||||
|
|
||||||
- `ENABLED`: **true**: Enable/Disable package registry capabilities
|
- `ENABLED`: **true**: Enable/Disable package registry capabilities
|
||||||
- `CHUNKED_UPLOAD_PATH`: **tmp/package-upload**: Path for chunked uploads. Defaults to `APP_DATA_PATH` + `tmp/package-upload`
|
- `CHUNKED_UPLOAD_PATH`: **tmp/package-upload**: Path for chunked uploads. Defaults to `APP_DATA_PATH` + `tmp/package-upload`
|
||||||
- `LIMIT_TOTAL_OWNER_COUNT`: **-1**: Maximum count of package versions a single owner can have (`-1` means no limits)
|
|
||||||
- `LIMIT_TOTAL_OWNER_SIZE`: **-1**: Maximum size of packages a single owner can use (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_COMPOSER`: **-1**: Maximum size of a Composer upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_CONAN`: **-1**: Maximum size of a Conan upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_CONTAINER`: **-1**: Maximum size of a Container upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_GENERIC`: **-1**: Maximum size of a Generic upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_HELM`: **-1**: Maximum size of a Helm upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_MAVEN`: **-1**: Maximum size of a Maven upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_NPM`: **-1**: Maximum size of a npm upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_NUGET`: **-1**: Maximum size of a NuGet upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_PUB`: **-1**: Maximum size of a Pub upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_PYPI`: **-1**: Maximum size of a PyPI upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_RUBYGEMS`: **-1**: Maximum size of a RubyGems upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
- `LIMIT_SIZE_VAGRANT`: **-1**: Maximum size of a Vagrant upload (`-1` means no limits, format `1000`, `1 MB`, `1 GiB`)
|
|
||||||
|
|
||||||
## Mirror (`mirror`)
|
## Mirror (`mirror`)
|
||||||
|
|
||||||
|
@ -1288,5 +1233,3 @@ PROXY_HOSTS = *.github.com
|
||||||
- `SHOW_FOOTER_BRANDING`: **false**: Show Gitea branding in the footer.
|
- `SHOW_FOOTER_BRANDING`: **false**: Show Gitea branding in the footer.
|
||||||
- `SHOW_FOOTER_VERSION`: **true**: Show Gitea and Go version information in the footer.
|
- `SHOW_FOOTER_VERSION`: **true**: Show Gitea and Go version information in the footer.
|
||||||
- `SHOW_FOOTER_TEMPLATE_LOAD_TIME`: **true**: Show time of template execution in the footer.
|
- `SHOW_FOOTER_TEMPLATE_LOAD_TIME`: **true**: Show time of template execution in the footer.
|
||||||
- `ENABLE_SITEMAP`: **true**: Generate sitemap.
|
|
||||||
- `ENABLE_FEED`: **true**: Enable/Disable RSS/Atom feed.
|
|
||||||
|
|
|
@ -145,8 +145,7 @@ menu:
|
||||||
- `ENABLE_NOTIFY_MAIL`: 是否发送工单创建等提醒邮件,需要 `Mailer` 被激活。
|
- `ENABLE_NOTIFY_MAIL`: 是否发送工单创建等提醒邮件,需要 `Mailer` 被激活。
|
||||||
- `ENABLE_REVERSE_PROXY_AUTHENTICATION`: 允许反向代理认证,更多细节见:https://github.com/gogits/gogs/issues/165
|
- `ENABLE_REVERSE_PROXY_AUTHENTICATION`: 允许反向代理认证,更多细节见:https://github.com/gogits/gogs/issues/165
|
||||||
- `ENABLE_REVERSE_PROXY_AUTO_REGISTRATION`: 允许通过反向认证做自动注册。
|
- `ENABLE_REVERSE_PROXY_AUTO_REGISTRATION`: 允许通过反向认证做自动注册。
|
||||||
- `ENABLE_CAPTCHA`: **false**: 注册时使用图片验证码。
|
- `ENABLE_CAPTCHA`: 注册时使用图片验证码。
|
||||||
- `REQUIRE_CAPTCHA_FOR_LOGIN`: **false**: 登录时需要图片验证码。需要同时开启 `ENABLE_CAPTCHA`。
|
|
||||||
|
|
||||||
### Service - Expore (`service.explore`)
|
### Service - Expore (`service.explore`)
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
---
|
||||||
|
date: "2016-12-01T16:00:00+02:00"
|
||||||
|
title: "加入 Gitea 开源"
|
||||||
|
slug: "hacking-on-gitea"
|
||||||
|
weight: 10
|
||||||
|
toc: false
|
||||||
|
draft: false
|
||||||
|
menu:
|
||||||
|
sidebar:
|
||||||
|
parent: "advanced"
|
||||||
|
name: "加入 Gitea 开源"
|
||||||
|
weight: 10
|
||||||
|
identifier: "hacking-on-gitea"
|
||||||
|
---
|
||||||
|
|
||||||
|
# Hacking on Gitea
|
||||||
|
|
||||||
|
首先你需要一些运行环境,这和 [从源代码安装]({{< relref "from-source.zh-cn.md" >}}) 相同,如果你还没有设置好,可以先阅读那个章节。
|
||||||
|
|
||||||
|
如果你想为 Gitea 贡献代码,你需要 Fork 这个项目并且以 `master` 为开发分支。Gitea 使用 Govendor
|
||||||
|
来管理依赖,因此所有依赖项都被工具自动 copy 在 vendor 子目录下。用下面的命令来下载源码:
|
||||||
|
|
||||||
|
```
|
||||||
|
go get -d code.gitea.io/gitea
|
||||||
|
```
|
||||||
|
|
||||||
|
然后你可以在 Github 上 fork [Gitea 项目](https://github.com/go-gitea/gitea),之后可以通过下面的命令进入源码目录:
|
||||||
|
|
||||||
|
```
|
||||||
|
cd $GOPATH/src/code.gitea.io/gitea
|
||||||
|
```
|
||||||
|
|
||||||
|
要创建 pull requests 你还需要在源码中新增一个 remote 指向你 Fork 的地址,直接推送到 origin 的话会告诉你没有写权限:
|
||||||
|
|
||||||
|
```
|
||||||
|
git remote rename origin upstream
|
||||||
|
git remote add origin git@github.com:<USERNAME>/gitea.git
|
||||||
|
git fetch --all --prune
|
||||||
|
```
|
||||||
|
|
||||||
|
然后你就可以开始开发了。你可以看一下 `Makefile` 的内容。`make test` 可以运行测试程序, `make build` 将生成一个 `gitea` 可运行文件在根目录。如果你的提交比较复杂,尽量多写一些单元测试代码。
|
||||||
|
|
||||||
|
好了,到这里你已经设置好了所有的开发 Gitea 所需的环境。欢迎成为 Gitea 的 Contributor。
|
|
@ -15,14 +15,6 @@ menu:
|
||||||
|
|
||||||
# Logging Configuration
|
# Logging Configuration
|
||||||
|
|
||||||
The logging configuration of Gitea mainly consists of 3 types of components:
|
|
||||||
|
|
||||||
- The `[log]` section for general configuration
|
|
||||||
- `[log.<sublogger>]` sections for the configuration of different log outputs
|
|
||||||
- `[log.<sublogger>.<group>]` sections for output specific configuration of a log group
|
|
||||||
|
|
||||||
As mentioned below, there is a fully functional log output by default, so it is not necessary to define one.
|
|
||||||
|
|
||||||
**Table of Contents**
|
**Table of Contents**
|
||||||
|
|
||||||
{{< toc >}}
|
{{< toc >}}
|
||||||
|
@ -31,166 +23,6 @@ As mentioned below, there is a fully functional log output by default, so it is
|
||||||
|
|
||||||
To collect logs for help and issue report, see [Support Options]({{< relref "doc/help/seek-help.en-us.md" >}}).
|
To collect logs for help and issue report, see [Support Options]({{< relref "doc/help/seek-help.en-us.md" >}}).
|
||||||
|
|
||||||
## The `[log]` section
|
|
||||||
|
|
||||||
Configuration of logging facilities in Gitea happen in the `[log]` section and it's subsections.
|
|
||||||
|
|
||||||
In the top level `[log]` section the following configurations can be placed:
|
|
||||||
|
|
||||||
- `ROOT_PATH`: (Default: **%(GITEA_WORK_DIR)/log**): Base path for log files
|
|
||||||
- `MODE`: (Default: **console**) List of log outputs to use for the Default logger.
|
|
||||||
- `ROUTER`: (Default: **console**): List of log outputs to use for the Router logger.
|
|
||||||
- `ACCESS`: List of log outputs to use for the Access logger.
|
|
||||||
- `XORM`: (Default: **,**) List of log outputs to use for the XORM logger.
|
|
||||||
- `ENABLE_ACCESS_LOG`: (Default: **false**): whether the Access logger is allowed to emit logs
|
|
||||||
- `ENABLE_XORM_LOG`: (Default: **true**): whether the XORM logger is allowed to emit logs
|
|
||||||
|
|
||||||
For details on the loggers check the "Log Groups" section.
|
|
||||||
Important: log outputs won't be used if you don't enable them for the desired loggers in the corresponding list value.
|
|
||||||
|
|
||||||
Lists are specified as comma separated values. This format also works in subsection.
|
|
||||||
|
|
||||||
This section may be used for defining default values for subsections.
|
|
||||||
Examples:
|
|
||||||
|
|
||||||
- `LEVEL`: (Default: **Info**) Least severe log events to persist. Case insensitive. The full list of levels as of v1.17.3 can be read [here](https://github.com/go-gitea/gitea/blob/v1.17.3/custom/conf/app.example.ini#L507).
|
|
||||||
- `STACKTRACE_LEVEL`: (Default: **None**) For this and more severe events the stacktrace will be printed upon getting logged.
|
|
||||||
|
|
||||||
Some values are not inherited by subsections. For details see the "Non-inherited default values" section.
|
|
||||||
|
|
||||||
## Log outputs
|
|
||||||
|
|
||||||
Log outputs are the targets to which log messages will be sent.
|
|
||||||
The content and the format of the log messages to be saved can be configured in these.
|
|
||||||
|
|
||||||
Log outputs are also called subloggers.
|
|
||||||
|
|
||||||
Gitea provides 4 possible log outputs:
|
|
||||||
|
|
||||||
- `console` - Log to `os.Stdout` or `os.Stderr`
|
|
||||||
- `file` - Log to a file
|
|
||||||
- `conn` - Log to a socket (network or unix)
|
|
||||||
- `smtp` - Log via email
|
|
||||||
|
|
||||||
By default, Gitea has a `console` output configured, which is used by the loggers as seen in the section "The log section" above.
|
|
||||||
|
|
||||||
### Common configuration
|
|
||||||
|
|
||||||
Certain configuration is common to all modes of log output:
|
|
||||||
|
|
||||||
- `MODE` is the mode of the log output. It will default to the sublogger
|
|
||||||
name, thus `[log.console.router]` will default to `MODE = console`.
|
|
||||||
For mode specific confgurations read further.
|
|
||||||
- `LEVEL` is the lowest level that this output will log. This value
|
|
||||||
is inherited from `[log]` and in the case of the non-default loggers
|
|
||||||
from `[log.sublogger]`.
|
|
||||||
- `STACKTRACE_LEVEL` is the lowest level that this output will print
|
|
||||||
a stacktrace. This value is inherited.
|
|
||||||
- `COLORIZE` will default to `true` for `console` as
|
|
||||||
described, otherwise it will default to `false`.
|
|
||||||
|
|
||||||
### Non-inherited default values
|
|
||||||
|
|
||||||
There are several values which are not inherited as described above but
|
|
||||||
rather default to those specific to type of logger, these are:
|
|
||||||
`EXPRESSION`, `FLAGS`, `PREFIX` and `FILE_NAME`.
|
|
||||||
|
|
||||||
#### `EXPRESSION`
|
|
||||||
|
|
||||||
`EXPRESSION` represents a regular expression that log events must match to be logged by the sublogger. Either the log message, (with colors removed), must match or the `longfilename:linenumber:functionname` must match. NB: the whole message or string doesn't need to completely match.
|
|
||||||
|
|
||||||
Please note this expression will be run in the sublogger's goroutine
|
|
||||||
not the logging event subroutine. Therefore it can be complicated.
|
|
||||||
|
|
||||||
#### `FLAGS`
|
|
||||||
|
|
||||||
`FLAGS` represents the preceding logging context information that is
|
|
||||||
printed before each message. It is a comma-separated string set. The order of values does not matter.
|
|
||||||
|
|
||||||
Possible values are:
|
|
||||||
|
|
||||||
- `none` or `,` - No flags.
|
|
||||||
- `date` - the date in the local time zone: `2009/01/23`.
|
|
||||||
- `time` - the time in the local time zone: `01:23:23`.
|
|
||||||
- `microseconds` - microsecond resolution: `01:23:23.123123`. Assumes
|
|
||||||
time.
|
|
||||||
- `longfile` - full file name and line number: `/a/b/c/d.go:23`.
|
|
||||||
- `shortfile` - final file name element and line number: `d.go:23`.
|
|
||||||
- `funcname` - function name of the caller: `runtime.Caller()`.
|
|
||||||
- `shortfuncname` - last part of the function name. Overrides
|
|
||||||
`funcname`.
|
|
||||||
- `utc` - if date or time is set, use UTC rather than the local time
|
|
||||||
zone.
|
|
||||||
- `levelinitial` - Initial character of the provided level in brackets eg. `[I]` for info.
|
|
||||||
- `level` - Provided level in brackets `[INFO]`
|
|
||||||
- `medfile` - Last 20 characters of the filename - equivalent to
|
|
||||||
`shortfile,longfile`.
|
|
||||||
- `stdflags` - Equivalent to `date,time,medfile,shortfuncname,levelinitial`
|
|
||||||
|
|
||||||
### Console mode
|
|
||||||
|
|
||||||
In this mode the logger will forward log messages to the stdout and
|
|
||||||
stderr streams attached to the Gitea process.
|
|
||||||
|
|
||||||
For loggers in console mode, `COLORIZE` will default to `true` if not
|
|
||||||
on windows, or the windows terminal can be set into ANSI mode or is a
|
|
||||||
cygwin or Msys pipe.
|
|
||||||
|
|
||||||
Settings:
|
|
||||||
|
|
||||||
- `STDERR`: **false**: Whether the logger should print to `stderr` instead of `stdout`.
|
|
||||||
|
|
||||||
### File mode
|
|
||||||
|
|
||||||
In this mode the logger will save log messages to a file.
|
|
||||||
|
|
||||||
Settings:
|
|
||||||
|
|
||||||
- `FILE_NAME`: The file to write the log events to. For details see below.
|
|
||||||
- `MAX_SIZE_SHIFT`: **28**: Maximum size shift of a single file. 28 represents 256Mb. For details see below.
|
|
||||||
- `LOG_ROTATE` **true**: Whether to rotate the log files. TODO: if false, will it delete instead on daily rotate, or do nothing?.
|
|
||||||
- `DAILY_ROTATE`: **true**: Whether to rotate logs daily.
|
|
||||||
- `MAX_DAYS`: **7**: Delete rotated log files after this number of days.
|
|
||||||
- `COMPRESS`: **true**: Whether to compress old log files by default with gzip.
|
|
||||||
- `COMPRESSION_LEVEL`: **-1**: Compression level. For details see below.
|
|
||||||
|
|
||||||
The default value of `FILE_NAME` depends on the respective logger facility.
|
|
||||||
If unset, their own default will be used.
|
|
||||||
If set it will be relative to the provided `ROOT_PATH` in the master `[log]` section.
|
|
||||||
|
|
||||||
`MAX_SIZE_SHIFT` defines the maximum size of a file by left shifting 1 the given number of times (`1 << x`).
|
|
||||||
The exact behavior at the time of v1.17.3 can be seen [here](https://github.com/go-gitea/gitea/blob/v1.17.3/modules/setting/log.go#L185).
|
|
||||||
|
|
||||||
The useful values of `COMPRESSION_LEVEL` are from 1 to (and including) 9, where higher numbers mean better compression.
|
|
||||||
Beware that better compression might come with higher resource usage.
|
|
||||||
Must be preceded with a `-` sign.
|
|
||||||
|
|
||||||
### Conn mode
|
|
||||||
|
|
||||||
In this mode the logger will send log messages over a network socket.
|
|
||||||
|
|
||||||
Settings:
|
|
||||||
|
|
||||||
- `ADDR`: **:7020**: Sets the address to connect to.
|
|
||||||
- `PROTOCOL`: **tcp**: Set the protocol, either "tcp", "unix" or "udp".
|
|
||||||
- `RECONNECT`: **false**: Try to reconnect when connection is lost.
|
|
||||||
- `RECONNECT_ON_MSG`: **false**: Reconnect host for every single message.
|
|
||||||
|
|
||||||
### SMTP mode
|
|
||||||
|
|
||||||
In this mode the logger will send log messages in email.
|
|
||||||
|
|
||||||
It is not recommended to use this logger to send general logging
|
|
||||||
messages. However, you could perhaps set this logger to work on `FATAL` messages only.
|
|
||||||
|
|
||||||
Settings:
|
|
||||||
|
|
||||||
- `HOST`: **127.0.0.1:25**: The SMTP host to connect to.
|
|
||||||
- `USER`: User email address to send from.
|
|
||||||
- `PASSWD`: Password for the smtp server.
|
|
||||||
- `RECEIVERS`: Email addresses to send to.
|
|
||||||
- `SUBJECT`: **Diagnostic message from Gitea**. The content of the email's subject field.
|
|
||||||
|
|
||||||
## Log Groups
|
## Log Groups
|
||||||
|
|
||||||
The fundamental thing to be aware of in Gitea is that there are several
|
The fundamental thing to be aware of in Gitea is that there are several
|
||||||
|
@ -340,6 +172,106 @@ which will not be inherited from the `[log]` or relevant
|
||||||
- `EXPRESSION` will default to `""`
|
- `EXPRESSION` will default to `""`
|
||||||
- `PREFIX` will default to `""`
|
- `PREFIX` will default to `""`
|
||||||
|
|
||||||
|
## Log outputs
|
||||||
|
|
||||||
|
Gitea provides 4 possible log outputs:
|
||||||
|
|
||||||
|
- `console` - Log to `os.Stdout` or `os.Stderr`
|
||||||
|
- `file` - Log to a file
|
||||||
|
- `conn` - Log to a keep-alive TCP connection
|
||||||
|
- `smtp` - Log via email
|
||||||
|
|
||||||
|
Certain configuration is common to all modes of log output:
|
||||||
|
|
||||||
|
- `LEVEL` is the lowest level that this output will log. This value
|
||||||
|
is inherited from `[log]` and in the case of the non-default loggers
|
||||||
|
from `[log.sublogger]`.
|
||||||
|
- `STACKTRACE_LEVEL` is the lowest level that this output will print
|
||||||
|
a stacktrace. This value is inherited.
|
||||||
|
- `MODE` is the mode of the log output. It will default to the sublogger
|
||||||
|
name. Thus `[log.console.router]` will default to `MODE = console`.
|
||||||
|
- `COLORIZE` will default to `true` for `console` as
|
||||||
|
described, otherwise it will default to `false`.
|
||||||
|
|
||||||
|
### Non-inherited default values
|
||||||
|
|
||||||
|
There are several values which are not inherited as described above but
|
||||||
|
rather default to those specific to type of logger, these are:
|
||||||
|
`EXPRESSION`, `FLAGS`, `PREFIX` and `FILE_NAME`.
|
||||||
|
|
||||||
|
#### `EXPRESSION`
|
||||||
|
|
||||||
|
`EXPRESSION` represents a regular expression that log events must match to be logged by the sublogger. Either the log message, (with colors removed), must match or the `longfilename:linenumber:functionname` must match. NB: the whole message or string doesn't need to completely match.
|
||||||
|
|
||||||
|
Please note this expression will be run in the sublogger's goroutine
|
||||||
|
not the logging event subroutine. Therefore it can be complicated.
|
||||||
|
|
||||||
|
#### `FLAGS`
|
||||||
|
|
||||||
|
`FLAGS` represents the preceding logging context information that is
|
||||||
|
printed before each message. It is a comma-separated string set. The order of values does not matter.
|
||||||
|
|
||||||
|
Possible values are:
|
||||||
|
|
||||||
|
- `none` or `,` - No flags.
|
||||||
|
- `date` - the date in the local time zone: `2009/01/23`.
|
||||||
|
- `time` - the time in the local time zone: `01:23:23`.
|
||||||
|
- `microseconds` - microsecond resolution: `01:23:23.123123`. Assumes
|
||||||
|
time.
|
||||||
|
- `longfile` - full file name and line number: `/a/b/c/d.go:23`.
|
||||||
|
- `shortfile` - final file name element and line number: `d.go:23`.
|
||||||
|
- `funcname` - function name of the caller: `runtime.Caller()`.
|
||||||
|
- `shortfuncname` - last part of the function name. Overrides
|
||||||
|
`funcname`.
|
||||||
|
- `utc` - if date or time is set, use UTC rather than the local time
|
||||||
|
zone.
|
||||||
|
- `levelinitial` - Initial character of the provided level in brackets eg. `[I]` for info.
|
||||||
|
- `level` - Provided level in brackets `[INFO]`
|
||||||
|
- `medfile` - Last 20 characters of the filename - equivalent to
|
||||||
|
`shortfile,longfile`.
|
||||||
|
- `stdflags` - Equivalent to `date,time,medfile,shortfuncname,levelinitial`
|
||||||
|
|
||||||
|
### Console mode
|
||||||
|
|
||||||
|
For loggers in console mode, `COLORIZE` will default to `true` if not
|
||||||
|
on windows, or the windows terminal can be set into ANSI mode or is a
|
||||||
|
cygwin or Msys pipe.
|
||||||
|
|
||||||
|
If `STDERR` is set to `true` the logger will use `os.Stderr` instead of
|
||||||
|
`os.Stdout`.
|
||||||
|
|
||||||
|
### File mode
|
||||||
|
|
||||||
|
The `FILE_NAME` defaults as described above. If set it will be relative
|
||||||
|
to the provided `ROOT_PATH` in the master `[log]` section.
|
||||||
|
|
||||||
|
Other values:
|
||||||
|
|
||||||
|
- `LOG_ROTATE`: **true**: Rotate the log files.
|
||||||
|
- `MAX_SIZE_SHIFT`: **28**: Maximum size shift of a single file, 28 represents 256Mb.
|
||||||
|
- `DAILY_ROTATE`: **true**: Rotate logs daily.
|
||||||
|
- `MAX_DAYS`: **7**: Delete the log file after n days
|
||||||
|
- `COMPRESS`: **true**: Compress old log files by default with gzip
|
||||||
|
- `COMPRESSION_LEVEL`: **-1**: Compression level
|
||||||
|
|
||||||
|
### Conn mode
|
||||||
|
|
||||||
|
- `RECONNECT_ON_MSG`: **false**: Reconnect host for every single message.
|
||||||
|
- `RECONNECT`: **false**: Try to reconnect when connection is lost.
|
||||||
|
- `PROTOCOL`: **tcp**: Set the protocol, either "tcp", "unix" or "udp".
|
||||||
|
- `ADDR`: **:7020**: Sets the address to connect to.
|
||||||
|
|
||||||
|
### SMTP mode
|
||||||
|
|
||||||
|
It is not recommended to use this logger to send general logging
|
||||||
|
messages. However, you could perhaps set this logger to work on `FATAL`.
|
||||||
|
|
||||||
|
- `USER`: User email address to send from.
|
||||||
|
- `PASSWD`: Password for the smtp server.
|
||||||
|
- `HOST`: **127.0.0.1:25**: The SMTP host to connect to.
|
||||||
|
- `RECEIVERS`: Email addresses to send to.
|
||||||
|
- `SUBJECT`: **Diagnostic message from Gitea**
|
||||||
|
|
||||||
## Debugging problems
|
## Debugging problems
|
||||||
|
|
||||||
When submitting logs in Gitea issues it is often helpful to submit
|
When submitting logs in Gitea issues it is often helpful to submit
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
---
|
||||||
|
date: "2017-08-23T09:00:00+02:00"
|
||||||
|
title: "Make"
|
||||||
|
slug: "make"
|
||||||
|
weight: 10
|
||||||
|
toc: false
|
||||||
|
draft: false
|
||||||
|
menu:
|
||||||
|
sidebar:
|
||||||
|
parent: "advanced"
|
||||||
|
name: "Make"
|
||||||
|
weight: 30
|
||||||
|
identifier: "make"
|
||||||
|
---
|
||||||
|
|
||||||
|
# Make
|
||||||
|
|
||||||
|
Gitea fait largement usage de Make pour automatiser les tâches et avoir un développement plus rapide. Ce guide explique comment installer Make.
|
||||||
|
|
||||||
|
### Linux
|
||||||
|
|
||||||
|
Vous pouvez installer Make avec votre gestionnaire de paquetages
|
||||||
|
|
||||||
|
Depuis Ubuntu/Debian:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo apt-get install build-essential
|
||||||
|
```
|
||||||
|
|
||||||
|
Depuis Fedora/RHEL/CentOS:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo yum install make
|
||||||
|
```
|
||||||
|
|
||||||
|
### Windows
|
||||||
|
|
||||||
|
Si vous utilisez Windows, vous pouvez télécharger une des versions suivantes de Make:
|
||||||
|
|
||||||
|
- [Simple binaire](http://www.equation.com/servlet/equation.cmd?fa=make). Copiez-le quelque part et mettez à jour `PATH`.
|
||||||
|
- [32-bits version](ftp://ftp.equation.com/make/32/make.exe)
|
||||||
|
- [64-bits version](ftp://ftp.equation.com/make/64/make.exe)
|
||||||
|
- [MinGW](http://www.mingw.org/) inclut un _build_. Le fichier binaire est nommé `mingw32-make.exe` plutôt que `make.exe`. Ajoutez le dossier `bin` à votre `PATH`.
|
||||||
|
- [Chocolatey package](https://chocolatey.org/packages/make). Exécutez `choco install make`.
|
|
@ -0,0 +1,45 @@
|
||||||
|
---
|
||||||
|
date: "2017-01-14T11:00:00-02:00"
|
||||||
|
title: "Make 安装"
|
||||||
|
slug: "make"
|
||||||
|
weight: 10
|
||||||
|
toc: false
|
||||||
|
draft: false
|
||||||
|
menu:
|
||||||
|
sidebar:
|
||||||
|
parent: "advanced"
|
||||||
|
name: "Make 安装"
|
||||||
|
weight: 30
|
||||||
|
identifier: "make"
|
||||||
|
---
|
||||||
|
|
||||||
|
# 安装 Make
|
||||||
|
|
||||||
|
Gitea 大量使用了 Make 工具来自动执行任务并改进开发,本文将介绍如何安装 Make。
|
||||||
|
|
||||||
|
### 在 Linux 环境下
|
||||||
|
|
||||||
|
可以使用包管理工具来安装 Make。
|
||||||
|
|
||||||
|
Ubuntu/Debian 环境,执行以下命令:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo apt-get install make
|
||||||
|
```
|
||||||
|
|
||||||
|
Fedora/RHEL/CentOS,执行以下命令:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo yum install make
|
||||||
|
```
|
||||||
|
|
||||||
|
### 在 Windows 环境下
|
||||||
|
|
||||||
|
您可以参照以下三种方案在 Windows 环境安装 Make:
|
||||||
|
|
||||||
|
- 直接使用 [exe文件](http://www.equation.com/servlet/equation.cmd?fa=make):将适合您系统的exe文件拷贝到某处并添加至环境变量 `PATH` 中。
|
||||||
|
- [32 位版本](ftp://ftp.equation.com/make/32/make.exe)
|
||||||
|
- [64 位版本](ftp://ftp.equation.com/make/64/make.exe)
|
||||||
|
- 使用 [MinGW](http://www.mingw.org/) 工具:
|
||||||
|
- 此处使用二进制文件 `mingw32-make.exe` 替代前面提到的 `make.exe`文件。同样您需要将包含此exe文件的 `bin` 目录添加至环境变量 `PATH`中。
|
||||||
|
- 通过 [Chocolatey](https://chocolatey.org/packages/make) 安装: 执行 `choco install make` 命令即可。
|
|
@ -41,15 +41,13 @@ For an existing remote repository, you can set up pull mirroring as follows:
|
||||||
|
|
||||||
The repository now gets mirrored periodically from the remote repository. You can force a sync by selecting **Synchronize Now** in the repository settings.
|
The repository now gets mirrored periodically from the remote repository. You can force a sync by selecting **Synchronize Now** in the repository settings.
|
||||||
|
|
||||||
:exclamation::exclamation: **NOTE:** You can only set up pull mirroring for repos that don't exist yet on your instance. Once the repo is created, you can't convert it into a pull mirror anymore. :exclamation::exclamation:
|
|
||||||
|
|
||||||
## Pushing to a remote repository
|
## Pushing to a remote repository
|
||||||
|
|
||||||
For an existing repository, you can set up push mirroring as follows:
|
For an existing repository, you can set up push mirroring as follows:
|
||||||
|
|
||||||
1. In your repository, go to **Settings** > **Repository**, and then the **Mirror Settings** section.
|
1. In your repository, go to **Settings** > **Repository**, and then the **Mirror Settings** section.
|
||||||
2. Enter a repository URL.
|
2. Enter a repository URL.
|
||||||
3. If the repository needs authentication expand the **Authorization** section and fill in your authentication information. Note that the requested **password** can also be your access token.
|
3. If the repository needs authentication expand the **Authorization** section and fill in your authentication information.
|
||||||
4. Select **Add Push Mirror** to save the configuration.
|
4. Select **Add Push Mirror** to save the configuration.
|
||||||
|
|
||||||
The repository now gets mirrored periodically to the remote repository. You can force a sync by selecting **Synchronize Now**. In case of an error a message displayed to help you resolve it.
|
The repository now gets mirrored periodically to the remote repository. You can force a sync by selecting **Synchronize Now**. In case of an error a message displayed to help you resolve it.
|
||||||
|
@ -61,11 +59,9 @@ The repository now gets mirrored periodically to the remote repository. You can
|
||||||
To set up a mirror from Gitea to GitHub, you need to follow these steps:
|
To set up a mirror from Gitea to GitHub, you need to follow these steps:
|
||||||
|
|
||||||
1. Create a [GitHub personal access token](https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token) with the *public_repo* box checked.
|
1. Create a [GitHub personal access token](https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token) with the *public_repo* box checked.
|
||||||
2. Create a repository with that name on GitHub. Unlike Gitea, GitHub does not support creating repositories by pushing to the remote. You can also use an existing remote repo if it has the same commit history as your Gitea repo.
|
2. Fill in the **Git Remote Repository URL**: `https://github.com/<your_github_group>/<your_github_project>.git`.
|
||||||
3. In the settings of your Gitea repo, fill in the **Git Remote Repository URL**: `https://github.com/<your_github_group>/<your_github_project>.git`.
|
3. Fill in the **Authorization** fields with your GitHub username and the personal access token.
|
||||||
4. Fill in the **Authorization** fields with your GitHub username and the personal access token as **Password**.
|
4. Select **Add Push Mirror** to save the configuration.
|
||||||
5. (Optional, available on Gitea 1.18+) Select `Sync when new commits are pushed` so that the mirror will be updated as well as soon as there are changes. You can also disable the periodic sync if you like.
|
|
||||||
6. Select **Add Push Mirror** to save the configuration.
|
|
||||||
|
|
||||||
The repository pushes shortly thereafter. To force a push, select the **Synchronize Now** button.
|
The repository pushes shortly thereafter. To force a push, select the **Synchronize Now** button.
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,39 @@
|
||||||
|
---
|
||||||
|
date: "2019-03-11T21:45:00+00:00"
|
||||||
|
title: "高级: 第三方工具"
|
||||||
|
slug: "third-party-tools"
|
||||||
|
weight: 50
|
||||||
|
toc: false
|
||||||
|
draft: false
|
||||||
|
menu:
|
||||||
|
sidebar:
|
||||||
|
parent: "advanced"
|
||||||
|
name: "第三方工具"
|
||||||
|
weight: 50
|
||||||
|
identifier: "third-party-tools"
|
||||||
|
---
|
||||||
|
|
||||||
|
# 第三方工具列表
|
||||||
|
|
||||||
|
**注意:** 这些工具并没有经过Gitea的检验,在这里列出它们只是为了便捷.
|
||||||
|
|
||||||
|
*此列表并不是完整的列表,可以随时咨询如何添加!*
|
||||||
|
|
||||||
|
### 持续集成
|
||||||
|
|
||||||
|
[BuildKite 连接器](https://github.com/techknowlogick/gitea-buildkite-connector)
|
||||||
|
[Jenkins 插件](https://github.com/jenkinsci/gitea-plugin)
|
||||||
|
[Gitea搭配Drone](https://docs.drone.io/installation/gitea)
|
||||||
|
|
||||||
|
### 迁移
|
||||||
|
|
||||||
|
[Gitea安装脚本](https://git.coolaj86.com/coolaj86/gitea-installer.sh)
|
||||||
|
[GitHub迁移](https://gitea.com/gitea/migrator)
|
||||||
|
|
||||||
|
### 移动端
|
||||||
|
|
||||||
|
[安卓客户端GitNex](https://gitlab.com/mmarif4u/gitnex)
|
||||||
|
|
||||||
|
### 编辑器扩展
|
||||||
|
|
||||||
|
- [Gitea的Visual Studio扩展](https://github.com/maikebing/Gitea.VisualStudio) 从 [Visual Studio 扩展市场](https://marketplace.visualstudio.com/items?itemName=MysticBoy.GiteaExtensionforVisualStudio) 下载
|
|
@ -8,6 +8,6 @@ draft: false
|
||||||
menu:
|
menu:
|
||||||
sidebar:
|
sidebar:
|
||||||
name: "开发者"
|
name: "开发者"
|
||||||
weight: 55
|
weight: 50
|
||||||
identifier: "developers"
|
identifier: "developers"
|
||||||
---
|
---
|
||||||
|
|
|
@ -166,47 +166,11 @@ Uses the following fields:
|
||||||
|
|
||||||
## PAM (Pluggable Authentication Module)
|
## PAM (Pluggable Authentication Module)
|
||||||
|
|
||||||
This procedure enables PAM authentication. Users may still be added to the
|
To configure PAM, set the 'PAM Service Name' to a filename in `/etc/pam.d/`. To
|
||||||
system manually using the user administration. PAM provides a mechanism to
|
work with normal Linux passwords, the user running Gitea must have read access
|
||||||
automatically add users to the current database by testing them against PAM
|
to `/etc/shadow`.
|
||||||
authentication. To work with normal Linux passwords, the user running Gitea
|
|
||||||
must also have read access to `/etc/shadow` in order to check the validity of
|
|
||||||
the account when logging in using a public key.
|
|
||||||
|
|
||||||
**Note**: If a user has added SSH public keys into Gitea, the use of these
|
**Note**: PAM support is added via [build-time flags](https://docs.gitea.io/en-us/install-from-source/#build), and the official binaries provided do not have this enabled.
|
||||||
keys _may_ bypass the login check system. Therefore, if you wish to disable a user who
|
|
||||||
authenticates with PAM, you _should_ also manually disable the account in Gitea using the
|
|
||||||
built-in user manager.
|
|
||||||
|
|
||||||
1. Configure and prepare the installation.
|
|
||||||
- It is recommended that you create an administrative user.
|
|
||||||
- Deselecting automatic sign-up may also be desired.
|
|
||||||
1. Once the database has been initialized, log in as the newly created
|
|
||||||
administrative user.
|
|
||||||
1. Navigate to the user setting (icon in top-right corner), and select
|
|
||||||
`Site Administration` -> `Authentication Sources`, and select
|
|
||||||
`Add Authentication Source`.
|
|
||||||
1. Fill out the field as follows:
|
|
||||||
- `Authentication Type` : `PAM`
|
|
||||||
- `Name` : Any value should be valid here, use "System Authentication" if
|
|
||||||
you'd like.
|
|
||||||
- `PAM Service Name` : Select the appropriate file listed under `/etc/pam.d/`
|
|
||||||
that performs the authentication desired.[^1]
|
|
||||||
- `PAM Email Domain` : The e-mail suffix to append to user authentication.
|
|
||||||
For example, if the login system expects a user called `gituser`, and this
|
|
||||||
field is set to `mail.com`, then Gitea will expect the `user email` field
|
|
||||||
for an authenticated GIT instance to be `gituser@mail.com`.[^2]
|
|
||||||
|
|
||||||
**Note**: PAM support is added via [build-time flags](https://docs.gitea.io/en-us/install-from-source/#build),
|
|
||||||
and the official binaries provided do not have this enabled. PAM requires that
|
|
||||||
the necessary libpam dynamic library be available and the necessary PAM
|
|
||||||
development headers be accessible to the compiler.
|
|
||||||
|
|
||||||
[^1]: For example, using standard Linux log-in on Debian "Bullseye" use
|
|
||||||
`common-session-noninteractive` - this value may be valid for other flavors of
|
|
||||||
Debian including Ubuntu and Mint, consult your distribution's documentation.
|
|
||||||
[^2]: **This is a required field for PAM**. Be aware: In the above example, the
|
|
||||||
user will log into the Gitea web interface as `gituser` and not `gituser@mail.com`
|
|
||||||
|
|
||||||
## SMTP (Simple Mail Transfer Protocol)
|
## SMTP (Simple Mail Transfer Protocol)
|
||||||
|
|
||||||
|
|
|
@ -188,7 +188,3 @@ if (json_last_error() !== JSON_ERROR_NONE) {
|
||||||
```
|
```
|
||||||
|
|
||||||
There is a Test Delivery button in the webhook settings that allows to test the configuration as well as a list of the most Recent Deliveries.
|
There is a Test Delivery button in the webhook settings that allows to test the configuration as well as a list of the most Recent Deliveries.
|
||||||
|
|
||||||
### Authorization header
|
|
||||||
|
|
||||||
**With 1.19**, Gitea hooks can be configured to send an [authorization header](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Authorization) to the webhook target.
|
|
||||||
|
|
|
@ -58,33 +58,29 @@ https://github.com/loganinak/MigrateGitlabToGogs
|
||||||
|
|
||||||
## Where does Gitea store what file
|
## Where does Gitea store what file
|
||||||
|
|
||||||
- _`AppWorkPath`_
|
- WorkPath
|
||||||
- The `--work-path` flag
|
- Environment variable `GITEA_WORK_DIR`
|
||||||
- Else Environment variable `GITEA_WORK_DIR`
|
- Else `--work-path` flag
|
||||||
- Else a built-in value set at build time
|
|
||||||
- Else the directory that contains the Gitea binary
|
- Else the directory that contains the Gitea binary
|
||||||
- `%(APP_DATA_PATH)` (default for database, indexers, etc.)
|
- AppDataPath (default for database, indexers, etc.)
|
||||||
- `APP_DATA_PATH` from `app.ini`
|
- `APP_DATA_PATH` from `app.ini`
|
||||||
- Else _`AppWorkPath`_`/data`
|
- Else `%(WorkPath)/data`
|
||||||
- _`CustomPath`_ (custom templates)
|
- CustomPath (custom templates)
|
||||||
- The `--custom-path` flag
|
- Environment variable `GITEA_CUSTOM`
|
||||||
- Else Environment variable `GITEA_CUSTOM`
|
- Else `%(WorkPath)/custom`
|
||||||
- Else a built-in value set at build time
|
|
||||||
- Else _`AppWorkPath`_`/custom`
|
|
||||||
- HomeDir
|
- HomeDir
|
||||||
- Unix: Environment variable `HOME`
|
- Unix: Environment variable `HOME`
|
||||||
- Windows: Environment variable `USERPROFILE`, else environment variables `HOMEDRIVE`+`HOMEPATH`
|
- Windows: Environment variable `USERPROFILE`, else environment variables `HOMEDRIVE`+`HOMEPATH`
|
||||||
- RepoRootPath
|
- RepoRootPath
|
||||||
- `ROOT` in the \[repository] section of `app.ini` if absolute
|
- `ROOT` in the \[repository] section of `app.ini` if absolute
|
||||||
- Else _`AppWorkPath`_`/ROOT` if `ROOT` in the \[repository] section of `app.ini` if relative
|
- Else `%(AppWorkPath)/ROOT` if `ROOT` in the \[repository] section of `app.ini` if relative
|
||||||
- Default `%(APP_DATA_PATH)/gitea-repositories`
|
- Default `%(AppDataPath)/gitea-repositories`
|
||||||
- INI (config file)
|
- INI (config file)
|
||||||
- `--config` flag
|
- `-c` flag
|
||||||
- A possible built-in value set a build time
|
- Else `%(CustomPath)/conf/app.ini`
|
||||||
- Else _`CustomPath`_`/conf/app.ini`
|
|
||||||
- SQLite Database
|
- SQLite Database
|
||||||
- `PATH` in `database` section of `app.ini`
|
- `PATH` in `database` section of `app.ini`
|
||||||
- Else `%(APP_DATA_PATH)/gitea.db`
|
- Else `%(AppDataPath)/gitea.db`
|
||||||
|
|
||||||
## Not seeing a clone URL or the clone URL being incorrect
|
## Not seeing a clone URL or the clone URL being incorrect
|
||||||
|
|
||||||
|
|
|
@ -87,14 +87,14 @@ To build from source, the following programs must be present on the system:
|
||||||
|
|
||||||
- `go` {{< min-go-version >}} or higher, see [here](https://golang.org/dl/)
|
- `go` {{< min-go-version >}} or higher, see [here](https://golang.org/dl/)
|
||||||
- `node` {{< min-node-version >}} or higher with `npm`, see [here](https://nodejs.org/en/download/)
|
- `node` {{< min-node-version >}} or higher with `npm`, see [here](https://nodejs.org/en/download/)
|
||||||
- `make`, see [here]({{< relref "doc/developers/hacking-on-gitea.en-us.md" >}}#installing-make)
|
- `make`, see <a href='{{< relref "doc/developers/hacking-on-gitea.en-us.md" >}}#installing-make'>here</a>
|
||||||
|
|
||||||
Various [make tasks](https://github.com/go-gitea/gitea/blob/main/Makefile)
|
Various [make tasks](https://github.com/go-gitea/gitea/blob/main/Makefile)
|
||||||
are provided to keep the build process as simple as possible.
|
are provided to keep the build process as simple as possible.
|
||||||
|
|
||||||
Depending on requirements, the following build tags can be included.
|
Depending on requirements, the following build tags can be included.
|
||||||
|
|
||||||
- `bindata`: Build a single monolithic binary, with all assets included. Required for production build.
|
- `bindata`: Build a single monolithic binary, with all assets included.
|
||||||
- `sqlite sqlite_unlock_notify`: Enable support for a
|
- `sqlite sqlite_unlock_notify`: Enable support for a
|
||||||
[SQLite3](https://sqlite.org/) database. Suggested only for tiny
|
[SQLite3](https://sqlite.org/) database. Suggested only for tiny
|
||||||
installations.
|
installations.
|
||||||
|
@ -103,10 +103,11 @@ Depending on requirements, the following build tags can be included.
|
||||||
available to PAM.
|
available to PAM.
|
||||||
- `gogit`: (EXPERIMENTAL) Use go-git variants of Git commands.
|
- `gogit`: (EXPERIMENTAL) Use go-git variants of Git commands.
|
||||||
|
|
||||||
Bundling all assets (JS/CSS/templates, etc) into the binary. Using the `bindata` build tag is required for
|
Bundling assets into the binary using the `bindata` build tag is recommended for
|
||||||
production deployments. You could exclude `bindata` when you are developing/testing Gitea or able to separate the assets correctly.
|
production deployments. It is possible to serve the static assets directly via a reverse proxy,
|
||||||
|
but in most cases it is not necessary, and assets should still be bundled in the binary.
|
||||||
To include all assets, use the `bindata` tag:
|
You may want to exclude bindata while developing/testing Gitea.
|
||||||
|
To include assets, add the `bindata` tag:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
TAGS="bindata" make build
|
TAGS="bindata" make build
|
||||||
|
@ -143,11 +144,11 @@ launched manually from command line, it can be killed by pressing `Ctrl + C`.
|
||||||
|
|
||||||
## Changing default paths
|
## Changing default paths
|
||||||
|
|
||||||
Gitea will search for a number of things from the _`CustomPath`_. By default this is
|
Gitea will search for a number of things from the `CustomPath`. By default this is
|
||||||
the `custom/` directory in the current working directory when running Gitea. It will also
|
the `custom/` directory in the current working directory when running Gitea. It will also
|
||||||
look for its configuration file _`CustomConf`_ in _`CustomPath`_/conf/app.ini`, and will use the
|
look for its configuration file `CustomConf` in `$CustomPath/conf/app.ini`, and will use the
|
||||||
current working directory as the relative base path _`AppWorkPath`_ for a number configurable
|
current working directory as the relative base path `AppWorkPath` for a number configurable
|
||||||
values. Finally the static files will be served from _`StaticRootPath`_ which defaults to the _`AppWorkPath`_.
|
values. Finally the static files will be served from `StaticRootPath` which defaults to the `AppWorkPath`.
|
||||||
|
|
||||||
These values, although useful when developing, may conflict with downstream users preferences.
|
These values, although useful when developing, may conflict with downstream users preferences.
|
||||||
|
|
||||||
|
@ -155,10 +156,10 @@ One option is to use a script file to shadow the `gitea` binary and create an ap
|
||||||
environment before running Gitea. However, when building you can change these defaults
|
environment before running Gitea. However, when building you can change these defaults
|
||||||
using the `LDFLAGS` environment variable for `make`. The appropriate settings are as follows
|
using the `LDFLAGS` environment variable for `make`. The appropriate settings are as follows
|
||||||
|
|
||||||
- To set the _`CustomPath`_ use `LDFLAGS="-X \"code.gitea.io/gitea/modules/setting.CustomPath=custom-path\""`
|
- To set the `CustomPath` use `LDFLAGS="-X \"code.gitea.io/gitea/modules/setting.CustomPath=custom-path\""`
|
||||||
- For _`CustomConf`_ you should use `-X \"code.gitea.io/gitea/modules/setting.CustomConf=conf.ini\"`
|
- For `CustomConf` you should use `-X \"code.gitea.io/gitea/modules/setting.CustomConf=conf.ini\"`
|
||||||
- For _`AppWorkPath`_ you should use `-X \"code.gitea.io/gitea/modules/setting.AppWorkPath=working-path\"`
|
- For `AppWorkPath` you should use `-X \"code.gitea.io/gitea/modules/setting.AppWorkPath=working-path\"`
|
||||||
- For _`StaticRootPath`_ you should use `-X \"code.gitea.io/gitea/modules/setting.StaticRootPath=static-root-path\"`
|
- For `StaticRootPath` you should use `-X \"code.gitea.io/gitea/modules/setting.StaticRootPath=static-root-path\"`
|
||||||
- To change the default PID file location use `-X \"code.gitea.io/gitea/modules/setting.PIDFile=/run/gitea.pid\"`
|
- To change the default PID file location use `-X \"code.gitea.io/gitea/modules/setting.PIDFile=/run/gitea.pid\"`
|
||||||
|
|
||||||
Add as many of the strings with their preceding `-X` to the `LDFLAGS` variable and run `make build`
|
Add as many of the strings with their preceding `-X` to the `LDFLAGS` variable and run `make build`
|
||||||
|
|
|
@ -53,7 +53,7 @@ git checkout pr-xyz
|
||||||
|
|
||||||
## Compilation
|
## Compilation
|
||||||
|
|
||||||
Comme nous regroupons déjà toutes les bibliothèques requises pour compiler Gitea, vous pouvez continuer avec le processus de compilation lui-même. Nous fournissons diverses [tâches Make](https://github.com/go-gitea/gitea/blob/master/Makefile) pour rendre le processus de construction aussi simple que possible. [Voyez ici comment obtenir Make](/fr-fr/hacking-on-gitea/). Selon vos besoins, vous pourrez éventuellement ajouter diverses options de compilation, vous pouvez choisir entre ces options :
|
Comme nous regroupons déjà toutes les bibliothèques requises pour compiler Gitea, vous pouvez continuer avec le processus de compilation lui-même. Nous fournissons diverses [tâches Make](https://github.com/go-gitea/gitea/blob/master/Makefile) pour rendre le processus de construction aussi simple que possible. <a href='{{< relref "doc/advanced/make.fr-fr.md" >}}'>Voyez ici comment obtenir Make</a>. Selon vos besoins, vous pourrez éventuellement ajouter diverses options de compilation, vous pouvez choisir entre ces options :
|
||||||
|
|
||||||
* `bindata`: Intègre toutes les ressources nécessaires à l'exécution d'une instance de Gitea, ce qui rend un déploiement facile car il n'est pas nécessaire de se préoccuper des fichiers supplémentaires.
|
* `bindata`: Intègre toutes les ressources nécessaires à l'exécution d'une instance de Gitea, ce qui rend un déploiement facile car il n'est pas nécessaire de se préoccuper des fichiers supplémentaires.
|
||||||
* `sqlite sqlite_unlock_notify`: Active la prise en charge d'une base de données [SQLite3](https://sqlite.org/), ceci n'est recommandé que pour les petites installations de Gitea.
|
* `sqlite sqlite_unlock_notify`: Active la prise en charge d'une base de données [SQLite3](https://sqlite.org/), ceci n'est recommandé que pour les petites installations de Gitea.
|
||||||
|
|
|
@ -54,7 +54,7 @@ git checkout v{{< version >}}
|
||||||
|
|
||||||
- `go` {{< min-go-version >}} 或以上版本, 详见[这里](https://golang.google.cn/doc/install)
|
- `go` {{< min-go-version >}} 或以上版本, 详见[这里](https://golang.google.cn/doc/install)
|
||||||
- `node` {{< min-node-version >}} 或以上版本,并且安装 `npm`, 详见[这里](https://nodejs.org/zh-cn/download/)
|
- `node` {{< min-node-version >}} 或以上版本,并且安装 `npm`, 详见[这里](https://nodejs.org/zh-cn/download/)
|
||||||
- `make`, 详见[这里](/zh-cn/hacking-on-gitea/)
|
- `make`, 详见[这里]({{< relref "make.zh-cn.md" >}})</a>
|
||||||
|
|
||||||
各种可用的 [make 任务](https://github.com/go-gitea/gitea/blob/main/Makefile)
|
各种可用的 [make 任务](https://github.com/go-gitea/gitea/blob/main/Makefile)
|
||||||
可以用来使编译过程更方便。
|
可以用来使编译过程更方便。
|
||||||
|
|
|
@ -29,16 +29,10 @@ the official [install instructions](https://docs.docker.com/compose/install/).
|
||||||
|
|
||||||
The most simple setup just creates a volume and a network and starts the `gitea/gitea:latest-rootless`
|
The most simple setup just creates a volume and a network and starts the `gitea/gitea:latest-rootless`
|
||||||
image as a service. Since there is no database available, one can be initialized using SQLite3.
|
image as a service. Since there is no database available, one can be initialized using SQLite3.
|
||||||
|
Create a directory for `data` and `config` then paste the following content into a file named `docker-compose.yml`.
|
||||||
Create a directory for `data` and `config`:
|
Note that the volume should be owned by the user/group with the UID/GID specified in the config file. By default Gitea in docker will use uid:1000 gid:1000. If needed you can set ownership on those folders with the command: `sudo chown 1000:1000 config/ data/`
|
||||||
|
If you don't give the volume correct permissions, the container may not start.
|
||||||
```sh
|
For a stable release you could use `:latest-rootless`, `:1-rootless` or specify a certain release like `:{{< version >}}-rootless`, but if you'd like to use the latest development version then `:dev-rootless` would be an appropriate tag. If you'd like to run the latest commit from a release branch you can use the `:1.x-dev-rootless` tag, where x is the minor version of Gitea. (e.g. `:1.16-dev-rootless`)
|
||||||
mkdir -p gitea/{data,config}
|
|
||||||
cd gitea
|
|
||||||
touch docker-compose.yml
|
|
||||||
```
|
|
||||||
|
|
||||||
Then paste the following content into a file named `docker-compose.yml`:
|
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
version: "2"
|
version: "2"
|
||||||
|
@ -57,16 +51,6 @@ services:
|
||||||
- "2222:2222"
|
- "2222:2222"
|
||||||
```
|
```
|
||||||
|
|
||||||
Note that the volume should be owned by the user/group with the UID/GID specified in the config file. By default Gitea in docker will use uid:1000 gid:1000. If needed you can set ownership on those folders with the command:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
sudo chown 1000:1000 config/ data/
|
|
||||||
```
|
|
||||||
|
|
||||||
> If you don't give the volume correct permissions, the container may not start.
|
|
||||||
|
|
||||||
For a stable release you could use `:latest-rootless`, `:1-rootless` or specify a certain release like `:{{< version >}}-rootless`, but if you'd like to use the latest development version then `:dev-rootless` would be an appropriate tag. If you'd like to run the latest commit from a release branch you can use the `:1.x-dev-rootless` tag, where x is the minor version of Gitea. (e.g. `:1.16-dev-rootless`)
|
|
||||||
|
|
||||||
## Custom port
|
## Custom port
|
||||||
|
|
||||||
To bind the integrated ssh and the webserver on a different port, adjust
|
To bind the integrated ssh and the webserver on a different port, adjust
|
||||||
|
|
|
@ -32,7 +32,7 @@ The following package managers are currently supported:
|
||||||
| [Generic]({{< relref "doc/packages/generic.en-us.md" >}}) | - | any HTTP client |
|
| [Generic]({{< relref "doc/packages/generic.en-us.md" >}}) | - | any HTTP client |
|
||||||
| [Helm]({{< relref "doc/packages/helm.en-us.md" >}}) | - | any HTTP client, `cm-push` |
|
| [Helm]({{< relref "doc/packages/helm.en-us.md" >}}) | - | any HTTP client, `cm-push` |
|
||||||
| [Maven]({{< relref "doc/packages/maven.en-us.md" >}}) | Java | `mvn`, `gradle` |
|
| [Maven]({{< relref "doc/packages/maven.en-us.md" >}}) | Java | `mvn`, `gradle` |
|
||||||
| [npm]({{< relref "doc/packages/npm.en-us.md" >}}) | JavaScript | `npm`, `yarn`, `pnpm` |
|
| [npm]({{< relref "doc/packages/npm.en-us.md" >}}) | JavaScript | `npm`, `yarn` |
|
||||||
| [NuGet]({{< relref "doc/packages/nuget.en-us.md" >}}) | .NET | `nuget` |
|
| [NuGet]({{< relref "doc/packages/nuget.en-us.md" >}}) | .NET | `nuget` |
|
||||||
| [Pub]({{< relref "doc/packages/pub.en-us.md" >}}) | Dart | `dart`, `flutter` |
|
| [Pub]({{< relref "doc/packages/pub.en-us.md" >}}) | Dart | `dart`, `flutter` |
|
||||||
| [PyPI]({{< relref "doc/packages/pypi.en-us.md" >}}) | Python | `pip`, `twine` |
|
| [PyPI]({{< relref "doc/packages/pypi.en-us.md" >}}) | Python | `pip`, `twine` |
|
||||||
|
|
|
@ -1,84 +0,0 @@
|
||||||
---
|
|
||||||
date: "2022-11-01T00:00:00+00:00"
|
|
||||||
title: "Storage"
|
|
||||||
slug: "packages/storage"
|
|
||||||
draft: false
|
|
||||||
toc: false
|
|
||||||
menu:
|
|
||||||
sidebar:
|
|
||||||
parent: "packages"
|
|
||||||
name: "Storage"
|
|
||||||
weight: 5
|
|
||||||
identifier: "storage"
|
|
||||||
---
|
|
||||||
|
|
||||||
# Storage
|
|
||||||
|
|
||||||
This document describes the storage of the package registry and how it can be managed.
|
|
||||||
|
|
||||||
**Table of Contents**
|
|
||||||
|
|
||||||
{{< toc >}}
|
|
||||||
|
|
||||||
## Deduplication
|
|
||||||
|
|
||||||
The package registry has a build-in deduplication of uploaded blobs.
|
|
||||||
If two identical files are uploaded only one blob is saved on the filesystem.
|
|
||||||
This ensures no space is wasted for duplicated files.
|
|
||||||
|
|
||||||
If two packages are uploaded with identical files, both packages will display the same size but on the filesystem they require only half of the size.
|
|
||||||
Whenever a package gets deleted only the references to the underlaying blobs are removed.
|
|
||||||
The blobs get not removed at this moment, so they still require space on the filesystem.
|
|
||||||
When a new package gets uploaded the existing blobs may get referenced again.
|
|
||||||
|
|
||||||
These unreferenced blobs get deleted by a [clean up job]({{< relref "doc/advanced/config-cheat-sheet.en-us.md#cron---cleanup-expired-packages-croncleanup_packages" >}}).
|
|
||||||
The config setting `OLDER_THAN` configures how long unreferenced blobs are kept before they get deleted.
|
|
||||||
|
|
||||||
## Cleanup Rules
|
|
||||||
|
|
||||||
Package registries can become large over time without cleanup.
|
|
||||||
It's recommended to delete unnecessary packages and set up cleanup rules to automatically manage the package registry usage.
|
|
||||||
Every package owner (user or organization) manages the cleanup rules which are applied to their packages.
|
|
||||||
|
|
||||||
|Setting|Description|
|
|
||||||
|-|-|
|
|
||||||
|Enabled|Turn the cleanup rule on or off.|
|
|
||||||
|Type|Every rule manages a specific package type.|
|
|
||||||
|Apply pattern to full package name|If enabled, the patterns below are applied to the full package name (`package/version`). Otherwise only the version (`version`) is used.|
|
|
||||||
|Keep the most recent|How many versions to *always* keep for each package.|
|
|
||||||
|Keep versions matching|The regex pattern that determines which versions to keep. An empty pattern keeps no version while `.+` keeps all versions. The container registry will always keep the `latest` version even if not configured.|
|
|
||||||
|Remove versions older than|Remove only versions older than the selected days.|
|
|
||||||
|Remove versions matching|The regex pattern that determines which versions to remove. An empty pattern or `.+` leads to the removal of every package if no other setting tells otherwise.|
|
|
||||||
|
|
||||||
Every cleanup rule can show a preview of the affected packages.
|
|
||||||
This can be used to check if the cleanup rules is proper configured.
|
|
||||||
|
|
||||||
### Regex examples
|
|
||||||
|
|
||||||
Regex patterns are automatically surrounded with `\A` and `\z` anchors.
|
|
||||||
Do not include any `\A`, `\z`, `^` or `$` token in the regex patterns as they are not necessary.
|
|
||||||
The patterns are case-insensitive which matches the behaviour of the package registry in Gitea.
|
|
||||||
|
|
||||||
|Pattern|Description|
|
|
||||||
|-|-|
|
|
||||||
|`.*`|Match every possible version.|
|
|
||||||
|`v.+`|Match versions that start with `v`.|
|
|
||||||
|`release`|Match only the version `release`.|
|
|
||||||
|`release.*`|Match versions that are either named or start with `release`.|
|
|
||||||
|`.+-temp-.+`|Match versions that contain `-temp-`.|
|
|
||||||
|`v.+\|release`|Match versions that either start with `v` or are named `release`.|
|
|
||||||
|`package/v.+\|other/release`|Match versions of the package `package` that start with `v` or the version `release` of the package `other`. This needs the setting *Apply pattern to full package name* enabled.|
|
|
||||||
|
|
||||||
### How the cleanup rules work
|
|
||||||
|
|
||||||
The cleanup rules are part of the [clean up job]({{< relref "doc/advanced/config-cheat-sheet.en-us.md#cron---cleanup-expired-packages-croncleanup_packages" >}}) and run periodicly.
|
|
||||||
|
|
||||||
The cleanup rule:
|
|
||||||
|
|
||||||
1. Collects all packages of the package type for the owners registry.
|
|
||||||
1. For every package it collects all versions.
|
|
||||||
1. Excludes from the list the # versions based on the *Keep the most recent* value.
|
|
||||||
1. Excludes from the list any versions matching the *Keep versions matching* value.
|
|
||||||
1. Excludes from the list the versions more recent than the *Remove versions older than* value.
|
|
||||||
1. Excludes from the list any versions not matching the *Remove versions matching* value.
|
|
||||||
1. Deletes the remaining versions.
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue