mirror of https://github.com/Xhofe/alist
✨ WebDAV auth
parent
3041da35ab
commit
0f0e1104a4
|
@ -141,6 +141,20 @@ func InitSettings() {
|
||||||
Description: "check down link password, your link will be 'https://alist.com/d/filename?pw=xxx'",
|
Description: "check down link password, your link will be 'https://alist.com/d/filename?pw=xxx'",
|
||||||
Group: model.PUBLIC,
|
Group: model.PUBLIC,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Key: "WebDAV username",
|
||||||
|
Value: "alist",
|
||||||
|
Description: "WebDAV username",
|
||||||
|
Type: "string",
|
||||||
|
Group: model.PRIVATE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Key: "WebDAV password",
|
||||||
|
Value: "alist",
|
||||||
|
Description: "WebDAV password",
|
||||||
|
Type: "string",
|
||||||
|
Group: model.PRIVATE,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
for _, v := range settings {
|
for _, v := range settings {
|
||||||
_, err := model.GetSettingByKey(v.Key)
|
_, err := model.GetSettingByKey(v.Key)
|
||||||
|
|
|
@ -45,4 +45,7 @@ var (
|
||||||
//CustomizeScript string
|
//CustomizeScript string
|
||||||
//Favicon string
|
//Favicon string
|
||||||
CheckDown bool
|
CheckDown bool
|
||||||
|
|
||||||
|
DavUsername string
|
||||||
|
DavPassword string
|
||||||
)
|
)
|
||||||
|
|
|
@ -85,4 +85,13 @@ func LoadSettings() {
|
||||||
//conf.CustomizeStyle = customizeScript.Value
|
//conf.CustomizeStyle = customizeScript.Value
|
||||||
conf.IndexHtml = strings.Replace(conf.IndexHtml, "// customize-js", customizeScript.Value, 1)
|
conf.IndexHtml = strings.Replace(conf.IndexHtml, "// customize-js", customizeScript.Value, 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
davUsername, err := GetSettingByKey("WebDAV username")
|
||||||
|
if err == nil {
|
||||||
|
conf.DavUsername = davUsername.Value
|
||||||
|
}
|
||||||
|
davPassword, err := GetSettingByKey("WebDAV password")
|
||||||
|
if err == nil {
|
||||||
|
conf.DavPassword = davPassword.Value
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
package server
|
package server
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/Xhofe/alist/conf"
|
||||||
"github.com/Xhofe/alist/server/webdav"
|
"github.com/Xhofe/alist/server/webdav"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
|
"net/http"
|
||||||
)
|
)
|
||||||
|
|
||||||
var handler *webdav.Handler
|
var handler *webdav.Handler
|
||||||
|
@ -16,6 +18,7 @@ func init() {
|
||||||
|
|
||||||
func WebDav(r *gin.Engine) {
|
func WebDav(r *gin.Engine) {
|
||||||
dav := r.Group("/dav")
|
dav := r.Group("/dav")
|
||||||
|
dav.Use(WebDAVAuth)
|
||||||
dav.Any("/*path", ServeWebDAV)
|
dav.Any("/*path", ServeWebDAV)
|
||||||
dav.Any("", ServeWebDAV)
|
dav.Any("", ServeWebDAV)
|
||||||
dav.Handle("PROPFIND", "/*path", ServeWebDAV)
|
dav.Handle("PROPFIND", "/*path", ServeWebDAV)
|
||||||
|
@ -32,3 +35,26 @@ func ServeWebDAV(c *gin.Context) {
|
||||||
fs := webdav.FileSystem{}
|
fs := webdav.FileSystem{}
|
||||||
handler.ServeHTTP(c.Writer,c.Request,&fs)
|
handler.ServeHTTP(c.Writer,c.Request,&fs)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func WebDAVAuth(c *gin.Context) {
|
||||||
|
if c.Request.Method == "OPTIONS" {
|
||||||
|
c.Next()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
username, password, ok := c.Request.BasicAuth()
|
||||||
|
if !ok {
|
||||||
|
c.Writer.Header()["WWW-Authenticate"] = []string{`Basic realm="alist"`}
|
||||||
|
c.Status(http.StatusUnauthorized)
|
||||||
|
c.Abort()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if conf.DavUsername != "" && conf.DavUsername != username {
|
||||||
|
c.Status(http.StatusUnauthorized)
|
||||||
|
c.Abort()
|
||||||
|
}
|
||||||
|
if conf.DavPassword != "" && conf.DavPassword != password {
|
||||||
|
c.Status(http.StatusUnauthorized)
|
||||||
|
c.Abort()
|
||||||
|
}
|
||||||
|
c.Next()
|
||||||
|
}
|
Loading…
Reference in New Issue