|
@@ -14,6 +14,7 @@ import (
|
|
|
"github.com/cockroachdb/errors"
|
|
"github.com/cockroachdb/errors"
|
|
|
gouuid "github.com/satori/go.uuid"
|
|
gouuid "github.com/satori/go.uuid"
|
|
|
"github.com/unknwon/com"
|
|
"github.com/unknwon/com"
|
|
|
|
|
+ "gorm.io/gorm"
|
|
|
|
|
|
|
|
"github.com/gogs/git-module"
|
|
"github.com/gogs/git-module"
|
|
|
|
|
|
|
@@ -441,7 +442,7 @@ func NewUpload(name string, buf []byte, file multipart.File) (_ *Upload, err err
|
|
|
return nil, errors.Newf("copy: %v", err)
|
|
return nil, errors.Newf("copy: %v", err)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- if _, err := x.Insert(upload); err != nil {
|
|
|
|
|
|
|
+ if err := db.Create(upload).Error; err != nil {
|
|
|
return nil, err
|
|
return nil, err
|
|
|
}
|
|
}
|
|
|
|
|
|
|
@@ -450,11 +451,12 @@ func NewUpload(name string, buf []byte, file multipart.File) (_ *Upload, err err
|
|
|
|
|
|
|
|
func GetUploadByUUID(uuid string) (*Upload, error) {
|
|
func GetUploadByUUID(uuid string) (*Upload, error) {
|
|
|
upload := &Upload{UUID: uuid}
|
|
upload := &Upload{UUID: uuid}
|
|
|
- has, err := x.Get(upload)
|
|
|
|
|
|
|
+ err := db.Where("uuid = ?", uuid).First(upload).Error
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
|
|
+ if errors.Is(err, gorm.ErrRecordNotFound) {
|
|
|
|
|
+ return nil, ErrUploadNotExist{0, uuid}
|
|
|
|
|
+ }
|
|
|
return nil, err
|
|
return nil, err
|
|
|
- } else if !has {
|
|
|
|
|
- return nil, ErrUploadNotExist{0, uuid}
|
|
|
|
|
}
|
|
}
|
|
|
return upload, nil
|
|
return upload, nil
|
|
|
}
|
|
}
|
|
@@ -466,7 +468,7 @@ func GetUploadsByUUIDs(uuids []string) ([]*Upload, error) {
|
|
|
|
|
|
|
|
// Silently drop invalid uuids.
|
|
// Silently drop invalid uuids.
|
|
|
uploads := make([]*Upload, 0, len(uuids))
|
|
uploads := make([]*Upload, 0, len(uuids))
|
|
|
- return uploads, x.In("uuid", uuids).Find(&uploads)
|
|
|
|
|
|
|
+ return uploads, db.Where("uuid IN ?", uuids).Find(&uploads).Error
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
func DeleteUploads(uploads ...*Upload) (err error) {
|
|
func DeleteUploads(uploads ...*Upload) (err error) {
|
|
@@ -474,32 +476,28 @@ func DeleteUploads(uploads ...*Upload) (err error) {
|
|
|
return nil
|
|
return nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- sess := x.NewSession()
|
|
|
|
|
- defer sess.Close()
|
|
|
|
|
- if err = sess.Begin(); err != nil {
|
|
|
|
|
- return err
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- ids := make([]int64, len(uploads))
|
|
|
|
|
- for i := 0; i < len(uploads); i++ {
|
|
|
|
|
- ids[i] = uploads[i].ID
|
|
|
|
|
- }
|
|
|
|
|
- if _, err = sess.In("id", ids).Delete(new(Upload)); err != nil {
|
|
|
|
|
- return errors.Newf("delete uploads: %v", err)
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- for _, upload := range uploads {
|
|
|
|
|
- localPath := upload.LocalPath()
|
|
|
|
|
- if !osutil.IsFile(localPath) {
|
|
|
|
|
- continue
|
|
|
|
|
|
|
+ return db.Transaction(func(tx *gorm.DB) error {
|
|
|
|
|
+ ids := make([]int64, len(uploads))
|
|
|
|
|
+ for i := 0; i < len(uploads); i++ {
|
|
|
|
|
+ ids[i] = uploads[i].ID
|
|
|
|
|
+ }
|
|
|
|
|
+ if err := tx.Where("id IN ?", ids).Delete(new(Upload)).Error; err != nil {
|
|
|
|
|
+ return errors.Newf("delete uploads: %v", err)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- if err := os.Remove(localPath); err != nil {
|
|
|
|
|
- return errors.Newf("remove upload: %v", err)
|
|
|
|
|
|
|
+ for _, upload := range uploads {
|
|
|
|
|
+ localPath := upload.LocalPath()
|
|
|
|
|
+ if !osutil.IsFile(localPath) {
|
|
|
|
|
+ continue
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ if err := os.Remove(localPath); err != nil {
|
|
|
|
|
+ return errors.Newf("remove upload: %v", err)
|
|
|
|
|
+ }
|
|
|
}
|
|
}
|
|
|
- }
|
|
|
|
|
|
|
|
|
|
- return sess.Commit()
|
|
|
|
|
|
|
+ return nil
|
|
|
|
|
+ })
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
func DeleteUpload(u *Upload) error {
|
|
func DeleteUpload(u *Upload) error {
|