1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- 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
- }
-
- tx := global.GVA_DB.Begin()
-
- err = tx.Delete(&model.ExaSimpleUploader{}, "identifier = ? AND is_done = ?", md5, false).Error
-
- if err != nil {
- fmt.Println(err)
- tx.Rollback()
- }
- err = tx.Create(&model.ExaSimpleUploader{
- Identifier: md5,
- IsDone: true,
- FilePath: finishDir + fileName,
- Filename: fileName,
- }).Error
- if err != nil {
- fmt.Println(err)
- tx.Rollback()
- }
- tx.Commit()
-
- err = os.RemoveAll(dir)
- return
- }
|