12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- package service
- import (
- "fmt"
- "gin-vue-admin/global"
- "gin-vue-admin/model"
- "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 = global.GVA_DB.First(&model.ExaSimpleUploader{}, "identifier = ? AND is_done = ?", md5, true).RecordNotFound()
- return err, uploads, !isDone
- }
- func MergeFileMd5(md5 string, fileName string) (err error) {
- finishDir := "./finish/"
- dir := "./chunk/" + md5
-
- notFinish := global.GVA_DB.First(&model.ExaSimpleUploader{}, "identifier = ? AND is_done = ?", md5, true).RecordNotFound()
- if !notFinish {
- 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
- }
|