跳至主要内容
版本:1.23.6

自定義 Gitea

自定義 Gitea 通常使用 CustomPath 文件夾進行 - 默認情況下,這是工作目錄(WorkPath)中的 custom 文件夾,但如果您的構建設置不同,則可能會有所不同。這是覆蓋配置設置、模板等的中心位置。您可以使用 gitea help 檢查 CustomPath。您還可以在 站點管理 頁面的 配置 標籤中找到路徑。您可以通過設置 GITEA_CUSTOM 環境變量或使用 gitea 二進制文件上的 --custom-path 選項來覆蓋 CustomPath。(該選項將覆蓋環境變量。)

如果 Gitea 是從二進制文件部署的,則所有默認路徑都將相對於 Gitea 二進制文件。如果從發行版安裝,這些路徑可能會修改為 Linux 文件系統標準。Gitea 將嘗試創建所需的文件夾,包括 custom/。發行版可能會使用 /etc/gitea/ 提供 custom 的符號鏈接。

應用程序設置可以在 CustomConf 文件中找到,默認情況下為 $GITEA_CUSTOM/conf/app.ini,但如果您的構建設置不同,則可能會有所不同。同樣,gitea help 將允許您查看此變量,您可以使用 gitea 二進制文件上的 --config 選項來覆蓋它。

如果無法找到 CustomPath 文件夾,請檢查 gitea help,請檢查 GITEA_CUSTOM 環境變量;這可以用於覆蓋默認路徑到其他位置。例如,GITEA_CUSTOM 可能由啟動腳本設置。您可以在站點管理頁面的“配置”標籤下檢查是否設置了該值。

備註

Gitea 必須完全重啟才能看到配置更改。

提供自定義公共文件

要使 Gitea 提供自定義公共文件(如頁面和圖像),請使用文件夾 $GITEA_CUSTOM/public/ 作為 webroot。將遵循符號鏈接。 目前,僅提供以下文件:

  • public/robots.txt
  • public/.well-known/ 文件夾中的文件
  • public/assets/ 文件夾中的文件

例如,存儲在 $GITEA_CUSTOM/public/assets/ 中的文件 image.png 可以通過 url http://gitea.domain.tld/assets/image.png 訪問。

更改徽標

要構建自定義徽標和/或圖標,克隆 Gitea 源代碼庫,替換 assets/logo.svg 和/或 assets/favicon.svg,然後運行 make generate-imagesassets/favicon.svg 僅用於圖標。這將更新以下輸出文件,然後您可以將它們放置在服務器上的 $GITEA_CUSTOM/public/assets/img 中:

  • public/assets/img/logo.svg - 用於站點圖標、應用程序圖標
  • public/assets/img/logo.png - 用於 Open Graph
  • public/assets/img/avatar_default.png - 用作默認頭像圖像
  • public/assets/img/apple-touch-icon.png - 用於 iOS 設備的書籤
  • public/assets/img/favicon.svg - 用於圖標
  • public/assets/img/favicon.png - 用於不支持 SVG 圖標的瀏覽器

如果源圖像不是矢量格式,您可以嘗試使用工具(如這個)將光柵圖像轉換為矢量圖像。

自定義 Gitea 頁面和資源

Gitea 的可執行文件包含運行所需的所有資源:模板、圖像、樣式表和翻譯。可以通過將替換文件放置在 custom 目錄中的匹配路徑中來覆蓋其中的任何資源。例如,要替換為 C++ 存儲庫提供的默認 .gitignore,我們需要替換 options/gitignore/C++。為此,必須將替換文件放置在 $GITEA_CUSTOM/options/gitignore/C++ 中(請參閱本文檔頂部有關 CustomPath 目錄位置的說明)。

Gitea 的每個頁面都可以更改。動態內容是使用 go 模板 生成的,可以通過將替換文件放置在 $GITEA_CUSTOM/templates 目錄下來修改。

要獲取任何嵌入文件(包括模板),可以使用 gitea embedded 工具。或者,它們可以在 Gitea 源代碼的 templates 目錄中找到(注意:示例鏈接來自 main 分支。確保使用與您使用的版本兼容的模板)。

請注意,任何包含在 {{}} 之間的語句都是 Gitea 的模板語法,應在完全理解這些組件之前不要觸摸。

自定義起始頁/首頁

templates 為您的 Gitea 版本複製 home.tmpl$GITEA_CUSTOM/templates。 根據需要進行編輯。 不要忘記重啟您的 Gitea 以應用更改。

添加鏈接和標籤

如果您只想在頂部導航欄或頁腳中添加額外的鏈接,或在存儲庫視圖中添加額外的標籤,可以將它們放在 extra_links.tmpl(添加到導航欄的鏈接)、extra_links_footer.tmpl(添加到頁腳左側的鏈接)和 extra_tabs.tmpl 中,放置在您的 $GITEA_CUSTOM/templates/custom/ 目錄中。

例如,假設您在德國,必須添加著名的法律要求的“Impressum”/關於頁面,列出誰對網站內容負責: 只需將其放置在您的 "$GITEA_CUSTOM/public/assets/" 目錄下(例如 $GITEA_CUSTOM/public/assets/impressum.html),並將鏈接放置在 $GITEA_CUSTOM/templates/custom/extra_links.tmpl$GITEA_CUSTOM/templates/custom/extra_links_footer.tmpl 中。

為了匹配當前樣式,鏈接應具有類名“item”,您可以使用 {{AppSubUrl}} 獲取基本 URL: <a class="item" href="{{AppSubUrl}}/assets/impressum.html">Impressum</a>

有關更多信息,請參閱 添加法律頁面

您可以以相同的方式添加新標籤,將它們放在 extra_tabs.tmpl 中。 匹配其他標籤樣式所需的確切 HTML 位於文件 templates/repo/header.tmpl 中 (GitHub 中的源代碼

頁面的其他添加

除了 extra_links.tmplextra_tabs.tmpl,還有其他有用的模板,您可以將它們放在 $GITEA_CUSTOM/templates/custom/ 目錄中:

  • header.tmpl,在 <head> 標籤結束之前,您可以添加自定義 CSS 文件。
  • body_outer_pre.tmpl,在 <body> 開始之後。
  • body_inner_pre.tmpl,在頂部導航欄之前,但已經在主容器 <div class="full height"> 內。
  • body_inner_post.tmpl,在主容器結束之前。
  • body_outer_post.tmpl,在底部 <footer> 元素之前。
  • footer.tmpl,在 <body> 標籤結束之前,是添加 JavaScript 的好地方。

使用 Gitea 變量

可以在自定義模板中使用各種 Gitea 變量。

首先,臨時 啟用開發模式:在您的 app.ini 中將 RUN_MODE = prod 更改為 RUN_MODE = dev。然後將 {{ $ | DumpVar }} 添加到任何模板中,重啟 Gitea 並刷新該頁面;這將轉儲所有可用變量。

找到您需要的數據,並使用相應的變量;例如,如果您需要存儲庫的名稱,則可以使用 {{.Repository.Name}}

如果您需要以某種方式轉換這些數據,並且不熟悉 Go,一個簡單的解決方法是將數據添加到 DOM 並添加一個小的 JavaScript 腳本塊來操作數據。

示例:PlantUML

您可以使用 PlantUML 服務器將 PlantUML 支持添加到 Gitea 的 markdown 中。 數據被編碼並發送到 PlantUML 服務器,該服務器生成圖片。有一個在線演示服務器位於 http://www.plantuml.com/plantuml,但如果您(或您的用戶)有敏感數據,您可以設置自己的 PlantUML 服務器。要設置 PlantUML 渲染,從 https://gitea.com/davidsvantesson/plantuml-code-highlight 複製 JavaScript 文件並將它們放在您的 $GITEA_CUSTOM/public/assets/ 文件夾中。然後將以下內容添加到 custom/footer.tmpl

<script>
$(async () => {
if (!$(".language-plantuml").length) return;
await Promise.all([
$.getScript("https://your-gitea-server.com/assets/deflate.js"),
$.getScript("https://your-gitea-server.com/assets/encode.js"),
$.getScript(
"https://your-gitea-server.com/assets/plantuml_codeblock_parse.js"
),
]);
// 用您的 plantuml 服務器地址替換調用
parsePlantumlCodeBlocks("https://www.plantuml.com/plantuml");
});
</script>

然後您可以將以下塊添加到您的 markdown 中:

Alice -> Bob: Authentication Request
Bob --> Alice: Authentication Response

Alice -> Bob: Another authentication Request
Alice <-- Bob: Another authentication Response

該腳本將檢測帶有 class="language-plantuml" 的標籤,但您可以通過提供第二個參數給 parsePlantumlCodeBlocks 來更改此設置。

示例:STL 預覽

您可以通過添加以下內容直接在 Gitea 中顯示 STL 文件:

<script>
function lS(src) {
return new Promise(function (resolve, reject) {
let s = document.createElement("script");
s.src = src;
s.addEventListener("load", () => {
resolve();
});
document.body.appendChild(s);
});
}

if ($('.view-raw>a[href$=".stl" i]').length) {
$("body").append(
'<link href="/assets/Madeleine.js/src/css/Madeleine.css" rel="stylesheet">'
);
Promise.all([
lS("/assets/Madeleine.js/src/lib/stats.js"),
lS("/assets/Madeleine.js/src/lib/detector.js"),
lS("/assets/Madeleine.js/src/lib/three.min.js"),
lS("/assets/Madeleine.js/src/Madeleine.js"),
]).then(function () {
$(".view-raw")
.attr("id", "view-raw")
.attr("style", "padding: 0;margin-bottom: -10px;");
new Madeleine({
target: "view-raw",
data: $('.view-raw>a[href$=".stl" i]').attr("href"),
path: "/assets/Madeleine.js/src",
});
$('.view-raw>a[href$=".stl"]').remove();
});
}
</script>

到文件 templates/custom/footer.tmpl

您還需要下載庫 Madeleine.js 的內容並將其放置在 $GITEA_CUSTOM/public/assets/ 文件夾下。

您應該最終得到類似於以下結構的文件夾:

$GITEA_CUSTOM/templates
-- custom
`-- footer.tmpl

$GITEA_CUSTOM/public/assets/
-- Madeleine.js
|-- LICENSE
|-- README.md
|-- css
| |-- pygment_trac.css
| `-- stylesheet.css
|-- examples
| |-- ajax.html
| |-- index.html
| `-- upload.html
|-- images
| |-- bg_hr.png
| |-- blacktocat.png
| |-- icon_download.png
| `-- sprite_download.png
|-- models
| |-- dino2.stl
| |-- ducati.stl
| |-- gallardo.stl
| |-- lamp.stl
| |-- octocat.stl
| |-- skull.stl
| `-- treefrog.stl
`-- src
|-- Madeleine.js
|-- css
| `-- Madeleine.css
|-- icons
| |-- logo.png
| |-- madeleine.eot
| |-- madeleine.svg
| |-- madeleine.ttf
| `-- madeleine.woff
`-- lib
|-- MadeleineConverter.js
|-- MadeleineLoader.js
|-- detector.js
|-- stats.js
`-- three.min.js

然後重啟 Gitea 並在您的 Gitea 實例上打開 STL 文件。

自定義 Gitea 郵件

$GITEA_CUSTOM/templates/mail 文件夾允許更改 Gitea 的每封郵件的正文。 可以在 Gitea 源代碼的 templates/mail 目錄中找到要覆蓋的模板。 通過在 $GITEA_CUSTOM/templates/mail 下製作文件副本來覆蓋,使用與源相匹配的完整路徑結構。

任何包含在 {{}} 之間的語句都是 Gitea 的模板語法,應在完全理解這些組件之前不要觸摸。

向 Gitea 添加分析

可以向 Gitea 添加 Google Analytics、Matomo(以前稱為 Piwik)和其他分析服務。要添加跟踪代碼,請參閱本文檔的“頁面的其他添加”部分,並將 JavaScript 添加到 $GITEA_CUSTOM/templates/custom/header.tmpl 文件中。

自定義 gitignores、標籤、許可證、本地化和 readmes

將自定義文件放置在 custom/options 下的相應子文件夾中。

備註

文件不應具有文件擴展名,例如 Labels 而不是 Labels.txt

gitignores

要添加自定義 .gitignore,請將包含現有 .gitignore 規則 的文件添加到 $GITEA_CUSTOM/options/gitignore

自定義 git 配置

從 Gitea 1.20 開始,您可以通過 git.config 部分自定義 git 配置。

啟用簽名 git 推送

要啟用簽名 git 推送,請設置以下兩個選項:

[git.config]
receive.advertisePushOptions = true
receive.certNonceSeed = <randomstring>

certNonceSeed 應設置為隨機字符串並保持秘密。

標籤

從 Gitea 1.19 開始,您可以將遵循 YAML 標籤格式 的文件添加到 $GITEA_CUSTOM/options/label

labels:
- name: "foo/bar" # 在下拉列表中顯示的標籤名稱
exclusive: true # 是否使用專用命名空間進行範圍標籤。範圍分隔符為 /
color: aabbcc # 十六進制顏色編碼
description: Some label # 標籤意圖的長描述

仍然可以使用 [舊文件格式](https://github.com/go-gitea/gitea/blob/main/options