8f9494c3c0 | ||
---|---|---|
app | ||
bin | ||
config | ||
db | ||
lib | ||
public | ||
spec | ||
test | ||
tmp | ||
vendor | ||
warn | ||
.gitignore | ||
.merge_file_a17580 | ||
Gemfile | ||
Gemfile.lock | ||
LICENSE | ||
README.md | ||
Rakefile | ||
bootstrap-datetimepicker.css | ||
config.ru | ||
docker-compose.yml | ||
dump.rdb |
README.md
本地开发部署步骤
1. 安装依赖包
bundle install
2. 配置初始化文件
进入项目根目录执行一下命令:
cp config/configuration.yml.example config/configuration.yml
cp config/database.yml.example config/database.yml
touch config/redis.yml
touch config/elasticsearch.yml
3. 创建数据库
rails db:create
4. 导入数据表结构
bundle exec rake sync_table_structure:import_csv
5. 执行migrate迁移文件
rails db:migrate RAILS_ENV=development
6. 启动rails服务
rails s
7. 浏览器访问
在浏览器中输入如下地址访问:
http://localhost:3000/projects
API文档
基本介绍
开发API服务地址:
https://testgitea.trustie.net/
响应状态说明:
字段 | 类型 | 说明 |
---|---|---|
status | int | 响应状态码,0:请求成功,-1: 请求失败 |
message | string | 响应说明 |
API接口
用户注册(通过其他平台)
POST accounts/remote_register
示例
curl -X POST \
-d "email=2456233122@qq.com" \
-d "password=djs_D_00001" \
-d "username=16895620" \
-d "platform=forge" \
http://localhost:3000/api/accounts/remote_register | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
是 | string | 邮箱 | |
username | 是 | string | 登录名 |
password | 是 | string | 秘密 |
platform | 否 | string | 用户来源的相关平台,取值范围['educoder', 'trustie', 'forge'], 默认值为forge |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
user | json object | 返回数据 |
-- id | int | 用户id |
-- token | string | 用户token |
返回值
{
"status": 0,
"message": "success",
"user": {
"id": 36400,
"token": "8c87a80d9cfacc92fcb2451845104f35119eda96"
}
}
获取当前登录用户信息
GET api/users/me
示例
curl -X GET http://localhost:3000/api/users/me | jq
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
user_id | int | 用户id |
username | string | 用户名称 |
admin | boolean | 是否为管理用户 |
login | string | 登录名 |
image_url | string | 用户头像 |
返回值
{
"username": "18816895620",
"login": "18816895620",
"user_id": 36401,
"image_url": "avatars/User/b",
"admin": false
}
用户列表(带搜索功能)
GET api/users/list
示例
curl -X GET \
-d "limit=10" \
-d "search=18816895620"
http://localhost:3000/api/users/list | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
page | 否 | int | 页数,第几页 |
limit | 否 | int | 每页多少条数据,默认15条 |
search | 否 | string | 用户名、登录名匹配搜索 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
total_count | int | 总用户条数 |
users | array | |
-- username | string | 用户全名 |
-- login | string | 用户登录名 |
-- user_id | int | 用户id |
-- image_url | string | 用户头像 |
返回值
{
"total_count": 1,
"users": [
{
"username": "18816895620",
"login": "18816895620",
"user_id": 36401,
"image_url": "avatars/User/b"
}
]
}
获取项目类别列表(可根据名称搜素)
GET api/project_categories
示例
curl -X GET \
-d "name=大数据" \
http://localhost:3000/api/project_categories/ | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
name | 否 | string | 类别名称 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
project_categories | array | 返回数据 |
-- id | int | 类别id |
-- name | string | 类别名称 |
返回值
{
"project_categories": [
{
"id": 1,
"name": "大数据"
}
]
}
获取项目语言列表(可根据名称搜素)
GET api/project_languages
示例
curl -X GET \
-d "name=Ruby" \
http://localhost:3000/api/project_languages/ | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
name | 否 | string | 类别名称 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
project_languages | array | 返回数据 |
-- id | int | 语言id |
-- name | string | 语言名称 |
返回值
{
"project_languages": [
{
"id": 1,
"name": "Ruby"
}
]
}
获取.gitignore模板列表(可根据名称搜素)
GET api/ignores
示例
curl -X GET \
-d "name=Ada" \
http://localhost:3000/api/ignores/ | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
name | 否 | string | gitignore名称 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
ignores | array | 返回数据 |
-- id | int | id |
-- name | string | gitignore名称 |
返回值
{
"ignores": [
{
"id": 1,
"name": "Ada"
}
]
}
获取开源许可证列表(可根据名称搜素)
GET api/licenses
示例
curl -X GET \
-d "name=AFL" \
http://localhost:3000/api/licenses/ | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
name | 否 | string | 开源许可证名称 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
licenses | array | 返回数据 |
-- id | int | id |
-- name | string | 开源许可证名称 |
返回值
{
"licenses": [
{
"id": 57,
"name": "AFL-1.2"
},
{
"id": 76,
"name": "AFL-3.0"
},
{
"id": 214,
"name": "AFL-1.1"
},
{
"id": 326,
"name": "AFL-2.1"
},
{
"id": 350,
"name": "AFL-2.0"
}
]
}
创建项目
POST api/projects
示例
curl -X POST \
-d "user_id=36401" \
-d "name=hnfl_demo" \
-d "description=my first project" \
-d "repository_name=hnfl_demo" \
-d "project_category_id=1" \
-d "project_language_id=2" \
-d "ignore_id=2" \
-d "license_id=1" \
http://localhost:3000/api/projects/ | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
user_id | 是 | int | 用户id或者组织id |
name | 是 | string | 项目名称 |
description | 是 | string | 项目描述 |
repository_name | 是 | string | 仓库名称, 只含有数字、字母、下划线不能以下划线开头和结尾,且唯一 |
project_category_id | 是 | int | 项目类别id |
project_language_id | 是 | int | 项目语言id |
ignore_id | 否 | int | gitignore相关id |
license_id | 否 | int | 开源许可证id |
private | 否 | boolean | 项目是否私有, true:为私有,false: 公开,默认为公开 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
id | int | id |
name | string | 项目名称 |
返回值
{
"id": 3240,
"name": "好项目"
}
新建镜像项目
POST api/projects/migrate
示例
curl -X POST \
-d "user_id=36401" \
-d "clone_addr=https://gitea.com/mx8090alex/golden.git" \
-d "name=golden" \
-d "description=golden" \
-d "repository_name=golden" \
-d "project_category_id=1" \
-d "project_language_id=2" \
http://localhost:3000/api/projects/migrate | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
user_id | 是 | int | 用户id或者组织id |
name | 是 | string | 项目名称 |
clone_addr | 是 | string | 镜像项目clone地址 |
description | 否 | string | 项目描述 |
repository_name | 是 | string | 仓库名称, 只含有数字、字母、下划线不能以下划线开头和结尾,且唯一 |
project_category_id | 是 | int | 项目类别id |
project_language_id | 是 | int | 项目语言id |
private | 否 | boolean | 项目是否私有, true:为私有,false: 非私有,默认为公开 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
id | int | id |
name | string | 项目名称 |
返回值
{
"id": 3263,
"name": "ni项目"
}
项目详情
GET api/projects/:id
示例
curl -X GET http://localhost:3000/api/projects/3263 | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
id | int | id |
name | string | 项目名称 |
identifier | string | 项目标识 |
is_public | boolean | 项目是否公开, true:公开,false:私有 |
description | string | 项目简介 |
repo_id | int | 仓库id |
repo_identifier | string | 仓库标识 |
返回值
{
"name": "ni项目",
"identifier": "mirror_demo",
"is_public": true,
"description": "my first project mirror_demo",
"repo_id": 75073,
"repo_identifier": "mirror_demo"
}
编辑仓库信息
GET /api/:login/:repo_identifier/edit.json
示例
curl -X GET http://localhost:3000/api/18816895620/mirror_demo/edit.json | jq
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
identifier | string | 仓库标识 |
project_id | int | 项目id |
project_name | string | 项目名称 |
project_identifier | string | 项目标识 |
project_description | string | 项目简介 |
project_category_id | int | 项目类别id |
project_language_id | int | 项目语言id |
private | boolean | 项目是否私有, true:为私有,false: 公开 |
返回值
{
"identifier": "mirror_demo",
"project_id": 3263,
"project_name": "ni项目",
"project_identifier": "mirror_demo",
"project_description": "my first project mirror_demo",
"project_category_id": 1,
"project_language_id": 2,
"private": false
}
修改项目信息
PATCH api/projects/:id
示例
curl -X PATCH \
-d "name=hnfl_demo" \
-d "description=my first project" \
-d "project_category_id=1" \
-d "project_language_id=2" \
-d "private=true" \
http://localhost:3000/api/projects/3263.json | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
name | 否 | string | 项目名称 |
description | 否 | string | 项目描述 |
project_category_id | 否 | int | 项目类别id |
project_language_id | 否 | int | 项目语言id |
private | 否 | boolean | 项目是否私有, true:为私有,false: 公开,默认为公开 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
id | int | id |
identifier | string | 项目标识 |
name | string | 项目名称 |
description | string | 项目简介 |
project_category_id | int | 项目类别id |
project_language_id | int | 项目语言id |
private | 否 | boolean |
返回值
{
"id": 3263,
"identifier": "mirror_demo",
"name": "hnfl_demo",
"description": "my first project",
"project_category_id": 1,
"project_language_id": 2,
"is_public": true
}
删除项目
DELETE api/projects/:id
示例
curl -X DELETE http://localhost:3000/api/projects/3263.json | jq
注:只有超级管理员和项目拥有者才能删除仓库
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 返回状态, 0: 表示操作成功 |
message | string | 返回信息说明 |
返回值
{
"status": 0,
"message": "success"
}
项目添加成员
POST api/projects/:id/members
示例
curl -X POST \
-d "user_id=36406" \
http://localhost:3000/api/projects/3297/members | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
user_id | 是 | int | 用户id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 0:添加成功, -1: 添加失败, 1: 表示已经是项目成员 |
message | string | 返回信息说明 |
返回值
{
"status": 0,
"message": "success"
}
项目删除成员
DELETE api/projects/:id/members/remove
示例
curl -X DELETE \
-d "user_id=36400" \
http://localhost:3000/api/projects/3263/members/remove | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
user_id | 是 | int | 用户id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 0:移除成功, -1: 移除失败, 1: 表示还不是项目成员 |
message | string | 返回信息说明 |
返回值
{
"status": 0,
"message": "success"
}
更改项目成员角色/权限
PUT api/projects/:id/members/change_role
示例
curl -X PUT \
-d "user_id=36400" \
-d "role=Developer" \
http://localhost:3000/api/projects/3263/members/change_role | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
user_id | 是 | int | 用户id |
role | 是 | string | 取值范围:"Manager", "Developer", "Reporter";分别为项目管理人员(拥有所有操作权限)、项目开发人员(只拥有读写权限)、项目报告人员(只拥有读权限) |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 0:角色更改成功, -1: 更改失败失败, 1: 表示还不是项目成员 |
message | string | 返回信息说明 |
返回值
{
"status": 0,
"message": "success"
}
项目成员列表
GET api/projects/:id/members
示例
curl -X GET \
-d "page=1" \
-d "limit=5" \
http://localhost:3000/api/projects/3263/members | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
page | 否 | string | 页数,第几页 |
limit | 否 | string | 每页多少条数据,默认15条 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
total_count | int | 返回记录总条数 |
members | array | 项目成员信息 |
-- id | int | 用户id |
-- name | string | 用户名称 |
-- login | string | 用户登录名/标识 |
-- image_url | string | 用户头像 |
-- is_owner | boolean | 是否是项目的拥有者,true:是, false:不是 |
-- role | string | 该用户在项目中的角色, Manager: 管理员(拥有操作权限); Developer:开发人员(只拥有读写权限); Reporter:报告人员(只拥有读权限) |
返回值
{
"total_count": 2,
"members": [
{
"id": 36401,
"name": "18816895620",
"login": "18816895620",
"image_url": "avatars/User/b",
"is_owner": true,
"role": "Manager"
},
{
"id": 36399,
"name": "18816365620",
"login": "18816365620",
"image_url": "avatars/User/b",
"is_owner": false,
"role": "Developer"
}
]
}
Fork项目
POST /api/projects/:project_id/forks
示例
curl -X POST http://localhost:3000/api/projects/3297/forks | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
project_id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
id | int | 项目id |
identifier | string | 项目标识 |
返回值
{
"id": 3290,
"identifier": "newadm"
}
获取代码目录列表
POST api/:login/:repo_identifier/entries
示例
curl -X GET \
-d "ref=develop" \
http://localhost:3000/api/18816895620/mirror_demo/entries | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
login | 是 | string | 用户标识(login) |
repo_identifier | 是 | string | 仓库标识(identifier) |
ref | 否 | string | 分支名称、tag名称或是提交记录id,默认为master分支 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
id | int | id |
name | string | 文件夹或文件名称 |
path | string | 文件夹或文件相对路径 |
type | string | 文件类型, file:文件,dir:文件目录 |
size | int | 文件夹或文件大小 单位B |
content | string | 文件内容, |
target | string | 标签 |
返回值
[
{
"name": "Manual",
"path": "Manual",
"sha": "c2f18765235076b4c835b3e31262b3ee65176a75",
"type": "file",
"size": 12579,
"content": null,
"target": null,
"commit": null
},
{
"name": "README",
"path": "README",
"sha": "91a29176828eba5c5598f5d4a95458e861f271ec",
"type": "file",
"size": 1767,
"content": null,
"target": null,
"commit": null
},
{
"name": "base",
"path": "base",
"sha": "7adbe5698e02dba062216333d5e1d16b36ae1cbd",
"type": "dir",
"size": 0,
"content": null,
"target": null,
"commit": null
}
]
获取子目录代码列表/编辑某个具体的文件
GET api/:login/:repo_identifier/sub_entries
示例
curl -X GET \
-d "ref=master" \
-d "filepath=test1_create_file.rb" \
http://localhost:3000/api/18816895620/mirror_demo/sub_entries | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
login | 是 | string | 用户标识(login) |
repo_identifier | 是 | string | 仓库标识(identifier) |
filepath | 是 | string | 文件夹、文件的相对路径 |
ref | 否 | string | 分支名称、tag名称或是提交记录id,默认为master分支 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
id | int | id |
name | string | 文件夹或文件名称 |
path | string | 文件夹或文件相对路径 |
type | string | 文件类型, file:文件,dir:文件目录 |
size | int | 文件夹或文件大小 单位KB |
content | string | 文件内容, |
target | string | 标签 |
url | string | 文件访问链接,带分支 |
html_url | string | 文件访问链接,未标识分支 |
git_url | string | 文件夹或文件的git仓库访问链接 |
download_url | string | 文件下载、文件内容访问链接 |
返回值
[
{
"name": "build.rc",
"path": "lib/build.rc",
"type": "",
"size": 1268,
"content": null,
"target": null,
"url": "http://localhost:3003/api/v1/repos/18816895620/mirror_demo/contents/lib/build.rc?ref=master",
"html_url": "http://localhost:3003/18816895620/mirror_demo/src/branch/master/lib/build.rc",
"git_url": "http://localhost:3003/api/v1/repos/18816895620/mirror_demo/git/blobs/191fcf1a63b3777e2977fcede7dd5309efdd70fe",
"download_url": null
},
{
"name": "cfg.rc",
"path": "lib/cfg.rc",
"type": "file",
"size": 107,
"content": null,
"target": null,
"url": "http://localhost:3003/api/v1/repos/18816895620/mirror_demo/contents/lib/cfg.rc?ref=master",
"html_url": "http://localhost:3003/18816895620/mirror_demo/src/branch/master/lib/cfg.rc",
"git_url": "http://localhost:3003/api/v1/repos/18816895620/mirror_demo/git/blobs/0b91ba0ed1c00e130c77bb9058af3787fea986a0",
"download_url": "http://localhost:3003/18816895620/mirror_demo/raw/branch/master/lib/cfg.rc"
},
{
"name": "fn",
"path": "lib/fn",
"type": "dir",
"size": 0,
"content": null,
"target": null,
"url": "http://localhost:3003/api/v1/repos/18816895620/mirror_demo/contents/lib/fn?ref=master",
"html_url": "http://localhost:3003/18816895620/mirror_demo/src/branch/master/lib/fn",
"git_url": "http://localhost:3003/api/v1/repos/18816895620/mirror_demo/git/blobs/e33bd45949ef8f804471d0b6b2c59728eb445989",
"download_url": null
}
]
项目类别列表(用于项目列表左侧导航中的项目类别列表)
GET api/project_categories/group_list
示例
curl -X GET http://localhost:3000/api/project_categories/group_list | jq
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
id | int | 项目分类id |
name | string | 项目分类名称 |
projects_count | int | 项目数量 |
返回值
[
{
"id": 1,
"name": "大数据",
"projects_count": 30
},
{
"id": 2,
"name": "机器学习",
"projects_count": 1
},
{
"id": 3,
"name": "深度学习",
"projects_count": 1
}
]
项目类型列表(用于项目列表左侧导航上方中的项目类型列表)
GET api/projects/group_type_list
示例
curl -X GET http://localhost:3000/api/projects/group_type_list | jq
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
project_type | string | 项目类型 |
name | string | 项目类型名称 |
projects_count | int | 项目数量 |
返回值
[
{
"project_type": "common",
"name": "开源托管项目",
"projects_count": 2106
},
{
"project_type": "mirror",
"name": "开源镜像项目",
"projects_count": 1
}
]
项目列表
GET api/projects
示例
curl -X GET \
-d "page=1" \
-d "limit=5" \
http://localhost:3000/api/projects | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
page | 否 | string | 页数,第几页 |
limit | 否 | string | 每页多少条数据,默认15条 |
sort_by | 否 | string | 排序类型, 取值:updated_on | created_on | forked_count | praises_count, updated_on: 更新时间排序,created_on: 创建时间排序,forked_count: fork数据排序,praises_count: 点赞数量排序,默认为updated_on更新时间排序 |
sort_direction | 否 | string | 排序方式,取值为: desc | asc; desc: 降序排序, asc: 升序排序, 默认为:desc |
search | 否 | string | 按照项目名称搜索 |
category_id | 否 | int | 项目类别id |
language_id | 否 | int | 项目语言id |
project_type | 否 | string | 项目类型, 取值为:common | mirror; common:开源托管项目, mirror:开源镜像项目 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
total_count | int | 项目总条数 |
id | string | 项目id |
name | string | 项目名称 |
description | string | 项目简介 |
visits | int | 流量数 |
forked_count | int | 被fork的数量 |
praises_count | int | star数量 |
is_public | boolean | 是否公开, true:公开,false:未公开 |
mirror_url | string | 镜像url |
last_update_time | int | 最后更新时间,为UNIX格式的时间戳 |
author | object | 项目创建者 |
-- name | string | 用户名,也是用户标识 |
category | object | 项目类别 |
-- id | int | 项目类型id |
-- name | string | 项目类型名称 |
language | object | 项目语言 |
-- id | int | 项目语言id |
-- name | string | 项目语言名称 |
返回值
{
"total_count": 3096,
"projects": [
{
"id": 1,
"name": "hnfl_demo1",
"description": "my first project",
"visits": 0,
"praises_count": 0,
"forked_count": 0,
"is_public": true,
"mirror_url": null,
"last_update_time": 1577697461,
"author": {
"name": "18816895620",
"image_url": "avatars/User/b"
},
"category": {
"id": 1,
"name": "大数据"
},
"language": {
"id": 2,
"name": "C"
}
},
{
"id": 2,
"name": "hnfl_demo",
"description": "my first project",
"visits": 0,
"praises_count": 0,
"forked_count": 0,
"is_public": true,
"mirror_url": null,
"last_update_time": 1577697403,
"author": {
"name": "18816895620",
"image_url": "avatars/User/b"
},
"category": {
"id": 1,
"name": "大数据"
},
"language": {
"id": 2,
"name": "C"
}
},
{
"id": 3,
"name": "统计局",
"description": "my first project",
"visits": 0,
"praises_count": 0,
"forked_count": 0,
"is_public": true,
"mirror_url": null,
"last_update_time": 1577415173,
"author": {
"name": "18816895620",
"image_url": "avatars/User/b"
},
"category": {
"id": 1,
"name": "大数据"
},
"language": {
"id": 2,
"name": "C"
}
},
{
"id": 5,
"name": "开源同名",
"description": "my first project",
"visits": 0,
"praises_count": 0,
"forked_count": 0,
"is_public": false,
"mirror_url": "https://gitea.com/CasperVector/slew.git",
"last_update_time": 1577346228,
"author": {
"name": "18816895620",
"image_url": "avatars/User/b"
},
"category": {
"id": 1,
"name": "大数据"
},
"language": {
"id": 2,
"name": "C"
}
},
{
"id": 7,
"name": "开源支持",
"description": "my first project",
"visits": 0,
"praises_count": 0,
"forked_count": 0,
"is_public": true,
"mirror_url": null,
"last_update_time": 1577341572,
"author": {
"name": "18816895620",
"image_url": "avatars/User/b"
},
"category": {
"id": 1,
"name": "大数据"
},
"language": {
"id": 2,
"name": "C"
}
}
]
}
获取分支列表
GET /api/projects/:identifier/branches
示例
curl -X GET http://localhost:3000/api/projects/mirror_demo/branches | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
identifier | 是 | string | 项目标识 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
name | string | 分支名称 |
user_can_push | boolean | 用户是否可push |
user_can_merge | boolean | 用户是否客merge |
protected | boolean | 是否为保护分支 |
http_url | boolean | http链接 |
zip_url | boolean | zip包下载链接 |
tar_url | boolean | tar.gz下载链接 |
last_commit | object | 最后提交记录 |
-- id | string | 提交记录id |
-- message | string | 提交的说明信息 |
-- timestamp | int | 提交时间,为UNIX时间戳 |
-- time_from_now | string | 转换后的时间 |
author | object | 提交用户 |
-- login | string | 用户名称 |
-- image_url | string | 用户头像 |
返回值
[
{
"name": "develop",
"user_can_push": true,
"user_can_merge": true,
"protected": false,
"http_url": "http://localhost:3003/18816895620/mirror_demo.git",
"zip_url": "http://localhost:3003/18816895620/mirror_demo/develop.zip",
"tar_url": "http://localhost:3003/18816895620/mirror_demo/develop.tar.gz",
"last_commit": {
"id": "735674d6696bddbafa993db9c67b40c41246c77f",
"message": "FIX test branch content\n",
"timestamp": 1577694074,
"time_from_now": "1天前"
},
"author": {
"login": "18816895620",
"image_url": "avatars/User/b"
}
},
{
"name": "master",
"user_can_push": true,
"user_can_merge": true,
"protected": false,
"http_url": "http://localhost:3003/18816895620/mirror_demo.git",
"zip_url": "http://localhost:3003/18816895620/mirror_demo/master.zip",
"tar_url": "http://localhost:3003/18816895620/mirror_demo/master.tar.gz",
"last_commit": {
"id": "19ac3bc45f62cc87a94b8ecce61101d8fd2dafd2",
"message": "合并pull request测试\n\n该功能很不错,感谢你的建议\n",
"timestamp": 1577244567,
"time_from_now": "6天前"
},
"author": {
"login": "18816895620",
"image_url": "avatars/User/b"
}
}
]
获取版本列表
GET /api/:login/:repo_identifier/tags
示例
curl -X GET http://localhost:3000/api/18816895620/mirror_demo/tags | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
identifier | 是 | string | 项目标识 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
name | string | 分支名称 |
user_can_push | boolean | 用户是否可push |
user_can_merge | boolean | 用户是否客merge |
protected | boolean | 是否为保护分支 |
http_url | boolean | http链接 |
zip_url | boolean | zip包下载链接 |
tar_url | boolean | tar.gz下载链接 |
last_commit | object | 最后提交记录 |
-- id | string | 提交记录id |
-- message | string | 提交的说明信息 |
-- timestamp | int | 提交时间,为UNIX时间戳 |
-- time_from_now | string | 转换后的时间 |
author | object | 提交用户 |
-- login | string | 用户名称 |
-- image_url | string | 用户头像 |
返回值
[
{
"name": "develop",
"user_can_push": true,
"user_can_merge": true,
"protected": false,
"http_url": "http://localhost:3003/18816895620/mirror_demo.git",
"zip_url": "http://localhost:3003/18816895620/mirror_demo/develop.zip",
"tar_url": "http://localhost:3003/18816895620/mirror_demo/develop.tar.gz",
"last_commit": {
"id": "735674d6696bddbafa993db9c67b40c41246c77f",
"message": "FIX test branch content\n",
"timestamp": 1577694074,
"time_from_now": "1天前"
},
"author": {
"login": "18816895620",
"image_url": "avatars/User/b"
}
},
{
"name": "master",
"user_can_push": true,
"user_can_merge": true,
"protected": false,
"http_url": "http://localhost:3003/18816895620/mirror_demo.git",
"zip_url": "http://localhost:3003/18816895620/mirror_demo/master.zip",
"tar_url": "http://localhost:3003/18816895620/mirror_demo/master.tar.gz",
"last_commit": {
"id": "19ac3bc45f62cc87a94b8ecce61101d8fd2dafd2",
"message": "合并pull request测试\n\n该功能很不错,感谢你的建议\n",
"timestamp": 1577244567,
"time_from_now": "6天前"
},
"author": {
"login": "18816895620",
"image_url": "avatars/User/b"
}
}
]
仓库详情
GET /api/:login/:repo_identifier/
示例
curl -X GET \
http://localhost:3000/api/18816895620/mirror_demo | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
login | 是 | string | 用户标识 |
repo_identifier | 是 | string | 仓库标识 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
identifier | string | 仓库标识 |
project_id | int | 项目id |
project_identifier | string | 项目标识 |
praises_count | int | 点赞数量 |
forked_count | int | fork数量 |
watchers_count | int | 关注数量 |
branches_count | int | 分支数量 |
commits_count | int | 总提交记录数量 |
issues_count | int | 总提交记录数量 |
pull_requests_count | int | 总提交记录数量 |
praised | boolean | 当前登录用户是否已点赞,true:已点赞,fasle:未点赞, 用户未登录状态为null |
watched | boolean | 当前登录用户是否已关注,true:已关注,fasle:未关注, 用户未登录状态为null |
permission | string | 当前登录用户对该仓库的操作权限, Manager:管理员,可以在线编辑文件、在线新建文件、可以设置仓库的基本信息; Developer:开发人员,可在线编辑文件、在线新建文件、不能设置仓库信息; Reporter: 报告人员,只能查看信息,不能设置仓库信息、不能在线编辑文件、不能在线新建文件;用户未登录时也会返回Reporter, 说明也只有读取文件的权限 |
size | int | 仓库文件大小,单位:KB |
mirror_url | string | 镜像地址, 只有通过镜像过来的项目才会有这个地址 |
ssh_url | string | 仓库ssh地址 |
clone_url | string | 仓库克隆地址 |
empty | boolean | 仓库是否为空,true: 空仓库;false: 非空仓库 |
private | boolean | 仓库是否私有,true: 私有仓库;fasle: 非私有的 |
default_branch | string | 仓库默认分支 |
full_name | string | 仓库全名(带用户名) |
author | object | 提交用户 |
-- login | string | 用户login |
-- name | string | 用户姓名 |
-- image_url | string | 用户头像 |
返回值
{
"identifier": "mirror_demo",
"project_id": 3263,
"project_identifier": "mirror_demo",
"praises_count": 1,
"forked_count": 0,
"watchers_count": 1,
"branches_count": 6,
"commits_count": 107,
"issues_count": 0,
"pull_requests_count": 0,
"permission": "Manager",
"mirror_url": "https://gitea.com/CasperVector/slew.git",
"watched": true,
"praised": true,
"size": 446,
"ssh_url": "jasder@localhost:18816895620/mirror_demo.git",
"clone_url": "http://localhost:3003/18816895620/mirror_demo.git",
"default_branch": "master",
"empty": false,
"full_name": "18816895620/mirror_demo",
"mirror": false,
"private": false,
"author": {
"login": "18816895620",
"name": "美女",
"image_url": "avatars/User/b"
}
}
获取提交记录列表
GET /api/:login/:repo_identifier/commits
示例
curl -X GET \
-d "sha=develop" \
-d "page=1" \
http://localhost:3000/api/18816895620/mirror_demo/commits | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
login | 是 | string | 用户标识 |
repo_identifier | 是 | string | 仓库标识 |
sha | 否 | string | 分支名称、提交记录的sha标识,默认为master分支 |
page | 否 | int | 页数, 默认为1 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
total_count | int | 总记录条数 |
commits | array | 提交记录的数组 |
-- sha | string | 提交记录sha标识 |
-- message | string | 提交的备注说明 |
-- timestamp | int | 提交UNIX时间戳 |
-- time_from_now | string | 提交距离当前的时间 |
author | object | 提交用户 |
-- login | string | 用户名称 |
-- image_url | string | 用户头像 |
返回值
{
"total_count": 63,
"commits": [
{
"sha": "19ac3bc45f62cc87a94b8ecce61101d8fd2dafd2",
"message": "合并pull request测试",
"timestamp": 1577244567,
"time_from_now": "7天前",
"author": {
"name": "18816895620",
"image_url": "avatars/User/b"
}
},
{
"sha": "2b33c5f55214db41879936312ee43611406c4dbd",
"message": "FIX .",
"timestamp": 1577244474,
"time_from_now": "7天前",
"author": {
"name": "18816895620",
"image_url": "avatars/User/b"
}
}
]
}
点赞
POST /api/projects/:id/praise_tread/like
示例
curl -X POST http://localhost:3000/api/projects/3263/praise_tread/like | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 0:点赞成功,-1:操作失败,2:表示已经点过赞了 |
返回值
{
"status": 0,
"message": "success"
}
取消点赞
DELETE /api/projects/:id/praise_tread/unlike
示例
curl -X DELETE http://localhost:3000/api/projects/3263/praise_tread/unlike | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 0:点赞成功,-1:操作失败,2:表示还未点赞 |
返回值
{
"status": 0,
"message": "success"
}
用户是否点过赞
GET /api/projects/:id/praise_tread/check_like
示例
curl -X GET http://localhost:3000/api/projects/3263/praise_tread/check_like | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 1:已点过赞,0:未点过赞, -1:请求操作失败 |
返回值
{
"status": 0,
"message": "success"
}
项目的点赞者列表
GET /api/projects/:id/praise_tread
示例
curl -X GET \
-d "page=1" \
-d "limit=5" \
http://localhost:3000/api/projects/3263/praise_tread | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
page | 否 | string | 页数,第几页 |
limit | 否 | string | 每页多少条数据,默认15条 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
total_count | int | 总条数 |
praises | array | 点赞数据 |
-- name | string | 用户名称 |
-- login | string | 用户标识/登录名(login) |
-- image_url | string | 用户头像 |
返回值
{
"total_count": 1,
"praises": [
{
"name": "18816895620",
"login": "18816895620",
"image_url": "avatars/User/b"
}
]
}
关注(项目)
POST /api/projects/:id/watchers/follow
示例
curl -X POST http://localhost:3000/api/projects/3263/watchers/follow | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 0:点赞成功,-1:操作失败,2:表示已经点过赞了 |
返回值
{
"status": 0,
"message": "响应成功"
}
取消关注
DELETE /api/projects/:id/watchers/unfollow
示例
curl -X DELETE http://localhost:3000//api/projects/3263/watchers/unfollow | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 0:点赞成功,-1:操作失败,2:表示还未点赞 |
返回值
{
"status": 0,
"message": "响应成功"
}
用户是否关注过项目
GET /api/projects/:id/watchers/check_watch
示例
curl -X GET http://localhost:3000/api/projects/3263/watchers/check_watch | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
status | int | 1:已关注,0:未关注, -1:请求操作失败 |
返回值
{
"status": 0,
"message": "success"
}
项目的关注者列表
GET /api/projects/:id/watchers
示例
curl -X GET \
-d "page=1" \
-d "limit=5" \
http://localhost:3000//api/projects/3263/watchers | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
id | 是 | int | 项目id |
page | 否 | string | 页数,第几页 |
limit | 否 | string | 每页多少条数据,默认15条 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
total_count | int | 总条数 |
watchers | array | 关注数据 |
-- name | string | 用户名称 |
-- login | string | 用户标识/登录名(login) |
-- image_url | string | 用户头像 |
返回值
{
"total_count": 1,
"watchers": [
{
"name": "18816895620",
"login": "18816895620",
"image_url": "avatars/User/b"
}
]
}
仓库新建文件
DELETE /api/:login/:repo_identifier/contents
示例
curl -X POST \
-d 'filepath=test1_create_file1.rb' \
-d 'branch=master' \
-d 'content=提交的内容' \
-d 'message=test commit ' \
http://localhost:3000/api/18816895620/mirror_demo/contents.json | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
login | 是 | string | 用户标识 |
repo_identifier | 是 | string | 仓库标识 |
filepath | 是 | string | 文件相对于仓库的路径 |
content | 否 | string | 内容 |
message | 否 | string | 提交说明 |
branch | 否 | string | 分支名称, branch和new_branch必须存在一个 |
new_branch | 否 | string | 新的分支名称 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
name | string | 文件名 |
sha | string | 提交文件的sha值 |
size | int | 文件大小, 单位:B |
content | string | base64编码后的文件内容 |
encoding | string | 编码方式 |
commit | object | |
-- message | string | 提交备注说明信息 |
-- committer | object | |
---- name | string | 用户名 |
string | 用户邮箱 | |
---- date | string | 文件创建时间 |
返回值
{
"name": "test1_create_file12.rb",
"sha": "7b70509105b587e71f5692b9e8ab70851e321f64",
"size": 12,
"content": "Wm5ObWMyRmtaZz09",
"encoding": "base64",
"commit": {
"message": "good luck\n",
"author": {
"name": "18816895620",
"email": "2456233122@qq.com",
"date": "2020-01-07T03:31:20Z"
},
"committer": {
"name": "18816895620",
"email": "2456233122@qq.com",
"date": "2020-01-07T03:31:20Z"
}
}
}
更新仓库中的文件
PUT /api/:login/:repo_identifier/contents/files/update
示例
curl -X PUT \
-d 'filepath=text1.rb' \
-d 'branch=master' \
-d 'content=ruby code' \
-d 'message=更改提交信息' \
-d 'from_path=text.rb' \
-d "sha=57426eb21e4ceabdf4b206f022077e0040" \
http://localhost:3000/api/18816895620/mirror_demo/contents/files/update.json | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
login | 是 | string | 用户标识 |
repo_identifier | 是 | string | 仓库标识 |
filepath | 是 | string | 文件相对于仓库的路径(或修改后的文件路径) |
from_path | 是 | string | 原文件相对于仓库的路径, 只有当需要修改原文件名称时,才需要该参数 |
sha | 是 | string | 文件的sha标识值 |
content | 是 | string | 内容 |
message | 否 | string | 提交说明 |
branch | 否 | string | 分支名称, branch和new_branch必须存在一个,且只能存在一个 |
new_branch | 否 | string | 新的分支名称 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
name | string | 文件名 |
sha | string | 提交文件的sha值 |
size | int | 文件大小, 单位:B |
content | string | base64编码后的文件内容 |
encoding | string | 编码方式 |
commit | object | |
-- message | string | 提交备注说明信息 |
-- committer | object | |
---- name | string | 用户名 |
string | 用户邮箱 | |
---- date | string | 文件创建时间 |
返回值
{
"name": "test1_create_file6.rb",
"sha": "57426eb21e4ceabdf4b206f022257e08077e0040",
"size": 16,
"content": "5o+Q5Lqk55qE5YaF5a65MQ==",
"encoding": "base64",
"commit": {
"message": "更改提交信息\n",
"author": {
"name": "18816895620",
"email": "2456233122@qq.com",
"date": "2020-01-08T07:05:15Z"
},
"committer": {
"name": "18816895620",
"email": "2456233122@qq.com",
"date": "2020-01-08T07:05:15Z"
}
}
}
删除仓库中的文件
DELETE /api/:login/:repo_identifier/contents/files/delete
示例
curl -X DELETE \
-d 'filepath=test1_create_file12.rb' \
-d 'test delete file' \
-d 'sha=7b70509105b587e71f5692b9e8ab70851e321f64' \
http://localhost:3000/api/18816895620/mirror_demo/contents/files/delete | jq
请求参数说明:
参数名 | 必选 | 类型 | 说明 |
---|---|---|---|
login | 是 | string | 用户标识 |
repo_identifier | 是 | string | 仓库标识 |
filepath | 是 | string | 文件相对于仓库的路径 |
message | 否 | string | 提交说明 |
branch | 否 | string | 分支名称, 默认为master分支 |
new_branch | 否 | string | 新的分支名称 |
返回参数说明:
参数名 | 类型 | 说明 |
---|---|---|
sha | string | 提交文件的sha值 |
commit | object | |
-- message | string | 提交备注说明信息 |
-- committer | object | |
---- name | string | 用户名 |
string | 用户邮箱 | |
---- date | string | 文件创建时间 |
返回值
{
"commit": {
"sha": "7b70509105b587e71f5692b9e8ab70851e321f64",
"message": "Delete 'test1_create_file11.rb'\n",
"author": {
"name": "18816895620",
"email": "2456233122@qq.com",
"date": "2020-01-08T07:57:34Z"
},
"committer": {
"name": "18816895620",
"email": "2456233122@qq.com",
"date": "2020-01-08T07:57:34Z"
}
}
}