Cloudreve/routers/router.go

586 lines
16 KiB
Go
Raw Normal View History

2019-11-05 12:31:22 +08:00
package routers
import (
"github.com/cloudreve/Cloudreve/v3/bootstrap"
"github.com/cloudreve/Cloudreve/v3/middleware"
"github.com/cloudreve/Cloudreve/v3/pkg/conf"
"github.com/cloudreve/Cloudreve/v3/pkg/hashid"
"github.com/cloudreve/Cloudreve/v3/pkg/util"
"github.com/cloudreve/Cloudreve/v3/routers/controllers"
2019-12-13 19:00:58 +08:00
"github.com/gin-contrib/cors"
2020-04-06 09:05:30 +08:00
"github.com/gin-contrib/gzip"
2020-03-09 14:07:36 +08:00
"github.com/gin-contrib/static"
2019-11-05 12:31:22 +08:00
"github.com/gin-gonic/gin"
)
// InitRouter 初始化路由
func InitRouter() *gin.Engine {
if conf.SystemConfig.Mode == "master" {
util.Log().Info("当前运行模式Master")
return InitMasterRouter()
2019-12-16 19:43:00 +08:00
}
util.Log().Info("当前运行模式Slave")
return InitSlaveRouter()
2019-12-16 19:43:00 +08:00
}
// InitSlaveRouter 初始化从机模式路由
func InitSlaveRouter() *gin.Engine {
2019-11-14 14:24:39 +08:00
r := gin.Default()
// 跨域相关
InitCORS(r)
v3 := r.Group("/api/v3/slave")
// 鉴权中间件
v3.Use(middleware.SignRequired())
2019-11-12 16:53:32 +08:00
/*
路由
2019-11-12 16:53:32 +08:00
*/
{
2020-02-27 11:17:59 +08:00
// Ping
v3.POST("ping", controllers.SlavePing)
// 上传
v3.POST("upload", controllers.SlaveUpload)
// 下载
v3.GET("download/:speed/:path/:name", controllers.SlaveDownload)
// 预览 / 外链
v3.GET("source/:speed/:path/:name", controllers.SlavePreview)
// 缩略图
v3.GET("thumb/:path", controllers.SlaveThumb)
// 删除文件
v3.POST("delete", controllers.SlaveDelete)
2020-04-28 10:02:53 +08:00
// 列出文件
v3.POST("list", controllers.SlaveList)
}
return r
}
2019-11-12 16:53:32 +08:00
// InitCORS 初始化跨域配置
func InitCORS(router *gin.Engine) {
if conf.CORSConfig.AllowOrigins[0] != "UNSET" {
router.Use(cors.New(cors.Config{
2019-12-13 19:00:58 +08:00
AllowOrigins: conf.CORSConfig.AllowOrigins,
AllowMethods: conf.CORSConfig.AllowMethods,
2019-12-13 19:00:58 +08:00
AllowHeaders: conf.CORSConfig.AllowHeaders,
AllowCredentials: conf.CORSConfig.AllowCredentials,
ExposeHeaders: conf.CORSConfig.ExposeHeaders,
}))
return
2019-12-13 19:00:58 +08:00
}
2019-11-23 15:09:46 +08:00
// slave模式下未启动跨域的警告
if conf.SystemConfig.Mode == "slave" {
util.Log().Warning("当前作为存储端Slave运行但未启用跨域配置可能会导致 Master 端无法正常上传文件")
}
}
// InitMasterRouter 初始化主机模式路由
func InitMasterRouter() *gin.Engine {
r := gin.Default()
/*
静态资源
*/
2020-04-06 09:05:30 +08:00
r.Use(gzip.Gzip(gzip.DefaultCompression, gzip.WithExcludedPaths([]string{"/api/"})))
r.Use(middleware.InjectSiteInfo())
2020-03-09 14:07:36 +08:00
r.Use(static.Serve("/", bootstrap.StaticFS))
r.GET("manifest.json", controllers.Manifest)
v3 := r.Group("/api/v3")
2020-02-23 10:19:13 +08:00
/*
中间件
*/
v3.Use(middleware.Session(conf.SystemConfig.SessionSecret))
// 跨域相关
InitCORS(r)
2019-11-14 14:45:06 +08:00
// 测试模式加入Mock助手中间件
2019-11-12 16:53:32 +08:00
if gin.Mode() == gin.TestMode {
2019-12-16 19:43:00 +08:00
v3.Use(middleware.MockHelper())
2019-11-12 16:53:32 +08:00
}
2019-12-16 19:43:00 +08:00
v3.Use(middleware.CurrentUser())
2019-11-11 19:13:17 +08:00
2019-11-12 16:53:32 +08:00
/*
路由
*/
2019-11-05 12:31:22 +08:00
{
2019-12-10 17:10:34 +08:00
// 全局设置相关
site := v3.Group("site")
{
// 测试用路由
site.GET("ping", controllers.Ping)
// 验证码
site.GET("captcha", controllers.Captcha)
// 站点全局配置
site.GET("config", middleware.CSRFInit(), controllers.SiteConfig)
2019-12-10 17:10:34 +08:00
}
2019-12-10 17:10:34 +08:00
// 用户相关路由
user := v3.Group("user")
{
// 用户登录
2019-12-10 17:10:34 +08:00
user.POST("session", controllers.UserLogin)
// 用户注册
2020-02-22 10:36:50 +08:00
user.POST("",
middleware.IsFunctionEnabled("register_enabled"),
controllers.UserRegister,
)
2020-02-22 09:50:34 +08:00
// 用二步验证户登录
2020-02-21 13:48:34 +08:00
user.POST("2fa", controllers.User2FALogin)
2020-02-22 10:36:50 +08:00
// 发送密码重设邮件
user.POST("reset", controllers.UserSendReset)
// 通过邮件里的链接重设密码
user.PATCH("reset", controllers.UserReset)
2020-02-22 09:50:34 +08:00
// 邮件激活
user.GET("activate/:id",
middleware.SignRequired(),
middleware.HashID(hashid.UserID),
controllers.UserActivate,
)
// WebAuthn登陆初始化
2020-02-21 10:08:47 +08:00
user.GET("authn/:username",
middleware.IsFunctionEnabled("authn_enabled"),
2020-02-22 10:36:50 +08:00
controllers.StartLoginAuthn,
)
// WebAuthn登陆
2020-02-21 10:08:47 +08:00
user.POST("authn/finish/:username",
middleware.IsFunctionEnabled("authn_enabled"),
2020-02-22 10:36:50 +08:00
controllers.FinishLoginAuthn,
)
2020-02-18 15:34:40 +08:00
// 获取用户主页展示用分享
user.GET("profile/:id",
middleware.HashID(hashid.UserID),
controllers.GetUserShare,
)
2020-02-19 16:05:54 +08:00
// 获取用户头像
user.GET("avatar/:id/:size",
middleware.HashID(hashid.UserID),
controllers.GetUserAvatar,
)
}
2019-12-10 17:10:34 +08:00
// 需要携带签名验证的
sign := v3.Group("")
sign.Use(middleware.SignRequired())
{
file := sign.Group("file")
{
// 文件外链
2019-12-10 17:10:34 +08:00
file.GET("get/:id/:name", controllers.AnonymousGetContent)
// 下載已经打包好的文件
file.GET("archive/:id/archive.zip", controllers.DownloadArchive)
// 下载文件
file.GET("download/:id", controllers.Download)
2019-12-10 17:10:34 +08:00
}
}
2019-11-05 12:31:22 +08:00
// 回调接口
callback := v3.Group("callback")
{
2020-01-15 10:14:15 +08:00
// 远程策略上传回调
callback.POST(
"remote/:key",
middleware.RemoteCallbackAuth(),
controllers.RemoteCallback,
)
2020-01-15 10:14:15 +08:00
// 七牛策略上传回调
callback.POST(
"qiniu/:key",
middleware.QiniuCallbackAuth(),
controllers.QiniuCallback,
)
2020-01-16 13:36:13 +08:00
// 阿里云OSS策略上传回调
callback.POST(
"oss/:key",
middleware.OSSCallbackAuth(),
controllers.OSSCallback,
)
2020-01-18 10:40:03 +08:00
// 又拍云策略上传回调
callback.POST(
"upyun/:key",
middleware.UpyunCallbackAuth(),
controllers.UpyunCallback,
)
onedrive := callback.Group("onedrive")
{
// 文件上传完成
onedrive.POST(
"finish/:key",
middleware.OneDriveCallbackAuth(),
controllers.OneDriveCallback,
)
2020-03-01 17:57:18 +08:00
// 文件上传完成
onedrive.GET(
"auth",
controllers.OneDriveOAuth,
)
}
2020-01-23 12:38:32 +08:00
// 腾讯云COS策略上传回调
callback.GET(
"cos/:key",
middleware.COSCallbackAuth(),
controllers.COSCallback,
)
// AWS S3策略上传回调
callback.GET(
"s3/:key",
middleware.S3CallbackAuth(),
controllers.S3Callback,
)
}
2020-01-26 14:57:07 +08:00
// 分享相关
2020-01-29 13:45:27 +08:00
share := v3.Group("share", middleware.ShareAvailable())
2020-01-26 14:57:07 +08:00
{
// 获取分享
2020-01-28 13:40:19 +08:00
share.GET("info/:id", controllers.GetShare)
// 创建文件下载会话
share.PUT("download/:id",
2020-01-30 13:21:21 +08:00
middleware.CheckShareUnlocked(),
2020-01-29 13:45:27 +08:00
middleware.BeforeShareDownload(),
controllers.GetShareDownload,
)
2020-01-28 13:40:19 +08:00
// 预览分享文件
2020-01-29 13:45:27 +08:00
share.GET("preview/:id",
middleware.CSRFCheck(),
2020-01-30 13:21:21 +08:00
middleware.CheckShareUnlocked(),
2020-01-29 13:45:27 +08:00
middleware.ShareCanPreview(),
middleware.BeforeShareDownload(),
controllers.PreviewShare,
)
2020-01-29 12:16:52 +08:00
// 取得Office文档预览地址
2020-01-30 13:21:21 +08:00
share.GET("doc/:id",
middleware.CheckShareUnlocked(),
middleware.ShareCanPreview(),
2020-01-29 13:45:27 +08:00
middleware.BeforeShareDownload(),
controllers.GetShareDocPreview,
)
2020-01-29 12:16:52 +08:00
// 获取文本文件内容
2020-01-29 13:45:27 +08:00
share.GET("content/:id",
2020-01-30 13:21:21 +08:00
middleware.CheckShareUnlocked(),
2020-01-29 13:45:27 +08:00
middleware.BeforeShareDownload(),
controllers.PreviewShareText,
)
2020-01-30 13:21:21 +08:00
// 分享目录列文件
share.GET("list/:id/*path",
middleware.CheckShareUnlocked(),
controllers.ListSharedFolder,
)
// 归档打包下载
share.POST("archive/:id",
middleware.CheckShareUnlocked(),
middleware.BeforeShareDownload(),
controllers.ArchiveShare,
)
2020-01-31 15:12:15 +08:00
// 获取README文本文件内容
share.GET("readme/:id",
middleware.CheckShareUnlocked(),
controllers.PreviewShareReadme,
)
2020-02-01 10:34:23 +08:00
// 获取缩略图
share.GET("thumb/:id/:file",
middleware.CheckShareUnlocked(),
middleware.ShareCanPreview(),
controllers.ShareThumb,
)
// 搜索公共分享
v3.Group("share").GET("search", controllers.SearchShare)
2020-01-26 14:57:07 +08:00
}
2019-11-12 15:34:54 +08:00
// 需要登录保护的
auth := v3.Group("")
auth.Use(middleware.AuthRequired())
{
2020-02-22 16:22:04 +08:00
// 管理
admin := auth.Group("admin", middleware.IsAdmin())
{
// 获取站点概况
admin.GET("summary", controllers.AdminSummary)
2020-02-23 10:19:13 +08:00
// 获取社区新闻
admin.GET("news", controllers.AdminNews)
// 更改设置
admin.PATCH("setting", controllers.AdminChangeSetting)
// 获取设置
admin.POST("setting", controllers.AdminGetSetting)
// 获取用户组列表
admin.GET("groups", controllers.AdminGetGroups)
2020-02-23 15:33:53 +08:00
// 重新加载子服务
admin.GET("reload/:service", controllers.AdminReloadService)
2020-02-23 18:40:14 +08:00
// 重新加载子服务
admin.POST("mailTest", controllers.AdminSendTestMail)
2020-02-24 15:52:13 +08:00
2020-02-26 15:11:06 +08:00
// 离线下载相关
aria2 := admin.Group("aria2")
{
// 测试连接配置
aria2.POST("test", controllers.AdminTestAria2)
}
2020-03-07 13:00:51 +08:00
// 存储策略管理
2020-02-26 15:11:06 +08:00
policy := admin.Group("policy")
{
// 列出存储策略
policy.POST("list", controllers.AdminListPolicy)
// 测试本地路径可用性
policy.POST("test/path", controllers.AdminTestPath)
2020-02-27 11:17:59 +08:00
// 测试从机通信
policy.POST("test/slave", controllers.AdminTestSlave)
2020-02-26 15:11:06 +08:00
// 创建存储策略
policy.POST("", controllers.AdminAddPolicy)
2020-03-01 16:25:56 +08:00
// 创建跨域策略
2020-02-27 15:12:15 +08:00
policy.POST("cors", controllers.AdminAddCORS)
2020-03-01 16:25:56 +08:00
// 创建COS回调函数
policy.POST("scf", controllers.AdminAddSCF)
2020-03-01 17:57:18 +08:00
// 获取 OneDrive OAuth URL
policy.GET(":id/oauth", controllers.AdminOneDriveOAuth)
// 获取 存储策略
policy.GET(":id", controllers.AdminGetPolicy)
// 删除 存储策略
policy.DELETE(":id", controllers.AdminDeletePolicy)
2020-02-26 15:11:06 +08:00
}
2020-03-07 13:00:51 +08:00
// 用户组管理
group := admin.Group("group")
{
// 列出用户组
group.POST("list", controllers.AdminListGroup)
// 获取用户组
group.GET(":id", controllers.AdminGetGroup)
// 创建/保存用户组
group.POST("", controllers.AdminAddGroup)
// 删除
group.DELETE(":id", controllers.AdminDeleteGroup)
}
2020-03-07 14:04:18 +08:00
user := admin.Group("user")
{
// 列出用户
user.POST("list", controllers.AdminListUser)
2020-03-08 10:49:34 +08:00
// 获取用户
user.GET(":id", controllers.AdminGetUser)
// 创建/保存用户
user.POST("", controllers.AdminAddUser)
2020-03-08 12:54:04 +08:00
// 删除
user.POST("delete", controllers.AdminDeleteUser)
// 封禁/解封用户
user.PATCH("ban/:id", controllers.AdminBanUser)
2020-03-07 14:04:18 +08:00
}
2020-03-08 13:53:13 +08:00
file := admin.Group("file")
{
// 列出文件
file.POST("list", controllers.AdminListFile)
// 预览文件
file.GET("preview/:id", controllers.AdminGetFile)
2020-03-09 10:17:59 +08:00
// 删除
file.POST("delete", controllers.AdminDeleteFile)
// 列出用户或外部文件系统目录
file.GET("folders/:type/:id/*path",
controllers.AdminListFolders)
2020-03-09 10:17:59 +08:00
}
share := admin.Group("share")
{
// 列出分享
share.POST("list", controllers.AdminListShare)
2020-03-09 10:59:42 +08:00
// 删除
share.POST("delete", controllers.AdminDeleteShare)
2020-03-08 13:53:13 +08:00
}
2020-03-09 12:30:43 +08:00
download := admin.Group("download")
{
// 列出任务
download.POST("list", controllers.AdminListDownload)
// 删除
download.POST("delete", controllers.AdminDeleteDownload)
}
task := admin.Group("task")
{
// 列出任务
task.POST("list", controllers.AdminListTask)
// 删除
task.POST("delete", controllers.AdminDeleteTask)
// 新建文件导入任务
task.POST("import", controllers.AdminCreateImportTask)
2020-03-09 12:30:43 +08:00
}
2020-02-22 16:22:04 +08:00
}
2019-11-23 15:37:13 +08:00
// 用户
2019-11-23 16:58:56 +08:00
user := auth.Group("user")
2019-11-12 15:34:54 +08:00
{
// 当前登录用户信息
2019-11-23 16:58:56 +08:00
user.GET("me", controllers.UserMe)
2020-01-28 13:40:19 +08:00
// 存储信息
user.GET("storage", controllers.UserStorage)
2020-01-28 13:40:19 +08:00
// 退出登录
user.DELETE("session", controllers.UserSignOut)
2019-12-08 22:17:36 +08:00
// WebAuthn 注册相关
2020-02-21 10:08:47 +08:00
authn := user.Group("authn",
middleware.IsFunctionEnabled("authn_enabled"))
2019-12-08 22:17:36 +08:00
{
authn.PUT("", controllers.StartRegAuthn)
authn.PUT("finish", controllers.FinishRegAuthn)
}
2020-02-18 13:45:59 +08:00
// 用户设置
setting := user.Group("setting")
{
2020-02-18 14:45:38 +08:00
// 任务队列
setting.GET("tasks", controllers.UserTasks)
2020-02-19 16:05:54 +08:00
// 获取当前用户设定
setting.GET("", controllers.UserSetting)
// 从文件上传头像
setting.POST("avatar", controllers.UploadAvatar)
// 设定为Gravatar头像
setting.PUT("avatar", controllers.UseGravatar)
// 更改用户设定
setting.PATCH(":option", controllers.UpdateOption)
2020-02-20 12:42:38 +08:00
// 获得二步验证初始化信息
setting.GET("2fa", controllers.UserInit2FA)
2020-02-18 13:45:59 +08:00
}
2019-11-12 15:34:54 +08:00
}
2019-11-15 18:12:34 +08:00
// 文件
file := auth.Group("file", middleware.HashID(hashid.FileID))
2019-11-15 18:12:34 +08:00
{
2019-11-22 14:56:46 +08:00
// 文件上传
2019-11-23 16:58:56 +08:00
file.POST("upload", controllers.FileUploadStream)
2019-12-28 15:50:56 +08:00
// 获取上传凭证
file.GET("upload/credential", controllers.GetUploadCredential)
2019-12-15 14:01:37 +08:00
// 更新文件
file.PUT("update/:id", controllers.PutContent)
// 创建空白文件
file.POST("create", controllers.CreateFile)
// 创建文件下载会话
file.PUT("download/:id", controllers.CreateDownloadSession)
// 预览文件
file.GET("preview/:id", controllers.Preview)
// 获取文本文件内容
file.GET("content/:id", controllers.PreviewText)
// 取得Office文档预览地址
file.GET("doc/:id", controllers.GetDocPreview)
// 获取缩略图
2019-12-08 22:17:36 +08:00
file.GET("thumb/:id", controllers.Thumb)
// 取得文件外链
file.GET("source/:id", controllers.GetSource)
2019-12-13 15:10:44 +08:00
// 打包要下载的文件
file.POST("archive", controllers.Archive)
2020-02-02 14:40:07 +08:00
// 创建文件压缩任务
file.POST("compress", controllers.Compress)
2020-02-03 13:23:33 +08:00
// 创建文件解压缩任务
file.POST("decompress", controllers.Decompress)
// 创建文件解压缩任务
file.GET("search/:type/:keywords", controllers.SearchFile)
2019-11-15 18:12:34 +08:00
}
// 离线下载任务
2020-02-04 15:29:52 +08:00
aria2 := auth.Group("aria2")
{
// 创建URL下载任务
2020-02-04 15:29:52 +08:00
aria2.POST("url", controllers.AddAria2URL)
// 创建种子下载任务
aria2.POST("torrent/:id", middleware.HashID(hashid.FileID), controllers.AddAria2Torrent)
// 重新选择要下载的文件
aria2.PUT("select/:gid", controllers.SelectAria2File)
// 取消或删除下载任务
2020-02-06 10:07:46 +08:00
aria2.DELETE("task/:gid", controllers.CancelAria2Download)
2020-02-08 15:37:51 +08:00
// 获取正在下载中的任务
aria2.GET("downloading", controllers.ListDownloading)
// 获取已完成的任务
aria2.GET("finished", controllers.ListFinished)
2020-02-04 15:29:52 +08:00
}
2019-11-23 15:37:13 +08:00
// 目录
2019-11-23 16:58:56 +08:00
directory := auth.Group("directory")
2019-11-23 15:37:13 +08:00
{
// 创建目录
directory.PUT("", controllers.CreateDirectory)
2019-11-24 13:06:15 +08:00
// 列出目录下内容
2019-11-30 15:09:56 +08:00
directory.GET("*path", controllers.ListDirectory)
}
// 对象,文件和目录的抽象
object := auth.Group("object")
{
2019-12-01 18:31:29 +08:00
// 删除对象
2019-11-30 15:09:56 +08:00
object.DELETE("", controllers.Delete)
2019-12-03 14:20:23 +08:00
// 移动对象
2019-12-01 18:31:29 +08:00
object.PATCH("", controllers.Move)
2019-12-03 14:20:23 +08:00
// 复制对象
object.POST("copy", controllers.Copy)
2019-12-07 15:54:07 +08:00
// 重命名对象
object.POST("rename", controllers.Rename)
2019-11-23 15:37:13 +08:00
}
2020-01-26 13:07:05 +08:00
// 分享
share := auth.Group("share")
{
// 创建新分享
share.POST("", controllers.CreateShare)
2020-02-13 11:53:24 +08:00
// 列出我的分享
share.GET("", controllers.ListShare)
// 更新分享属性
share.PATCH(":id",
middleware.ShareAvailable(),
middleware.ShareOwner(),
controllers.UpdateShare,
)
// 删除分享
share.DELETE(":id",
controllers.DeleteShare,
)
2020-01-26 13:07:05 +08:00
}
2020-02-12 11:38:04 +08:00
// 用户标签
tag := auth.Group("tag")
{
// 创建文件分类标签
tag.POST("filter", controllers.CreateFilterTag)
// 创建目录快捷方式标签
tag.POST("link", controllers.CreateLinkTag)
// 删除标签
tag.DELETE(":id", middleware.HashID(hashid.TagID), controllers.DeleteTag)
}
2020-02-18 12:10:28 +08:00
// WebDAV管理相关
webdav := auth.Group("webdav")
{
// 获取账号信息
webdav.GET("accounts", controllers.GetWebDAVAccounts)
// 新建账号
webdav.POST("accounts", controllers.CreateWebDAVAccounts)
// 删除账号
webdav.DELETE("accounts/:id", controllers.DeleteWebDAVAccounts)
}
2019-11-12 15:34:54 +08:00
}
2019-11-05 12:31:22 +08:00
}
2019-12-16 19:43:00 +08:00
// 初始化WebDAV相关路由
initWebDAV(r.Group("dav"))
2019-11-05 12:31:22 +08:00
return r
}
// initWebDAV 初始化WebDAV相关路由
func initWebDAV(group *gin.RouterGroup) {
{
group.Use(middleware.WebDAVAuth())
group.Any("/*path", controllers.ServeWebDAV)
group.Any("", controllers.ServeWebDAV)
group.Handle("PROPFIND", "/*path", controllers.ServeWebDAV)
group.Handle("PROPFIND", "", controllers.ServeWebDAV)
group.Handle("MKCOL", "/*path", controllers.ServeWebDAV)
group.Handle("LOCK", "/*path", controllers.ServeWebDAV)
group.Handle("UNLOCK", "/*path", controllers.ServeWebDAV)
group.Handle("PROPPATCH", "/*path", controllers.ServeWebDAV)
group.Handle("COPY", "/*path", controllers.ServeWebDAV)
group.Handle("MOVE", "/*path", controllers.ServeWebDAV)
}
}