Compare commits
	
		
			No commits in common. "fcb33cc71551fd0f035f5e69cb1c38ba2bb4b9e3" and "ef6d40cf81f57d753f5415d3556d83ad94f1a786" have entirely different histories.
		
	
	
		
			fcb33cc715
			...
			ef6d40cf81
		
	
		
| @ -4,20 +4,13 @@ import ( | |||||||
| 	apiCast "fonchain-fiee/api/cast" | 	apiCast "fonchain-fiee/api/cast" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type AccountInfo struct { |  | ||||||
| 	NickName  string `json:"nickName"` |  | ||||||
| 	AccountId string `json:"accountId"` |  | ||||||
| } |  | ||||||
| type ArtistAccount struct { | type ArtistAccount struct { | ||||||
| 	Index   string                                 `json:"index"` |  | ||||||
| 	Name    string                            `json:"name"` | 	Name    string                            `json:"name"` | ||||||
| 	SubNum  string                                 `json:"subNum"` | 	Account map[apiCast.PlatformIDENUM]string `json:"account"` | ||||||
| 	Account map[apiCast.PlatformIDENUM]AccountInfo `json:"account"` |  | ||||||
| } | } | ||||||
| type ArtistMedia struct { | type ArtistMedia struct { | ||||||
| 	Id        string `json:"id"` | 	Id        string `json:"id"` | ||||||
| 	Name      string `json:"name"` | 	Name      string `json:"name"` | ||||||
| 	SubNum    string `json:"subNum"` |  | ||||||
| 	Title     string `json:"title"` | 	Title     string `json:"title"` | ||||||
| 	Img       string `json:"img"` | 	Img       string `json:"img"` | ||||||
| 	Video     string `json:"video"` | 	Video     string `json:"video"` | ||||||
| @ -38,8 +31,6 @@ type ArtistVideoDetail struct { | |||||||
| 	Youtube    string `json:"youtube"` | 	Youtube    string `json:"youtube"` | ||||||
| 	Instagram  string `json:"instagram"` | 	Instagram  string `json:"instagram"` | ||||||
| 	TikTok     string `json:"tiktok"` | 	TikTok     string `json:"tiktok"` | ||||||
| 	ArtistId   string `json:"artistId"` |  | ||||||
| 	SubNum     string `json:"subNum"` |  | ||||||
| } | } | ||||||
| type CreateRequest struct { | type CreateRequest struct { | ||||||
| 	Type             string            `json:"Type"` | 	Type             string            `json:"Type"` | ||||||
|  | |||||||
| @ -13,7 +13,6 @@ import ( | |||||||
| 	modelCast "fonchain-fiee/pkg/model/cast" | 	modelCast "fonchain-fiee/pkg/model/cast" | ||||||
| 	"fonchain-fiee/pkg/service" | 	"fonchain-fiee/pkg/service" | ||||||
| 	"fonchain-fiee/pkg/service/cast" | 	"fonchain-fiee/pkg/service/cast" | ||||||
| 	"fonchain-fiee/pkg/service/upload" |  | ||||||
| 	"log" | 	"log" | ||||||
| 	"os" | 	"os" | ||||||
| 	"path/filepath" | 	"path/filepath" | ||||||
| @ -24,9 +23,11 @@ import ( | |||||||
| 	"github.com/xuri/excelize/v2" | 	"github.com/xuri/excelize/v2" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | type artu struct { | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func ImportBind(c *gin.Context) { | func ImportBind(c *gin.Context) { | ||||||
| 	var failedRecords []FailedRecord | 	var failedRecords []FailedRecord | ||||||
| 	var record []*apiCast.UpdateMediaAccountReq |  | ||||||
| 	// 1. 上传文件
 | 	// 1. 上传文件
 | ||||||
| 	excelFile, err := c.FormFile("excel") | 	excelFile, err := c.FormFile("excel") | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| @ -58,7 +59,6 @@ func ImportBind(c *gin.Context) { | |||||||
| 			} | 			} | ||||||
| 			res, err := service.AccountFieeProvider.UserList(context.Background(), &account.UserListRequest{ | 			res, err := service.AccountFieeProvider.UserList(context.Background(), &account.UserListRequest{ | ||||||
| 				Name: artist.Name, | 				Name: artist.Name, | ||||||
| 				SubNum: artist.SubNum, |  | ||||||
| 			}) | 			}) | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
| 				failedRecords = append(failedRecords, FailedRecord{ | 				failedRecords = append(failedRecords, FailedRecord{ | ||||||
| @ -68,14 +68,6 @@ func ImportBind(c *gin.Context) { | |||||||
| 				log.Printf(fmt.Sprintf("获取用户信息失败: %s", err.Error())) | 				log.Printf(fmt.Sprintf("获取用户信息失败: %s", err.Error())) | ||||||
| 				continue | 				continue | ||||||
| 			} | 			} | ||||||
| 			if res.Count == 0 { |  | ||||||
| 				failedRecords = append(failedRecords, FailedRecord{ |  | ||||||
| 					Name: artist.Name, |  | ||||||
| 					Msg:  "未找到用户信息", |  | ||||||
| 				}) |  | ||||||
| 				log.Printf("未找到用户信息") |  | ||||||
| 				continue |  | ||||||
| 			} |  | ||||||
| 			if res != nil && len(res.UserList) > 0 { | 			if res != nil && len(res.UserList) > 0 { | ||||||
| 				var infoResp *account.UserInfoResponse | 				var infoResp *account.UserInfoResponse | ||||||
| 				var err error | 				var err error | ||||||
| @ -127,11 +119,11 @@ func ImportBind(c *gin.Context) { | |||||||
| 					log.Printf(fmt.Sprintf("增加账户数量失败: %s", err.Error())) | 					log.Printf(fmt.Sprintf("增加账户数量失败: %s", err.Error())) | ||||||
| 					continue | 					continue | ||||||
| 				} | 				} | ||||||
| 				mediaAccountInfoRes, err := service.CastProvider.UpdateMediaAccount(c, &apiCast.UpdateMediaAccountReq{ | 				_, err = service.CastProvider.UpdateMediaAccount(c, &apiCast.UpdateMediaAccountReq{ | ||||||
| 					ArtistUuid:          strconv.FormatUint(res.UserList[0].Id, 10), | 					ArtistUuid:          strconv.FormatUint(res.UserList[0].Id, 10), | ||||||
| 					PlatformID:          accountType, | 					PlatformID:          accountType, | ||||||
| 					PlatformUserName:    accountInfo.NickName, | 					PlatformUserName:    artist.Name, | ||||||
| 					PlatformUserID:      accountInfo.AccountId, | 					PlatformUserID:      accountInfo, | ||||||
| 					ArtistName:          infoResp.Name, | 					ArtistName:          infoResp.Name, | ||||||
| 					ArtistPhone:         infoResp.TelNum, | 					ArtistPhone:         infoResp.TelNum, | ||||||
| 					ArtistPhoneAreaCode: infoResp.TelAreaCode, | 					ArtistPhoneAreaCode: infoResp.TelAreaCode, | ||||||
| @ -142,39 +134,23 @@ func ImportBind(c *gin.Context) { | |||||||
| 						Msg:  fmt.Sprintf("绑定账户信息失败: %s", err.Error()), | 						Msg:  fmt.Sprintf("绑定账户信息失败: %s", err.Error()), | ||||||
| 					}) | 					}) | ||||||
| 					log.Printf(fmt.Sprintf("绑定账户信息失败: %s", err.Error())) | 					log.Printf(fmt.Sprintf("绑定账户信息失败: %s", err.Error())) | ||||||
| 					_, err1 := service.BundleProvider.AddBundleBalance(context.Background(), &bundle.AddBundleBalanceReq{ | 					_, err = service.BundleProvider.AddBundleBalance(context.Background(), &bundle.AddBundleBalanceReq{ | ||||||
| 						UserId:                   int32(res.UserList[0].Id), | 						UserId:                   int32(res.UserList[0].Id), | ||||||
| 						AccountConsumptionNumber: -1, | 						AccountConsumptionNumber: -1, | ||||||
| 					}) | 					}) | ||||||
| 					if err1 != nil { |  | ||||||
| 					failedRecords = append(failedRecords, FailedRecord{ | 					failedRecords = append(failedRecords, FailedRecord{ | ||||||
| 						Name: artist.Name, | 						Name: artist.Name, | ||||||
| 							Msg:  fmt.Sprintf("绑定失败后减少余额失败: %s", err1.Error()), | 						Msg:  fmt.Sprintf("绑定失败后减少余额失败: %s", err.Error()), | ||||||
| 					}) | 					}) | ||||||
| 						log.Println(fmt.Sprintf("绑定失败后减少余额失败: %s", err1.Error()), errors.New(e.GetMsg(e.InvalidParams))) | 					log.Println(fmt.Sprintf("绑定失败后减少余额失败: %s", err.Error()), errors.New(e.GetMsg(e.InvalidParams))) | ||||||
| 					} |  | ||||||
| 					continue | 					continue | ||||||
| 				} | 
 | ||||||
| 				record = append(record, &apiCast.UpdateMediaAccountReq{ | 				} | ||||||
| 					MediaAccountUuid:    mediaAccountInfoRes.MediaAccountUuid, |  | ||||||
| 					ArtistUuid:          strconv.FormatUint(res.UserList[0].Id, 10), |  | ||||||
| 					PlatformID:          accountType, |  | ||||||
| 					PlatformUserName:    accountInfo.NickName, |  | ||||||
| 					PlatformUserID:      accountInfo.AccountId, |  | ||||||
| 					ArtistName:          infoResp.Name, |  | ||||||
| 					ArtistPhone:         infoResp.TelNum, |  | ||||||
| 					ArtistPhoneAreaCode: infoResp.TelAreaCode, |  | ||||||
| 				}) |  | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	excelUrl, err := exportBindingRecordsToExcel(record) |  | ||||||
| 	// 5. 返回结果
 | 	// 5. 返回结果
 | ||||||
| 	service.Success(c, map[string]interface{}{ | 	service.Success(c, failedRecords) | ||||||
| 		"excelUrl":      excelUrl, |  | ||||||
| 		"failedRecords": failedRecords, |  | ||||||
| 		"accountInfo":   artists, |  | ||||||
| 	}) |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func readArtistAccountInfo(excelPath string) ([]ArtistAccount, error) { | func readArtistAccountInfo(excelPath string) ([]ArtistAccount, error) { | ||||||
| @ -195,96 +171,29 @@ func readArtistAccountInfo(excelPath string) ([]ArtistAccount, error) { | |||||||
| 		if i == 0 || len(row) < 2 { | 		if i == 0 || len(row) < 2 { | ||||||
| 			continue | 			continue | ||||||
| 		} | 		} | ||||||
|  | 		if i == 58 { | ||||||
|  | 			break | ||||||
|  | 		} | ||||||
| 		tmp := ArtistAccount{ | 		tmp := ArtistAccount{ | ||||||
| 			Account: make(map[apiCast.PlatformIDENUM]AccountInfo), | 			Account: make(map[apiCast.PlatformIDENUM]string), | ||||||
| 			Index:   strings.TrimSpace(row[0]), |  | ||||||
| 			Name:    strings.TrimSpace(row[1]), | 			Name:    strings.TrimSpace(row[1]), | ||||||
| 			SubNum:  strings.TrimSpace(row[2]), |  | ||||||
| 		} | 		} | ||||||
| 		youtubeId, _ := f.GetCellValue(sheetName, fmt.Sprintf("D%d", i+1)) | 		youtube, _ := f.GetCellValue(sheetName, fmt.Sprintf("C%d", i+1)) | ||||||
| 		youtubeNickName, _ := f.GetCellValue(sheetName, fmt.Sprintf("E%d", i+1)) | 		if youtube != "" { | ||||||
| 		youtube := AccountInfo{ | 			tmp.Account[2] = strings.TrimSpace(youtube) | ||||||
| 			AccountId: strings.TrimSpace(youtubeId), |  | ||||||
| 			NickName:  strings.TrimSpace(youtubeNickName), |  | ||||||
| 		} |  | ||||||
| 		tmp.Account[2] = youtube |  | ||||||
| 
 | 
 | ||||||
| 		insId, _ := f.GetCellValue(sheetName, fmt.Sprintf("F%d", i+1)) |  | ||||||
| 		insNickName, _ := f.GetCellValue(sheetName, fmt.Sprintf("G%d", i+1)) |  | ||||||
| 		ins := AccountInfo{ |  | ||||||
| 			AccountId: strings.TrimSpace(insId), |  | ||||||
| 			NickName:  strings.TrimSpace(insNickName), |  | ||||||
| 		} | 		} | ||||||
| 		tmp.Account[3] = ins | 		ins, _ := f.GetCellValue(sheetName, fmt.Sprintf("D%d", i+1)) | ||||||
|  | 		if ins != "" { | ||||||
|  | 			tmp.Account[3] = strings.TrimSpace(ins) | ||||||
| 
 | 
 | ||||||
| 		tiktokId, _ := f.GetCellValue(sheetName, fmt.Sprintf("H%d", i+1)) |  | ||||||
| 		tiktokNiackName, _ := f.GetCellValue(sheetName, fmt.Sprintf("I%d", i+1)) |  | ||||||
| 		tiktok := AccountInfo{ |  | ||||||
| 			AccountId: strings.TrimSpace(tiktokId), |  | ||||||
| 			NickName:  strings.TrimSpace(tiktokNiackName), |  | ||||||
| 		} | 		} | ||||||
| 		tmp.Account[1] = tiktok | 		tiktok, _ := f.GetCellValue(sheetName, fmt.Sprintf("E%d", i+1)) | ||||||
|  | 		if tiktok != "" { | ||||||
|  | 			tmp.Account[1] = strings.TrimSpace(tiktok) | ||||||
| 
 | 
 | ||||||
|  | 		} | ||||||
| 		artists = append(artists, tmp) | 		artists = append(artists, tmp) | ||||||
| 	} | 	} | ||||||
| 	return artists, nil | 	return artists, nil | ||||||
| } | } | ||||||
| func exportBindingRecordsToExcel(records []*apiCast.UpdateMediaAccountReq) (string, error) { |  | ||||||
| 	fileDir := "./runtime/import/" |  | ||||||
| 	filename := "绑定账户记录.xlsx" |  | ||||||
| 	filePath := filepath.Join(fileDir, filename) |  | ||||||
| 
 |  | ||||||
| 	// 创建目录
 |  | ||||||
| 	_ = os.MkdirAll(fileDir, os.ModePerm) |  | ||||||
| 
 |  | ||||||
| 	var f *excelize.File |  | ||||||
| 	sheet := "Sheet1" |  | ||||||
| 
 |  | ||||||
| 	// 判断文件是否存在
 |  | ||||||
| 	if _, err := os.Stat(filePath); os.IsNotExist(err) { |  | ||||||
| 		f = excelize.NewFile() |  | ||||||
| 		f.NewSheet(sheet) |  | ||||||
| 		headers := []string{"序号", "MediaAccountUuid", "ArtistUuid", "PlatformID", "PlatformUserName", "PlatformUserID", "ArtistName", "ArtistPhone", "ArtistPhoneAreaCode"} |  | ||||||
| 		for col, h := range headers { |  | ||||||
| 			_ = f.SetCellValue(sheet, fmt.Sprintf("%c1", 'A'+col), h) |  | ||||||
| 		} |  | ||||||
| 	} else { |  | ||||||
| 		var err error |  | ||||||
| 		f, err = excelize.OpenFile(filePath) |  | ||||||
| 		if err != nil { |  | ||||||
| 			return "", err |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	// 找到最后一行
 |  | ||||||
| 	rows, err := f.GetRows(sheet) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return "", err |  | ||||||
| 	} |  | ||||||
| 	startRow := len(rows) + 1 |  | ||||||
| 
 |  | ||||||
| 	// 写入数据
 |  | ||||||
| 	for i, r := range records { |  | ||||||
| 		row := startRow + i |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("A%d", row), i+1) |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("B%d", row), r.MediaAccountUuid) |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("C%d", row), r.ArtistUuid) |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("D%d", row), r.PlatformID) |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("E%d", row), r.PlatformUserName) |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("F%d", row), r.PlatformUserID) |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("G%d", row), r.ArtistName) |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("H%d", row), r.ArtistPhone) |  | ||||||
| 		_ = f.SetCellValue(sheet, fmt.Sprintf("I%d", row), r.ArtistPhoneAreaCode) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	// 保存
 |  | ||||||
| 	if err = f.SaveAs(filePath); err != nil { |  | ||||||
| 		return "", err |  | ||||||
| 	} |  | ||||||
| 	// 上传
 |  | ||||||
| 	excelUrl, err := upload.PutBos(filePath, "excel", true) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return "", err |  | ||||||
| 	} |  | ||||||
| 	return excelUrl, nil |  | ||||||
| } |  | ||||||
|  | |||||||
| @ -2,47 +2,38 @@ package imports | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
|  | 	"errors" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	account "fonchain-fiee/api/accountFiee" | 	account "fonchain-fiee/api/accountFiee" | ||||||
| 	"fonchain-fiee/api/bundle" | 	"fonchain-fiee/api/bundle" | ||||||
| 	apiCast "fonchain-fiee/api/cast" | 	apiCast "fonchain-fiee/api/cast" | ||||||
| 	"fonchain-fiee/pkg/service" | 	"fonchain-fiee/pkg/service" | ||||||
|  | 	"fonchain-fiee/pkg/service/cast" | ||||||
| 	"log" | 	"log" | ||||||
| 	"os" |  | ||||||
| 	"path/filepath" |  | ||||||
| 	"strings" |  | ||||||
| 
 | 
 | ||||||
| 	"github.com/gin-gonic/gin" | 	"github.com/gin-gonic/gin" | ||||||
| 	"github.com/xuri/excelize/v2" |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func WorkConfirm(c *gin.Context) { // 确认作品并扣除余量
 | func WorkConfirm(c *gin.Context) { // 确认作品并扣除余量
 | ||||||
| 	excelFile, err := c.FormFile("excel") | 	newCtx := cast.NewCtxWithUserInfo(c) | ||||||
|  | 	list, err := service.CastProvider.WorkList(newCtx, &apiCast.WorkListReq{ | ||||||
|  | 		WorkStatus: 4, | ||||||
|  | 		Page:       1, | ||||||
|  | 		PageSize:   999, | ||||||
|  | 	}) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		c.JSON(400, gin.H{"error": "缺少 Excel 文件 excel"}) | 		service.Error(c, err) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	// 2. 保存临时文件
 | 	if len(list.Data) == 0 { | ||||||
| 	tempDir := "tmp" | 		service.Error(c, errors.New("没有待确认的作品")) | ||||||
| 	os.MkdirAll(tempDir, 0755) |  | ||||||
| 	excelPath := filepath.Join(tempDir, "artists.xlsx") |  | ||||||
| 	if err = c.SaveUploadedFile(excelFile, excelPath); err != nil { |  | ||||||
| 		c.JSON(500, gin.H{"error": "保存 Excel 失败"}) |  | ||||||
| 		return |  | ||||||
| 	} |  | ||||||
| 	defer os.RemoveAll(tempDir) |  | ||||||
| 	// 3. 读取 Excel 视频发布信息
 |  | ||||||
| 	artists, err := readCastWorkList(excelPath) |  | ||||||
| 	if err != nil { |  | ||||||
| 		c.JSON(500, gin.H{"error": "读取 Excel 失败"}) |  | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	//遍历更新状态
 | 	//遍历更新状态
 | ||||||
| 	var failedRecords []FailedRecord | 	var failedRecords []FailedRecord | ||||||
| 	for _, v := range artists { | 	for _, v := range list.Data { | ||||||
| 		res, err := service.AccountFieeProvider.UserList(context.Background(), &account.UserListRequest{ | 		res, err := service.AccountFieeProvider.UserList(context.Background(), &account.UserListRequest{ | ||||||
| 			Name: v.ArtistName, | 			Name: v.ArtistName, | ||||||
| 			SubNum: v.SubNum, |  | ||||||
| 		}) | 		}) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			failedRecords = append(failedRecords, FailedRecord{ | 			failedRecords = append(failedRecords, FailedRecord{ | ||||||
| @ -85,30 +76,3 @@ func WorkConfirm(c *gin.Context) { // 确认作品并扣除余量 | |||||||
| 	} | 	} | ||||||
| 	service.Success(c, failedRecords) | 	service.Success(c, failedRecords) | ||||||
| } | } | ||||||
| func readCastWorkList(excelPath string) ([]ArtistVideoDetail, error) { |  | ||||||
| 	f, err := excelize.OpenFile(excelPath) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, err |  | ||||||
| 	} |  | ||||||
| 	defer f.Close() |  | ||||||
| 
 |  | ||||||
| 	sheetName := f.GetSheetName(0) |  | ||||||
| 	rows, err := f.GetRows(sheetName) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, err |  | ||||||
| 	} |  | ||||||
| 	log.Println("start read excel...") |  | ||||||
| 	var artistVideos []ArtistVideoDetail |  | ||||||
| 	for i, row := range rows { |  | ||||||
| 		if i == 0 || len(row) < 2 { |  | ||||||
| 			continue |  | ||||||
| 		} |  | ||||||
| 		tmp := ArtistVideoDetail{ |  | ||||||
| 			ArtistName: strings.TrimSpace(row[1]), |  | ||||||
| 			WorkUuid:   strings.TrimSpace(row[3]), |  | ||||||
| 			SubNum:     strings.TrimSpace(row[7]), |  | ||||||
| 		} |  | ||||||
| 		artistVideos = append(artistVideos, tmp) |  | ||||||
| 	} |  | ||||||
| 	return artistVideos, nil |  | ||||||
| } |  | ||||||
|  | |||||||
| @ -1,9 +1,12 @@ | |||||||
| package imports | package imports | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"bytes" | ||||||
| 	"context" | 	"context" | ||||||
|  | 	"encoding/json" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"fonchain-fiee/api/accountFiee" | 	"fonchain-fiee/api/accountFiee" | ||||||
|  | 	"fonchain-fiee/api/bundle" | ||||||
| 	apiCast "fonchain-fiee/api/cast" | 	apiCast "fonchain-fiee/api/cast" | ||||||
| 	"fonchain-fiee/api/files" | 	"fonchain-fiee/api/files" | ||||||
| 	"fonchain-fiee/pkg/config" | 	"fonchain-fiee/pkg/config" | ||||||
| @ -12,7 +15,9 @@ import ( | |||||||
| 	"fonchain-fiee/pkg/service" | 	"fonchain-fiee/pkg/service" | ||||||
| 	"fonchain-fiee/pkg/service/cast" | 	"fonchain-fiee/pkg/service/cast" | ||||||
| 	"fonchain-fiee/pkg/service/upload" | 	"fonchain-fiee/pkg/service/upload" | ||||||
|  | 	"io" | ||||||
| 	"log" | 	"log" | ||||||
|  | 	"net/http" | ||||||
| 	"os" | 	"os" | ||||||
| 	"path/filepath" | 	"path/filepath" | ||||||
| 	"strconv" | 	"strconv" | ||||||
| @ -92,7 +97,6 @@ func ImportPublish(c *gin.Context) { | |||||||
| 		var err error | 		var err error | ||||||
| 		list, err := service.AccountFieeProvider.UserList(context.Background(), &accountFiee.UserListRequest{ | 		list, err := service.AccountFieeProvider.UserList(context.Background(), &accountFiee.UserListRequest{ | ||||||
| 			Name: artist.Name, | 			Name: artist.Name, | ||||||
| 			SubNum: artist.SubNum, |  | ||||||
| 		}) | 		}) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			failedRecords = append(failedRecords, FailedRecord{ | 			failedRecords = append(failedRecords, FailedRecord{ | ||||||
| @ -211,7 +215,6 @@ func ImportPublish(c *gin.Context) { | |||||||
| 		artistResp = append(artistResp, ArtistVideoDetail{ | 		artistResp = append(artistResp, ArtistVideoDetail{ | ||||||
| 			Id:         artist.Id, | 			Id:         artist.Id, | ||||||
| 			ArtistName: artist.Name, | 			ArtistName: artist.Name, | ||||||
| 			SubNum:     artist.SubNum, |  | ||||||
| 			Title:      artist.Title, | 			Title:      artist.Title, | ||||||
| 			WorkUuid:   resp.WorkUuid, | 			WorkUuid:   resp.WorkUuid, | ||||||
| 			Youtube:    artist.Youtube, | 			Youtube:    artist.Youtube, | ||||||
| @ -219,7 +222,7 @@ func ImportPublish(c *gin.Context) { | |||||||
| 			TikTok:     artist.TikTok, | 			TikTok:     artist.TikTok, | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 	excelUrl, err := exportPublishRecordsToExcel(artistResp) | 	excelUrl, err := exportRecordsToExcel(artistResp) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		service.Error(c, err) | 		service.Error(c, err) | ||||||
| 		return | 		return | ||||||
| @ -277,10 +280,6 @@ func readArtistVideoInfo(excelPath, unzipPath string) ([]ArtistMedia, error) { | |||||||
| 		if tiktok != "" { | 		if tiktok != "" { | ||||||
| 			tiktok = strings.TrimSpace(tiktok) | 			tiktok = strings.TrimSpace(tiktok) | ||||||
| 		} | 		} | ||||||
| 		subNum, _ := f.GetCellValue(sheetName, fmt.Sprintf("G%d", i+1)) |  | ||||||
| 		if subNum != "" { |  | ||||||
| 			subNum = strings.TrimSpace(subNum) |  | ||||||
| 		} |  | ||||||
| 		artists = append(artists, ArtistMedia{ | 		artists = append(artists, ArtistMedia{ | ||||||
| 			Id:        id, | 			Id:        id, | ||||||
| 			Name:      artistName, | 			Name:      artistName, | ||||||
| @ -288,7 +287,6 @@ func readArtistVideoInfo(excelPath, unzipPath string) ([]ArtistMedia, error) { | |||||||
| 			Youtube:   youtube, | 			Youtube:   youtube, | ||||||
| 			Instagram: instagram, | 			Instagram: instagram, | ||||||
| 			TikTok:    tiktok, | 			TikTok:    tiktok, | ||||||
| 			SubNum:    subNum, |  | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 	artists, err = matchArtistMedia(artists, unzipPath) | 	artists, err = matchArtistMedia(artists, unzipPath) | ||||||
| @ -299,19 +297,12 @@ func matchArtistMedia(artists []ArtistMedia, unzipPath string) ([]ArtistMedia, e | |||||||
| 	var res []ArtistMedia | 	var res []ArtistMedia | ||||||
| 	for _, artist := range artists { | 	for _, artist := range artists { | ||||||
| 		oldImgPath := fmt.Sprintf("%s/%s/%s.jpg", unzipPath, artist.Name, artist.Id) | 		oldImgPath := fmt.Sprintf("%s/%s/%s.jpg", unzipPath, artist.Name, artist.Id) | ||||||
|  | 		oldVideoPath := fmt.Sprintf("%s/%s/%s.mp4", unzipPath, artist.Name, artist.Id) | ||||||
| 		// 检查源文件是否存在
 | 		// 检查源文件是否存在
 | ||||||
| 		if _, err = os.Stat(oldImgPath); os.IsNotExist(err) { | 		if _, err = os.Stat(oldImgPath); os.IsNotExist(err) { | ||||||
| 			continue | 			continue | ||||||
| 		} | 		} | ||||||
| 		var oldVideoPath string | 		if _, err = os.Stat(oldVideoPath); os.IsNotExist(err) { | ||||||
| 		for _, ext := range []string{".mp4", ".mov"} { |  | ||||||
| 			p := fmt.Sprintf("%s/%s/%s%s", unzipPath, artist.Name, artist.Id, ext) |  | ||||||
| 			if _, err = os.Stat(p); err == nil { |  | ||||||
| 				oldVideoPath = p |  | ||||||
| 				break |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		if oldVideoPath == "" { |  | ||||||
| 			continue | 			continue | ||||||
| 		} | 		} | ||||||
| 		baseDir := filepath.Join(unzipPath, artist.Name) | 		baseDir := filepath.Join(unzipPath, artist.Name) | ||||||
| @ -364,7 +355,6 @@ func matchArtistMedia(artists []ArtistMedia, unzipPath string) ([]ArtistMedia, e | |||||||
| 		tmp.Img = imgUrl | 		tmp.Img = imgUrl | ||||||
| 		//tmp.Video = filepath.ToSlash(videoPath)
 | 		//tmp.Video = filepath.ToSlash(videoPath)
 | ||||||
| 		tmp.Video = videoUrl | 		tmp.Video = videoUrl | ||||||
| 		tmp.SubNum = artist.SubNum |  | ||||||
| 		res = append(res, tmp) | 		res = append(res, tmp) | ||||||
| 	} | 	} | ||||||
| 	return res, nil | 	return res, nil | ||||||
| @ -402,71 +392,148 @@ func UploadToAnotherService(ctx context.Context, fileData []byte, path string) e | |||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| func exportPublishRecordsToExcel(artistInfos []ArtistVideoDetail) (string, error) { | func exportRecordsToExcel(artistInfos []ArtistVideoDetail) (string, error) { | ||||||
| 	fileDir := "./runtime/import/" | 	f := excelize.NewFile() | ||||||
| 	filename := "画家视频详情记录0922.xlsx" |  | ||||||
| 	filePath := filepath.Join(fileDir, filename) |  | ||||||
| 
 |  | ||||||
| 	_ = os.MkdirAll(fileDir, os.ModePerm) |  | ||||||
| 
 |  | ||||||
| 	var f *excelize.File |  | ||||||
| 	sheet := "Sheet1" | 	sheet := "Sheet1" | ||||||
| 
 | 	f.NewSheet(sheet) | ||||||
| 	// 判断文件是否存在
 |  | ||||||
| 	if _, err := os.Stat(filePath); os.IsNotExist(err) { |  | ||||||
| 		// 文件不存在,新建文件和Sheet
 |  | ||||||
| 		f = excelize.NewFile() |  | ||||||
| 		f.SetSheetName(f.GetSheetName(0), sheet) |  | ||||||
| 
 | 
 | ||||||
| 	// 写表头
 | 	// 写表头
 | ||||||
| 		headers := []string{"序号", "画家名", "标题", "uuid", "youtube", "instagram", "tiktok", "用户编号"} | 	headers := []string{"序号", "画家名", "标题", "uuid", "youtube", "instagram", "tiktok"} | ||||||
|  | 
 | ||||||
| 	for col, h := range headers { | 	for col, h := range headers { | ||||||
| 			_ = f.SetCellValue(sheet, string('A'+col)+"1", h) | 		_ = f.SetCellValue(sheet, string(rune('A'+col))+"1", h) | ||||||
| 		} |  | ||||||
| 	} else { |  | ||||||
| 		// 文件存在,打开
 |  | ||||||
| 		var err error |  | ||||||
| 		f, err = excelize.OpenFile(filePath) |  | ||||||
| 		if err != nil { |  | ||||||
| 			return "", err |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	// 找到最后一行,追加数据
 |  | ||||||
| 	rows, err := f.GetRows(sheet) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return "", err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	// 计算下一行,从表头之后开始
 |  | ||||||
| 	startRow := len(rows) + 1 |  | ||||||
| 	if startRow == 1 { |  | ||||||
| 		startRow = 2 // 文件新建或没有数据,从第2行开始
 |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// 写数据
 | 	// 写数据
 | ||||||
| 	for i, artistInfo := range artistInfos { | 	for i, artistInfo := range artistInfos { | ||||||
| 		row := startRow + i | 		row := i + 2 | ||||||
| 		_ = f.SetCellValue(sheet, "A"+strconv.Itoa(row), row-1) // 序号连续
 | 		_ = f.SetCellValue(sheet, "A"+strconv.Itoa(row), artistInfo.Id) | ||||||
| 		_ = f.SetCellValue(sheet, "B"+strconv.Itoa(row), artistInfo.ArtistName) | 		_ = f.SetCellValue(sheet, "B"+strconv.Itoa(row), artistInfo.ArtistName) | ||||||
| 		_ = f.SetCellValue(sheet, "C"+strconv.Itoa(row), artistInfo.Title) | 		_ = f.SetCellValue(sheet, "C"+strconv.Itoa(row), artistInfo.Title) | ||||||
| 		_ = f.SetCellValue(sheet, "D"+strconv.Itoa(row), artistInfo.WorkUuid) | 		_ = f.SetCellValue(sheet, "D"+strconv.Itoa(row), artistInfo.WorkUuid) | ||||||
| 		_ = f.SetCellValue(sheet, "E"+strconv.Itoa(row), artistInfo.Youtube) | 		_ = f.SetCellValue(sheet, "E"+strconv.Itoa(row), artistInfo.Youtube) | ||||||
| 		_ = f.SetCellValue(sheet, "F"+strconv.Itoa(row), artistInfo.Instagram) | 		_ = f.SetCellValue(sheet, "F"+strconv.Itoa(row), artistInfo.Instagram) | ||||||
| 		_ = f.SetCellValue(sheet, "G"+strconv.Itoa(row), artistInfo.TikTok) | 		_ = f.SetCellValue(sheet, "G"+strconv.Itoa(row), artistInfo.TikTok) | ||||||
| 		_ = f.SetCellValue(sheet, "H"+strconv.Itoa(row), artistInfo.SubNum) |  | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	// 保存文件
 | 	// 保存文件
 | ||||||
| 	if err = f.SaveAs(filePath); err != nil { | 	filename := "画家视频详情记录.xlsx" | ||||||
| 		fmt.Println("saveAs err: ", err) | 	fileDir := "./runtime/import/" // 自定义目录
 | ||||||
|  | 	_ = os.MkdirAll(fileDir, os.ModePerm) | ||||||
|  | 	filePath := filepath.Join(fileDir, filename) | ||||||
|  | 	if err := f.SaveAs(filePath); err != nil { | ||||||
| 		return "", err | 		return "", err | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	// 上传
 |  | ||||||
| 	excelUrl, err := upload.PutBos(filePath, "excel", true) | 	excelUrl, err := upload.PutBos(filePath, "excel", true) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return "", err | 		return "", err | ||||||
|  | 
 | ||||||
| 	} | 	} | ||||||
| 	return excelUrl, nil | 	return excelUrl, nil | ||||||
| } | } | ||||||
|  | func updateApproval(ctx *gin.Context, artistId uint64, workUuid string, accountInfos []*apiCast.MediaUserInfo, videoUrl, imgUrl, title string) error { | ||||||
|  | 	var publishAccounts []PublishAccount | ||||||
|  | 	var publishPlatformIds []int32 | ||||||
|  | 
 | ||||||
|  | 	for _, v := range accountInfos { | ||||||
|  | 		publishAccounts = append(publishAccounts, PublishAccount{ | ||||||
|  | 			AccountName: v.PlatformUserName, | ||||||
|  | 			AccountID:   v.MediaAccountUuid, | ||||||
|  | 		}) | ||||||
|  | 		publishPlatformIds = append(publishPlatformIds, int32(v.PlatformID)) | ||||||
|  | 	} | ||||||
|  | 	var req CreateRequest | ||||||
|  | 	var url string | ||||||
|  | 	saasPublishVideo := &SaasPublishVideo{ | ||||||
|  | 		Title:              title, | ||||||
|  | 		Describe:           title, | ||||||
|  | 		IsYoutubeSee:       1, | ||||||
|  | 		IsTiktokScreen:     1, | ||||||
|  | 		IsTiktokComment:    1, | ||||||
|  | 		IsTiktokQuote:      1, | ||||||
|  | 		IsTiktokAiGenerate: 1, | ||||||
|  | 		Cover:              imgUrl, | ||||||
|  | 		PlatformIds:        publishPlatformIds, | ||||||
|  | 		PublishAccounts:    publishAccounts, | ||||||
|  | 		Videos: []Video{ | ||||||
|  | 			{ | ||||||
|  | 				VideoAddress:   videoUrl, | ||||||
|  | 				VideoThumbnail: imgUrl, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  | 	if config.AppMode == "prod" { | ||||||
|  | 		url = "https://erp.fonchain.com/approval/v2/create" | ||||||
|  | 		req = CreateRequest{ | ||||||
|  | 			Type:             "SaasPublishVideo", | ||||||
|  | 			DepartmentID:     3, | ||||||
|  | 			Domain:           "7bfa3942cceb20389822af7b57c5798e", | ||||||
|  | 			MenuType:         2, | ||||||
|  | 			SaasPublishVideo: saasPublishVideo, | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		url = "http://114.218.158.24:9020/approval/v2/create" | ||||||
|  | 		req = CreateRequest{ | ||||||
|  | 			Type:             "SaasPublishVideo", | ||||||
|  | 			DepartmentID:     3, | ||||||
|  | 			Domain:           "7bfa3942cceb20389822af7b57c5798e", | ||||||
|  | 			MenuType:         2, | ||||||
|  | 			SaasPublishVideo: saasPublishVideo, | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	jsonBytes, err := json.Marshal(req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | 	res, err := http.Post(url, "application/json", bytes.NewBuffer(jsonBytes)) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	defer res.Body.Close() | ||||||
|  | 	responseBodyBytes, err := io.ReadAll(res.Body) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	var apiResp APIResponse | ||||||
|  | 	err = json.Unmarshal(responseBodyBytes, &apiResp) | ||||||
|  | 	if err != nil { | ||||||
|  | 		// 处理错误
 | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	fmt.Println("拿到审批ID:", apiResp.Data.ID) | ||||||
|  | 	_, err = service.CastProvider.UpdateStatus(ctx, &apiCast.UpdateStatusReq{ | ||||||
|  | 		WorkUuid:   workUuid, | ||||||
|  | 		WorkAction: apiCast.WorkActionENUM_APPROVAL, | ||||||
|  | 		ApprovalID: strconv.FormatUint(apiResp.Data.ID, 10), | ||||||
|  | 	}) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	_, err = service.CastProvider.UpdateStatus(ctx, &apiCast.UpdateStatusReq{ | ||||||
|  | 		WorkUuid:   workUuid, | ||||||
|  | 		WorkAction: apiCast.WorkActionENUM_APPROVAL_PASS, | ||||||
|  | 		ApprovalID: strconv.FormatUint(apiResp.Data.ID, 10), | ||||||
|  | 	}) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	_, err = service.BundleProvider.AddBundleBalance(ctx, &bundle.AddBundleBalanceReq{ | ||||||
|  | 		UserId:                 int32(artistId), | ||||||
|  | 		VideoConsumptionNumber: 1, | ||||||
|  | 	}) | ||||||
|  | 	if err != nil { | ||||||
|  | 		log.Printf(fmt.Sprintf("扣除余额失败: %s", err.Error())) | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	_, err = service.CastProvider.UpdateStatus(ctx, &apiCast.UpdateStatusReq{ | ||||||
|  | 		WorkAction:    apiCast.WorkActionENUM_CONFIRM, | ||||||
|  | 		WorkUuid:      workUuid, | ||||||
|  | 		ConfirmRemark: "", | ||||||
|  | 		ConfirmStatus: 1, | ||||||
|  | 	}) | ||||||
|  | 	if err != nil { | ||||||
|  | 		log.Printf(fmt.Sprintf("更新状态失败: %s", err.Error())) | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user