12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- package service
- import (
- "errors"
- "fmt"
- "gin-vue-admin/global"
- "gin-vue-admin/model"
- "gorm.io/gorm"
- "io/ioutil"
- "os"
- "strconv"
- )
- func SaveChunk(uploader model.ExaSimpleUploader) (err error) {
- return global.GVA_DB.Create(uploader).Error
- }
- func CheckFileMd5(md5 string) (err error, uploads []model.ExaSimpleUploader, isDone bool) {
- err = global.GVA_DB.Find(&uploads, "identifier = ? AND is_done = ?", md5, false).Error
- isDone = errors.Is(global.GVA_DB.First(&model.ExaSimpleUploader{}, "identifier = ? AND is_done = ?", md5, true).Error, gorm.ErrRecordNotFound)
- return err, uploads, !isDone
- }
- func MergeFileMd5(md5 string, fileName string) (err error) {
- finishDir := "./finish/"
- dir := "./chunk/" + md5
-
- if !errors.Is(global.GVA_DB.First(&model.ExaSimpleUploader{}, "identifier = ? AND is_done = ?", md5, true).Error, gorm.ErrRecordNotFound) {
- return nil
- }
-
- rd, err := ioutil.ReadDir(dir)
- _ = os.MkdirAll(finishDir, os.ModePerm)
-
- fd, _ := os.OpenFile(finishDir+fileName, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0644)
-
- for k := range rd {
- content, _ := ioutil.ReadFile(dir + "/" + fileName + strconv.Itoa(k+1))
- _, err = fd.Write(content)
- if err != nil {
- _ = os.Remove(finishDir + fileName)
- }
- }
-
- defer fd.Close()
- if err != nil {
- return err
- }
- err = global.GVA_DB.Transaction(func(tx *gorm.DB) error {
-
- if err = tx.Delete(&model.ExaSimpleUploader{}, "identifier = ? AND is_done = ?", md5, false).Error; err != nil {
- fmt.Println(err)
- return err
- }
- data := model.ExaSimpleUploader{
- Identifier: md5,
- IsDone: true,
- FilePath: finishDir + fileName,
- Filename: fileName,
- }
-
- if err = tx.Create(&data).Error; err != nil {
- fmt.Println(err)
- return err
- }
- return nil
- })
- err = os.RemoveAll(dir)
- return err
- }
|