Compare commits
24 Commits
v2.0.0-bet
...
v2.0.0-bet
Author | SHA1 | Date | |
---|---|---|---|
f4affb2c69 | |||
17af21079f | |||
f7d35ec925 | |||
a8730e82b5 | |||
6275e27d1b | |||
e70353704f | |||
be5b1e42d4 | |||
7d08cbc4a9 | |||
1542878d66 | |||
ac8f5d5737 | |||
9ed5b6e581 | |||
db7bff2d61 | |||
7970e737f0 | |||
d4523d52ee | |||
ac8476702c | |||
12f68eaed9 | |||
6a51f02845 | |||
e7071e1093 | |||
11b141b190 | |||
7e099b39cf | |||
b46bf0dfc9 | |||
91f64161b2 | |||
8255ef4346 | |||
254b6c6f79 |
18
.github/workflows/build.yml
vendored
18
.github/workflows/build.yml
vendored
@ -10,7 +10,7 @@ jobs:
|
|||||||
build:
|
build:
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
platform: [macos-latest]
|
platform: [ubuntu-latest]
|
||||||
go-version: [1.17]
|
go-version: [1.17]
|
||||||
name: Build
|
name: Build
|
||||||
runs-on: ${{ matrix.platform }}
|
runs-on: ${{ matrix.platform }}
|
||||||
@ -25,8 +25,8 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
node-version: '16'
|
node-version: '16'
|
||||||
|
|
||||||
- name: Setup docker
|
# - name: Setup docker
|
||||||
uses: docker-practice/actions-setup-docker@master
|
# uses: docker-practice/actions-setup-docker@master
|
||||||
|
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
@ -45,20 +45,12 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
docker pull techknowlogick/xgo:latest
|
docker pull techknowlogick/xgo:latest
|
||||||
go install src.techknowlogick.com/xgo@latest
|
go install src.techknowlogick.com/xgo@latest
|
||||||
brew install upx
|
sudo apt install upx
|
||||||
|
|
||||||
- name: Build web
|
|
||||||
run: |
|
|
||||||
cd alist-web
|
|
||||||
yarn
|
|
||||||
yarn build
|
|
||||||
cd ..
|
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
cd alist
|
mv alist/build.sh .
|
||||||
bash build.sh
|
bash build.sh
|
||||||
cd ..
|
|
||||||
|
|
||||||
- name: Upload artifact
|
- name: Upload artifact
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
|
48
.github/workflows/docker.yml
vendored
Normal file
48
.github/workflows/docker.yml
vendored
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
name: docker
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- 'v2'
|
||||||
|
tags:
|
||||||
|
- 'v*'
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- 'v2'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
docker:
|
||||||
|
name: Docker
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Docker meta
|
||||||
|
id: meta
|
||||||
|
uses: docker/metadata-action@v3
|
||||||
|
with:
|
||||||
|
images: xhofe/alist
|
||||||
|
- name: Set up Node
|
||||||
|
uses: actions/setup-node@v2
|
||||||
|
with:
|
||||||
|
node-version: '16'
|
||||||
|
- name: Build web
|
||||||
|
run: bash build.sh web
|
||||||
|
- name: Set up QEMU
|
||||||
|
uses: docker/setup-qemu-action@v1
|
||||||
|
- name: Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v1
|
||||||
|
- name: Login to DockerHub
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
username: xhofe
|
||||||
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
|
- name: Build and push
|
||||||
|
id: docker_build
|
||||||
|
uses: docker/build-push-action@v2
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
push: true
|
||||||
|
tags: ${{ steps.meta.outputs.tags }}
|
||||||
|
labels: ${{ steps.meta.outputs.labels }}
|
||||||
|
platforms: linux/amd64,linux/arm64,linux/arm/v7,linux/386,linux/arm/v6,linux/ppc64le,linux/s390x
|
30
.github/workflows/release.yml
vendored
30
.github/workflows/release.yml
vendored
@ -9,7 +9,7 @@ jobs:
|
|||||||
release:
|
release:
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
platform: [macos-latest]
|
platform: [ubuntu-latest]
|
||||||
go-version: [1.17]
|
go-version: [1.17]
|
||||||
name: Release
|
name: Release
|
||||||
runs-on: ${{ matrix.platform }}
|
runs-on: ${{ matrix.platform }}
|
||||||
@ -19,8 +19,8 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
go-version: ${{ matrix.go-version }}
|
go-version: ${{ matrix.go-version }}
|
||||||
|
|
||||||
- name: Setup docker
|
# - name: Setup docker
|
||||||
uses: docker-practice/actions-setup-docker@master
|
# uses: docker-practice/actions-setup-docker@master
|
||||||
|
|
||||||
- name: Setup Node
|
- name: Setup Node
|
||||||
uses: actions/setup-node@v2
|
uses: actions/setup-node@v2
|
||||||
@ -32,6 +32,8 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
ref: v2
|
ref: v2
|
||||||
path: alist
|
path: alist
|
||||||
|
persist-credentials: false
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Checkout web repo
|
- name: Checkout web repo
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
@ -39,25 +41,27 @@ jobs:
|
|||||||
repository: Xhofe/alist-web
|
repository: Xhofe/alist-web
|
||||||
ref: v2
|
ref: v2
|
||||||
path: alist-web
|
path: alist-web
|
||||||
|
persist-credentials: false
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Set up xgo
|
- name: Set up xgo
|
||||||
run: |
|
run: |
|
||||||
docker pull techknowlogick/xgo:latest
|
docker pull techknowlogick/xgo:latest
|
||||||
go install src.techknowlogick.com/xgo@latest
|
go install src.techknowlogick.com/xgo@latest
|
||||||
brew install upx
|
sudo apt install upx
|
||||||
|
|
||||||
- name: Build web
|
|
||||||
run: |
|
|
||||||
cd alist-web
|
|
||||||
yarn
|
|
||||||
yarn build
|
|
||||||
cd ..
|
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
cd alist
|
mv alist/build.sh .
|
||||||
bash build.sh release
|
bash build.sh release
|
||||||
cd ..
|
|
||||||
|
- name: Upload asserts files
|
||||||
|
uses: ad-m/github-push-action@master
|
||||||
|
with:
|
||||||
|
github_token: ${{ secrets.MY_TOKEN }}
|
||||||
|
branch: cdn
|
||||||
|
directory: alist-web
|
||||||
|
repository: Xhofe/alist-web
|
||||||
|
|
||||||
- name: Release
|
- name: Release
|
||||||
uses: softprops/action-gh-release@v1
|
uses: softprops/action-gh-release@v1
|
||||||
|
13
Dockerfile
Normal file
13
Dockerfile
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
FROM alpine:edge as builder
|
||||||
|
LABEL stage=go-builder
|
||||||
|
WORKDIR /app/
|
||||||
|
COPY ./ ./
|
||||||
|
RUN apk add --no-cache bash git go gcc musl-dev; \
|
||||||
|
sh build.sh docker
|
||||||
|
|
||||||
|
FROM alpine:edge
|
||||||
|
LABEL MAINTAINER="i@nn.ci"
|
||||||
|
WORKDIR /opt/alist/
|
||||||
|
COPY --from=builder /app/bin/alist ./
|
||||||
|
EXPOSE 5244
|
||||||
|
CMD [ "./alist" ]
|
@ -171,6 +171,12 @@ func initSettings() {
|
|||||||
Description: "when have multiple, the readme file to show",
|
Description: "when have multiple, the readme file to show",
|
||||||
Group: model.PUBLIC,
|
Group: model.PUBLIC,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Key: "markdown theme",
|
||||||
|
Value: "vuepress",
|
||||||
|
Description: "default | github | vuepress",
|
||||||
|
Group: model.PUBLIC,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
for _, v := range settings {
|
for _, v := range settings {
|
||||||
_, err := model.GetSettingByKey(v.Key)
|
_, err := model.GetSettingByKey(v.Key)
|
||||||
|
65
build.sh
65
build.sh
@ -1,17 +1,57 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
if [ "$1" == "web" ]; then
|
||||||
|
git clone https://github.com/Xhofe/alist-web.git
|
||||||
|
cd alist-web || exit
|
||||||
|
yarn
|
||||||
|
yarn build
|
||||||
|
mv dist/* ../public
|
||||||
|
cd ..
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
go env -w GOPROXY=https://goproxy.cn,https://mirrors.aliyun.com/goproxy/,https://goproxy.io,direct
|
||||||
|
|
||||||
|
if [ "$1" == "docker" ]; then
|
||||||
appName="alist"
|
appName="alist"
|
||||||
builtAt="$(date +'%F %T %z')"
|
builtAt="$(date +'%F %T %z')"
|
||||||
goVersion=$(go version | sed 's/go version //')
|
goVersion=$(go version | sed 's/go version //')
|
||||||
gitAuthor=$(git show -s --format='format:%aN <%ae>' HEAD)
|
gitAuthor=$(git show -s --format='format:%aN <%ae>' HEAD)
|
||||||
gitCommit=$(git log --pretty=format:"%h" -1)
|
gitCommit=$(git log --pretty=format:"%h" -1)
|
||||||
|
gitTag=$(git describe --long --tags --dirty --always)
|
||||||
if [ "$1" == "release" ]; then
|
ldflags="\
|
||||||
gitTag=$(git describe --abbrev=0 --tags)
|
-w -s \
|
||||||
else
|
-X 'github.com/Xhofe/alist/conf.BuiltAt=$builtAt' \
|
||||||
gitTag=$(git describe --abbrev=0 --tags)-next
|
-X 'github.com/Xhofe/alist/conf.GoVersion=$goVersion' \
|
||||||
|
-X 'github.com/Xhofe/alist/conf.GitAuthor=$gitAuthor' \
|
||||||
|
-X 'github.com/Xhofe/alist/conf.GitCommit=$gitCommit' \
|
||||||
|
-X 'github.com/Xhofe/alist/conf.GitTag=$gitTag' \
|
||||||
|
"
|
||||||
|
go build -o ./bin/alist -ldflags="$ldflags" alist.go
|
||||||
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
cd alist-web || exit
|
||||||
|
webCommit=$(git log --pretty=format:"%h" -1)
|
||||||
|
echo "web commit id: $webCommit"
|
||||||
|
yarn
|
||||||
|
if [ "$1" == "release" ]; then
|
||||||
|
yarn build --base="https://cdn.jsdelivr.net/gh/Xhofe/alist-web@cdn/v2/$webCommit"
|
||||||
|
mv dist/assets ..
|
||||||
|
else
|
||||||
|
yarn build
|
||||||
|
fi
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
cd alist
|
||||||
|
appName="alist"
|
||||||
|
builtAt="$(date +'%F %T %z')"
|
||||||
|
goVersion=$(go version | sed 's/go version //')
|
||||||
|
gitAuthor=$(git show -s --format='format:%aN <%ae>' HEAD)
|
||||||
|
gitCommit=$(git log --pretty=format:"%h" -1)
|
||||||
|
gitTag=$(git describe --long --tags --dirty --always)
|
||||||
|
|
||||||
|
echo "build version: $gitTag"
|
||||||
|
|
||||||
ldflags="\
|
ldflags="\
|
||||||
-w -s \
|
-w -s \
|
||||||
-X 'github.com/Xhofe/alist/conf.BuiltAt=$builtAt' \
|
-X 'github.com/Xhofe/alist/conf.BuiltAt=$builtAt' \
|
||||||
@ -33,7 +73,7 @@ mv alist-* build
|
|||||||
cd build || exit
|
cd build || exit
|
||||||
upx -9 ./*
|
upx -9 ./*
|
||||||
find . -type f -print0 | xargs -0 md5sum > md5.txt
|
find . -type f -print0 | xargs -0 md5sum > md5.txt
|
||||||
|
cat md5.txt
|
||||||
# compress file (release)
|
# compress file (release)
|
||||||
if [ "$1" == "release" ]; then
|
if [ "$1" == "release" ]; then
|
||||||
mkdir compress
|
mkdir compress
|
||||||
@ -51,3 +91,16 @@ if [ "$1" == "release" ]; then
|
|||||||
zip compress/$(echo $i | sed 's/\.[^.]*$//').zip "$i"
|
zip compress/$(echo $i | sed 's/\.[^.]*$//').zip "$i"
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
cd ../..
|
||||||
|
|
||||||
|
if [ "$1" == "release" ]; then
|
||||||
|
cd alist-web
|
||||||
|
git checkout cdn
|
||||||
|
mkdir "v2/$webCommit"
|
||||||
|
mv ../assets/ v2/$webCommit
|
||||||
|
git add .
|
||||||
|
git config --local user.email "i@nn.ci"
|
||||||
|
git config --local user.name "Xhofe"
|
||||||
|
git commit --allow-empty -m "upload $webCommit assets files" -a
|
||||||
|
cd ..
|
||||||
|
fi
|
@ -221,13 +221,16 @@ func (a AliDrive) Path(path string, account *model.Account) (*model.File, []*mod
|
|||||||
return a.FormatFile(&file), nil, nil
|
return a.FormatFile(&file), nil, nil
|
||||||
} else {
|
} else {
|
||||||
files, _ := cache.([]AliFile)
|
files, _ := cache.([]AliFile)
|
||||||
|
if len(files) != 0 {
|
||||||
res := make([]*model.File, 0)
|
res := make([]*model.File, 0)
|
||||||
for _, file = range files {
|
for _, file = range files {
|
||||||
res = append(res, a.FormatFile(&file))
|
res = append(res, a.FormatFile(&file))
|
||||||
}
|
}
|
||||||
return nil, res, nil
|
return nil, res, nil
|
||||||
}
|
}
|
||||||
} else {
|
}
|
||||||
|
}
|
||||||
|
// no cache or len(files) == 0
|
||||||
fileId := account.RootFolder
|
fileId := account.RootFolder
|
||||||
if path != "/" {
|
if path != "/" {
|
||||||
dir, name := filepath.Split(path)
|
dir, name := filepath.Split(path)
|
||||||
@ -270,7 +273,6 @@ func (a AliDrive) Path(path string, account *model.Account) (*model.File, []*mod
|
|||||||
}
|
}
|
||||||
return nil, res, nil
|
return nil, res, nil
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
func (a AliDrive) Link(path string, account *model.Account) (string, error) {
|
func (a AliDrive) Link(path string, account *model.Account) (string, error) {
|
||||||
file, err := a.GetFile(utils.ParsePath(path), account)
|
file, err := a.GetFile(utils.ParsePath(path), account)
|
||||||
@ -316,10 +318,12 @@ func (a AliDrive) RefreshToken(account *model.Account) error {
|
|||||||
SetError(&e).
|
SetError(&e).
|
||||||
Post(url)
|
Post(url)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
account.Status = err.Error()
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
log.Debugf("%+v,%+v", resp, e)
|
log.Debugf("%+v,%+v", resp, e)
|
||||||
if e.Code != "" {
|
if e.Code != "" {
|
||||||
|
account.Status = e.Message
|
||||||
return fmt.Errorf("failed to refresh token: %s", e.Message)
|
return fmt.Errorf("failed to refresh token: %s", e.Message)
|
||||||
}
|
}
|
||||||
account.RefreshToken, account.AccessToken = resp.RefreshToken, resp.AccessToken
|
account.RefreshToken, account.AccessToken = resp.RefreshToken, resp.AccessToken
|
||||||
@ -354,9 +358,6 @@ func (a AliDrive) Save(account *model.Account, old *model.Account) error {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
err = a.RefreshToken(&newAccount)
|
err = a.RefreshToken(&newAccount)
|
||||||
if err != nil {
|
|
||||||
newAccount.Status = err.Error()
|
|
||||||
}
|
|
||||||
_ = model.SaveAccount(newAccount)
|
_ = model.SaveAccount(newAccount)
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -146,9 +146,11 @@ func (o Onedrive) RefreshToken(account *model.Account) error {
|
|||||||
"refresh_token": account.RefreshToken,
|
"refresh_token": account.RefreshToken,
|
||||||
}).Post(url)
|
}).Post(url)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
account.Status = err.Error()
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if e.Error != "" {
|
if e.Error != "" {
|
||||||
|
account.Status = e.ErrorDescription
|
||||||
return fmt.Errorf("%s", e.ErrorDescription)
|
return fmt.Errorf("%s", e.ErrorDescription)
|
||||||
}
|
}
|
||||||
account.RefreshToken, account.AccessToken = resp.RefreshToken, resp.AccessToken
|
account.RefreshToken, account.AccessToken = resp.RefreshToken, resp.AccessToken
|
||||||
@ -280,9 +282,6 @@ func (o Onedrive) Save(account *model.Account, old *model.Account) error {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
err = o.RefreshToken(&newAccount)
|
err = o.RefreshToken(&newAccount)
|
||||||
if err != nil {
|
|
||||||
newAccount.Status = err.Error()
|
|
||||||
}
|
|
||||||
_ = model.SaveAccount(newAccount)
|
_ = model.SaveAccount(newAccount)
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
package model
|
package model
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"github.com/Xhofe/alist/conf"
|
"github.com/Xhofe/alist/conf"
|
||||||
|
"github.com/robfig/cron/v3"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -44,9 +46,11 @@ func SaveAccount(account Account) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func DeleteAccount(name string) error {
|
func DeleteAccount(name string) error {
|
||||||
account := Account{
|
account, ok := GetAccount(name)
|
||||||
Name: name,
|
if !ok {
|
||||||
|
return fmt.Errorf("no [%s] account", name)
|
||||||
}
|
}
|
||||||
|
conf.Cron.Remove(cron.EntryID(account.CronId))
|
||||||
if err := conf.DB.Delete(&account).Error; err != nil {
|
if err := conf.DB.Delete(&account).Error; err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,7 @@ func GetSettings() (*[]SettingItem, error) {
|
|||||||
|
|
||||||
func GetSettingByKey(key string) (*SettingItem, error) {
|
func GetSettingByKey(key string) (*SettingItem, error) {
|
||||||
var items SettingItem
|
var items SettingItem
|
||||||
if err := conf.DB.Where("key = ?", key).First(&items).Error; err != nil {
|
if err := conf.DB.Where("`key` = ?", key).First(&items).Error; err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return &items, nil
|
return &items, nil
|
||||||
|
@ -12,7 +12,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func Down(ctx *fiber.Ctx) error {
|
func Down(ctx *fiber.Ctx) error {
|
||||||
rawPath, err:= url.QueryUnescape(ctx.Params("*"))
|
rawPath, err := url.PathUnescape(ctx.Params("*"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return ErrorResp(ctx, err, 500)
|
return ErrorResp(ctx, err, 500)
|
||||||
}
|
}
|
||||||
@ -34,7 +34,7 @@ func Down(ctx *fiber.Ctx) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Proxy(ctx *fiber.Ctx) error {
|
func Proxy(ctx *fiber.Ctx) error {
|
||||||
rawPath, err:= url.QueryUnescape(ctx.Params("*"))
|
rawPath, err := url.PathUnescape(ctx.Params("*"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return ErrorResp(ctx, err, 500)
|
return ErrorResp(ctx, err, 500)
|
||||||
}
|
}
|
||||||
@ -55,6 +55,20 @@ func Proxy(ctx *fiber.Ctx) error {
|
|||||||
return ctx.SendFile(link)
|
return ctx.SendFile(link)
|
||||||
} else {
|
} else {
|
||||||
driver.Proxy(ctx)
|
driver.Proxy(ctx)
|
||||||
|
//ctx.Response().ImmediateHeaderFlush = true
|
||||||
|
//var ProxyNetHttp = fasthttpadaptor.NewFastHTTPHandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
// target, _ := url.Parse(link)
|
||||||
|
// protocol := "https://"
|
||||||
|
// if strings.HasPrefix(link, "http://") {
|
||||||
|
// protocol = "http://"
|
||||||
|
// }
|
||||||
|
// targetHost, _ := url.Parse(fmt.Sprintf("%s%s", protocol, target.Host))
|
||||||
|
// proxy := httputil.NewSingleHostReverseProxy(targetHost)
|
||||||
|
// r.URL = target
|
||||||
|
// r.Host = target.Host
|
||||||
|
// proxy.ServeHTTP(w, r)
|
||||||
|
//})
|
||||||
|
//ProxyNetHttp(ctx.Context())
|
||||||
if err := proxy.Do(ctx, link); err != nil {
|
if err := proxy.Do(ctx, link); err != nil {
|
||||||
log.Errorf("proxy error: %s", err)
|
log.Errorf("proxy error: %s", err)
|
||||||
return ErrorResp(ctx,err,500)
|
return ErrorResp(ctx,err,500)
|
||||||
|
@ -32,7 +32,7 @@ func SaveMeta(ctx *fiber.Ctx) error {
|
|||||||
|
|
||||||
func DeleteMeta(ctx *fiber.Ctx) error {
|
func DeleteMeta(ctx *fiber.Ctx) error {
|
||||||
path := ctx.Query("path")
|
path := ctx.Query("path")
|
||||||
path = utils.ParsePath(path)
|
//path = utils.ParsePath(path)
|
||||||
if err := model.DeleteMeta(path); err != nil {
|
if err := model.DeleteMeta(path); err != nil {
|
||||||
return ErrorResp(ctx, err, 500)
|
return ErrorResp(ctx, err, 500)
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user