123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372 |
- package controllers
- import (
- "archive/zip"
- "eta/eta_mobile/models"
- "eta/eta_mobile/services"
- "eta/eta_mobile/utils"
- "fmt"
- "github.com/kgiannakakis/mp3duration/src/mp3duration"
- "github.com/rdlucklib/rdluck_tools/http"
- "os"
- "path"
- "strconv"
- "strings"
- "time"
- )
- type VoiceController struct {
- BaseAuthController
- }
- func (this *VoiceController) Upload() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- f, h, err := this.GetFile("file")
- if err != nil {
- br.Msg = "获取资源信息失败"
- br.ErrMsg = "获取资源信息失败,Err:" + err.Error()
- return
- }
- reportId, err := this.GetInt("ReportId")
- if err != nil {
- br.Msg = "报告id异常"
- br.ErrMsg = "报告id异常,Err:" + err.Error()
- return
- }
- reportInfo, err := models.GetReportByReportId(reportId)
- if err != nil {
- br.Msg = "获取报告信息失败"
- br.ErrMsg = "获取报告信息失败,Err:" + err.Error()
- return
- }
- ext := path.Ext(h.Filename)
- dateDir := time.Now().Format("20060102")
- uploadDir := utils.STATIC_DIR + "hongze/" + dateDir
- err = os.MkdirAll(uploadDir, utils.DIR_MOD)
- if err != nil {
- br.Msg = "存储目录创建失败"
- br.ErrMsg = "存储目录创建失败,Err:" + err.Error()
- return
- }
- randStr := utils.GetRandStringNoSpecialChar(28)
- fileName := randStr + ext
- fpath := uploadDir + "/" + fileName
- defer f.Close()
- err = this.SaveToFile("file", fpath)
- if err != nil {
- br.Msg = "文件上传失败"
- br.ErrMsg = "文件上传失败,Err:" + err.Error()
- return
- }
- resourceUrl := ``
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ossClient := services.NewOssClient()
- if ossClient == nil {
- br.Msg = "上传失败"
- br.ErrMsg = "初始化OSS服务失败"
- return
- }
- resourceUrl, err = ossClient.UploadFile(fileName, fpath, "")
- if err != nil {
- br.Msg = "文件上传失败"
- br.ErrMsg = "文件上传失败,Err:" + err.Error()
- return
- }
- defer func() {
- os.Remove(fpath)
- }()
- item := new(models.Resource)
- item.ResourceUrl = resourceUrl
- item.ResourceType = 2
- item.CreateTime = time.Now()
- newId, err := models.AddResource(item)
- if err != nil {
- br.Msg = "资源上传失败"
- br.ErrMsg = "资源上传失败,Err:" + err.Error()
- return
- }
- var playSeconds float64
- playSeconds, err = mp3duration.Calculate(fpath)
- if playSeconds <= 0 {
- playSeconds, err = utils.GetVideoPlaySeconds(fpath)
- if err != nil {
- br.Msg = "获取音频时间失败"
- br.ErrMsg = "获取音频时间失败,Err:" + err.Error()
- return
- }
- }
- fileBody, err := os.ReadFile(fpath)
- videoSize := len(fileBody)
- sizeFloat := (float64(videoSize) / float64(1024)) / float64(1024)
- sizeStr := utils.SubFloatToFloatStr(sizeFloat, 2)
-
- {
- reportCreateTime, err := time.Parse(utils.FormatDateTime, reportInfo.CreateTime)
- if err != nil {
- br.Msg = "上传失败"
- br.ErrMsg = "上传失败,Err:" + err.Error()
- return
- }
- createTimeStr := reportCreateTime.Format("0102")
- videoName := reportInfo.Title + "(" + createTimeStr + ")"
- reportInfo.VideoUrl = resourceUrl
- reportInfo.VideoName = videoName
- reportInfo.VideoPlaySeconds = fmt.Sprint(playSeconds)
- reportInfo.VideoSize = sizeStr
- reportInfo.LastModifyAdminId = this.SysUser.AdminId
- reportInfo.LastModifyAdminName = this.SysUser.RealName
- reportInfo.VoiceGenerateType = 1
- reportInfo.ModifyTime = time.Now()
- err = reportInfo.UpdateReport([]string{"VideoUrl", "VideoName", "VideoPlaySeconds", "VideoSize", "LastModifyAdminId", "LastModifyAdminName", "VoiceGenerateType", "ModifyTime"})
- if err != nil {
- br.Msg = "上传失败"
- br.ErrMsg = "修改报告的音频信息失败,Err:" + err.Error()
- return
- }
- }
- resp := new(models.ResourceResp)
- resp.Id = newId
- resp.ResourceUrl = resourceUrl
- br.Msg = "上传成功"
- br.Ret = 200
- br.Success = true
- br.Data = resp
- return
- }
- type VoiceCommonController struct {
- BaseCommonController
- }
- func (this *VoiceCommonController) Download() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- reportId, err := this.GetInt("ReportId")
- if err != nil {
- br.Msg = "参数错误"
- br.ErrMsg = "获取,ReportId,Err:" + err.Error()
- return
- }
- reportInfo, err := models.GetReportById(reportId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取信息失败,Err:" + err.Error()
- return
- }
- savePath, fileName, err, errMsg := services.DownloadVoice(reportInfo)
-
- if savePath != `` {
- defer func() {
- os.Remove(savePath)
- }()
- }
- if err != nil {
- br.Msg = errMsg
- br.ErrMsg = "下载失败,Err:" + err.Error()
- return
- }
- if savePath != `` {
- this.Ctx.Output.Download(savePath, fileName)
- }
- br.Ret = 200
- br.Msg = "下载成功"
- br.Success = true
- return
- }
- func (this *VoiceCommonController) ReportChapterDownload() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- strChapterIds := this.GetString("ChapterIds")
- if strChapterIds == "" {
- br.Msg = "参数错误"
- return
- }
- chapterIds := make([]int, 0)
- chapterIdArr := strings.Split(strChapterIds, ",")
- for _, v := range chapterIdArr {
- id, e := strconv.Atoi(v)
- if e != nil {
- br.Msg = "参数有误"
- br.ErrMsg = "章节ID有误, Err: " + e.Error()
- return
- }
- chapterIds = append(chapterIds, id)
- }
- if len(chapterIds) == 0 {
- br.Msg = "参数有误"
- return
- }
- videoList, err := models.GetReportChapterVideoListByChapterIds(chapterIds)
- if err != nil {
- br.Msg = "获取音频列表失败"
- br.ErrMsg = "获取音频列表失败, Err: " + err.Error()
- return
- }
- if len(videoList) > 0 {
- reportId := videoList[0].ReportId
- reportInfo, err := models.GetReportById(reportId)
- if err != nil {
- br.Msg = "报告信息有误"
- br.ErrMsg = "获取报告信息失败, Err: " + err.Error()
- return
- }
-
- zipName := time.Now().Format(utils.FormatDateTimeUnSpace) + utils.GetRandString(5) + ".zip"
- savePath := zipName
- zipFile, err := os.Create(zipName)
- if err != nil {
- return
- }
- zipWriter := zip.NewWriter(zipFile)
-
- defer func() {
- if err != nil {
- zipWriter.Close()
- zipFile.Close()
- }
- os.Remove(savePath)
- }()
-
- for i := 0; i < len(videoList); i++ {
- item := videoList[i]
- if item.VideoName == "" || item.VideoUrl == "" {
- continue
- }
-
- ext := path.Ext(item.VideoUrl)
- ioWriter, err := zipWriter.Create(fmt.Sprintf("%s%s", item.VideoName, ext))
- if err != nil {
- if os.IsPermission(err) {
- fmt.Println("权限不足: ", err)
- return
- }
- return
- }
- var content []byte
- content, err = http.Get(item.VideoUrl)
- if err != nil {
- content = []byte("")
- }
- ioWriter.Write(content)
- }
-
- zipWriter.Close()
- zipFile.Close()
- this.Ctx.Output.Download(savePath, fmt.Sprintf("%s.zip", reportInfo.Title))
- }
- br.Ret = 200
- br.Msg = "下载成功"
- br.Success = true
- return
- }
|