【Gitea】配置 Push To Create

在 Git 代码管理工具使用过程中,经常需要将一个文件夹作为仓库上传到一个未创建的代码仓库。如果 Git 服务端使用的是 Gitea,通常会推送失败。

shell 复制代码
PS D:\tmp\git-test> git remote add origin http://192.1.1.1:3000/root/git-test.git
PS D:\tmp\git-test> git push --set-upstream origin master
remote: Push to create is not enabled for users.
fatal: unable to access 'http://192.1.1.1:3000/root/git-test.git/': The requested URL returned error: 403

因为 Gitea 默认推送时不创建仓库。

开启 Push To Create

Push To Create即推送创建 , Gitea 提供了两个参数开启推送创建 ,分别是 ENABLE_PUSH_CREATE_USERENABLE_PUSH_CREATE_ORG 。[官方文档介绍](推送 | Gitea Documentation)如下:

推送创建

推送创建是一项功能,允许您将提交推送到在 Gitea 中尚不存在的仓库。这对于自动化和允许用户创建仓库而无需通过 Web 界面非常有用。此功能默认处于禁用状态。

开启推送创建

app.ini 文件中,将 ENABLE_PUSH_CREATE_USER 设置为 true,如果您希望允许用户在自己的用户帐户和所属的组织中创建仓库,将 ENABLE_PUSH_CREATE_ORG 设置为 true。重新启动 Gitea 以使更改生效。您可以在 配置速查表 中了解有关这两个选项的更多信息。

使用推送创建

假设您在当前目录中有一个 git 仓库,您可以通过运行以下命令将提交推送到在 Gitea 中尚不存在的仓库:

shell 复制代码
# 添加要推送到的远程仓库
git remote add origin git@{domain}:{username}/{尚不存在的仓库名称}.git

# 推送到远程仓库
git push -u origin main

这假设您使用的是 SSH 远程,但您也可以使用 HTTPS 远程。

推送创建将默认使用 app.ini 中定义的可见性 DEFAULT_PUSH_CREATE_PRIVATE

具体配置

以上官方章节说明了 Gitea 可以通过配置开启推送创建功能,也给出了两个具体的配置项,但打开开 app.ini (docker 容器启动实例中文件位置为: /data/gitea/conf/app.ini)文件后,你会发现不知道在哪里配置。

因为Gitea有很多功能域,以上文章并没有交代开启推送创建的功能项属于哪个功能域。

配置说明 | Gitea Documentation文档中详细阐述了 Gitea 所有配置项,并且说明了配置项所属的功能域。

通过查看,ENABLE_PUSH_CREATE_USERENABLE_PUSH_CREATE_RRG 都属于 [repository] 功能域。因此配置如下:

重启

配置完成后重启 Gitea 即可。

附 : Win 下 Docker 安装 Gitea 实践-CSDN博客

相关推荐
**蓝桉**20 小时前
prometheus监控nginx
nginx·elasticsearch·prometheus
光影少年20 小时前
说说模块化规范?CommonJS和ES Module的区别?
前端·javascript·elasticsearch
七夜zippoe20 小时前
Elasticsearch全文搜索与数据分析实战指南
大数据·python·elasticsearch·数据分析·全文搜索
Elasticsearch1 天前
AI agent 记忆:使用 Elasticsearch 托管记忆创建智能代理
elasticsearch
三水不滴1 天前
Elasticsearch 实战系列(一):从核心基础概念入门到实战落地
后端·elasticsearch
三水不滴1 天前
Elasticsearch 生产环境全栈最佳实践:从架构设计到故障排查一站式落地指南
后端·elasticsearch·搜索引擎
深念Y1 天前
Elasticsearch 8.11 + IK 分词器安装踩坑记录
大数据·数据库·elasticsearch·中文分词·jenkins·ki分词器
weixin_448119941 天前
Datawhale Obsidian智能体 202603作业1
大数据·elasticsearch·搜索引擎
margu_1681 天前
【Elasticsearch】es7.2 跨集群迁移少量数据
elasticsearch
秋知叶i1 天前
【git命令】Git 删除远程分支保姆级教程(含缓存清理 + 本地残留绝杀)
git·elasticsearch·缓存