aboutsummaryrefslogtreecommitdiffstats
path: root/docs/content/doc/development/migrations.zh-cn.md
diff options
context:
space:
mode:
Diffstat (limited to 'docs/content/doc/development/migrations.zh-cn.md')
-rw-r--r--docs/content/doc/development/migrations.zh-cn.md40
1 files changed, 40 insertions, 0 deletions
diff --git a/docs/content/doc/development/migrations.zh-cn.md b/docs/content/doc/development/migrations.zh-cn.md
new file mode 100644
index 0000000000..8e3d73417d
--- /dev/null
+++ b/docs/content/doc/development/migrations.zh-cn.md
@@ -0,0 +1,40 @@
+---
+date: "2023-05-25T17:29:00+08:00"
+title: "迁移界面"
+slug: "migrations-interfaces"
+weight: 55
+toc: false
+draft: false
+aliases:
+ - /zh-cn/migrations-interfaces
+menu:
+ sidebar:
+ parent: "development"
+ name: "迁移界面"
+ weight: 55
+ identifier: "migrations-interfaces"
+---
+
+# 迁移功能
+
+完整迁移功能在Gitea 1.9.0版本中引入。它定义了两个接口,用于支持从其他Git托管平台迁移存储库数据到Gitea,或者在将来将Gitea数据迁移到其他Git托管平台。
+
+目前已实现了从GitHub、GitLab和其他Gitea实例的迁移。
+
+首先,Gitea在包[modules/migration](https://github.com/go-gitea/gitea/tree/main/modules/migration)中定义了一些标准对象。它们是`Repository`、`Milestone`、`Release`、`ReleaseAsset`、`Label`、`Issue`、`Comment`、`PullRequest`、`Reaction`、`Review`、`ReviewComment`。
+
+## 下载器接口
+
+要从新的Git托管平台迁移,需要进行两个步骤的更新。
+
+- 您应该实现一个`Downloader`,用于获取存储库信息。
+- 您应该实现一个`DownloaderFactory`,用于检测URL是否匹配,并创建上述的`Downloader`。
+ - 您需要在`init()`中通过`RegisterDownloaderFactory`注册`DownloaderFactory`。
+
+您可以在[downloader.go](https://github.com/go-gitea/gitea/blob/main/modules/migration/downloader.go)中找到这些接口。
+
+## 上传器接口
+
+目前,只实现了`GiteaLocalUploader`,因此我们只能通过此Uploader将下载的数据保存到本地的Gitea实例。目前不支持其他上传器。
+
+您可以在[uploader.go](https://github.com/go-gitea/gitea/blob/main/modules/migration/uploader.go)中找到这些接口。