跳至主要内容
版本:1.23.6

嵌入式數據提取工具

Gitea 的可執行文件包含運行所需的所有資源:模板、圖像、樣式表和翻譯。可以通過將替換文件放置在 custom 目錄中的匹配路徑中來覆蓋其中的任何資源(請參閱 自定義 Gitea)。

要獲取嵌入資源的副本以供編輯,可以從操作系統的 shell 界面使用 CLI 的 embedded 命令。

備註

嵌入式數據提取工具包含在 Gitea 1.12 及更高版本中。

列出資源

要列出嵌入在 Gitea 可執行文件中的資源,請使用以下語法:

gitea embedded list [--include-vendored] [patterns...]

--include-vendored 標誌使命令包括供應商文件,這些文件通常被排除在外;即,Gitea 所需的外部庫中的文件(例如 octicons 等)。

可以提供文件搜索模式列表。Gitea 使用 gobwas/glob 進行其 glob 語法。以下是一些示例:

  • 列出所有模板文件,在任何虛擬目錄中:**.tmpl
  • 列出所有郵件模板文件:templates/mail/**.tmpl
  • 列出 public/assets/img 內的所有文件:public/assets/img/**

不要忘記對模式使用引號,因為空格、* 和其他字符可能對您的命令 shell 有特殊含義。

如果未提供任何模式,則列出所有文件。

示例:列出所有嵌入文件

列出所有路徑中包含 openid 的嵌入文件:

$ gitea embedded list '**openid**'
public/assets/img/auth/openid_connect.svg
public/assets/img/openid-16x16.png
templates/user/auth/finalize_openid.tmpl
templates/user/auth/signin_openid.tmpl
templates/user/auth/signup_openid_connect.tmpl
templates/user/auth/signup_openid_navbar.tmpl
templates/user/auth/signup_openid_register.tmpl
templates/user/settings/security_openid.tmpl

提取資源

要提取嵌入在 Gitea 可執行文件中的資源,請使用以下語法:

gitea [--config {file}] embedded extract [--destination {dir}|--custom] [--overwrite|--rename] [--include-vendored] {patterns...}

--config 選項告訴 Gitea app.ini 配置文件的位置(如果它不在默認位置)。此選項僅與 --custom 標誌一起使用。

--destination 選項告訴 Gitea 文件必須提取到的目錄。默認是當前目錄。

--custom 標誌告訴 Gitea 將文件直接提取到 custom 目錄中。為了使其工作,命令需要知道 app.ini 配置文件的位置(--config),並且根據配置,從 Gitea 通常啟動的目錄運行。詳情請參閱 自定義 Gitea

--overwrite 標誌允許覆蓋目標目錄中的任何現有文件。

--rename 標誌告訴 Gitea 將目標目錄中的任何現有文件重命名為 filename.bak。以前的 .bak 文件將被覆蓋。

必須提供至少一個文件搜索模式;請參閱上面的 list 子命令以了解模式語法和示例。

重要通知

確保僅提取那些需要自定義的文件custom 目錄中存在的文件不會被 Gitea 的升級過程升級。當 Gitea 升級到新版本(通過替換可執行文件)時,許多嵌入文件將發生變化。Gitea 將尊重並使用 custom 目錄中找到的任何文件,即使它們是舊的且不兼容。

示例:提取郵件模板

將郵件模板提取到臨時目錄:

$ mkdir tempdir
$ gitea embedded extract --destination tempdir 'templates/mail/**.tmpl'
Extracting to tempdir:
tempdir/templates/mail/auth/activate.tmpl
tempdir/templates/mail/auth/activate_email.tmpl
tempdir/templates/mail/auth/register_notify.tmpl
tempdir/templates/mail/auth/reset_passwd.tmpl
tempdir/templates/mail/issue/assigned.tmpl
tempdir/templates/mail/issue/default.tmpl
tempdir/templates/mail/notify/collaborator.tmpl