Compare commits
	
		
			3 Commits
		
	
	
		
			46f1a12dee
			...
			7008642797
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 7008642797 | |||
| 3d13747ad9 | |||
| ef6d40cf81 | 
| @ -1,7 +1,7 @@ | ||||
| // Code generated by protoc-gen-go-triple. DO NOT EDIT.
 | ||||
| // versions:
 | ||||
| // - protoc-gen-go-triple v1.0.5
 | ||||
| // - protoc             v6.32.0
 | ||||
| // - protoc-gen-go-triple v1.0.8
 | ||||
| // - protoc             v3.20.3
 | ||||
| // source: pb/bundle.proto
 | ||||
| 
 | ||||
| package bundle | ||||
| @ -50,11 +50,11 @@ type BundleClient interface { | ||||
| 	OrderRecordsListV2(ctx context.Context, in *OrderRecordsRequestV2, opts ...grpc_go.CallOption) (*OrderRecordsResponseV2, common.ErrorWithAttachment) | ||||
| 	OrderListByOrderNo(ctx context.Context, in *OrderInfoByOrderNoRequest, opts ...grpc_go.CallOption) (*OrderInfoByOrderNoResp, common.ErrorWithAttachment) | ||||
| 	OnlyAddValueListByOrderNo(ctx context.Context, in *OnlyAddValueListByOrderNoRequest, opts ...grpc_go.CallOption) (*OnlyAddValueListByOrderNoResp, common.ErrorWithAttachment) | ||||
| 	// 增值套餐
 | ||||
| 	//增值套餐
 | ||||
| 	CreateValueAddBundle(ctx context.Context, in *CreateValueAddBundleRequest, opts ...grpc_go.CallOption) (*CreateValueAddBundleResponse, common.ErrorWithAttachment) | ||||
| 	ValueAddBundleList(ctx context.Context, in *ValueAddBundleListRequest, opts ...grpc_go.CallOption) (*ValueAddBundleListResponse, common.ErrorWithAttachment) | ||||
| 	ValueAddBundleDetail(ctx context.Context, in *ValueAddBundleDetailRequest, opts ...grpc_go.CallOption) (*ValueAddBundleDetailResponse, common.ErrorWithAttachment) | ||||
| 	// 新增值服务
 | ||||
| 	//新增值服务
 | ||||
| 	SaveValueAddService(ctx context.Context, in *ValueAddServiceLang, opts ...grpc_go.CallOption) (*SaveResponse, common.ErrorWithAttachment) | ||||
| 	ValueAddServiceList(ctx context.Context, in *ValueAddServiceListRequest, opts ...grpc_go.CallOption) (*ValueAddServiceListResponse, common.ErrorWithAttachment) | ||||
| 	ValueAddServiceDetail(ctx context.Context, in *ValueAddServiceDetailRequest, opts ...grpc_go.CallOption) (*ValueAddServiceDetailResponse, common.ErrorWithAttachment) | ||||
| @ -75,7 +75,7 @@ type BundleClient interface { | ||||
| 	GetVedioWorkDetail(ctx context.Context, in *GetVedioWorkDetailReq, opts ...grpc_go.CallOption) (*GetVedioeWorkDetailResp, common.ErrorWithAttachment) | ||||
| 	ToBeComfirmedWorks(ctx context.Context, in *ToBeComfirmedWorksReq, opts ...grpc_go.CallOption) (*ToBeComfirmedWorksResp, common.ErrorWithAttachment) | ||||
| 	ConfirmWork(ctx context.Context, in *ConfirmWorkReq, opts ...grpc_go.CallOption) (*ConfirmWorkResp, common.ErrorWithAttachment) | ||||
| 	// 对账单
 | ||||
| 	//对账单
 | ||||
| 	GetReconciliationList(ctx context.Context, in *GetReconciliationListReq, opts ...grpc_go.CallOption) (*GetReconciliationListResp, common.ErrorWithAttachment) | ||||
| 	CreateReconciliation(ctx context.Context, in *ReconciliationInfo, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | ||||
| 	UpdateReconciliation(ctx context.Context, in *ReconciliationInfo, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | ||||
| @ -546,11 +546,11 @@ type BundleServer interface { | ||||
| 	OrderRecordsListV2(context.Context, *OrderRecordsRequestV2) (*OrderRecordsResponseV2, error) | ||||
| 	OrderListByOrderNo(context.Context, *OrderInfoByOrderNoRequest) (*OrderInfoByOrderNoResp, error) | ||||
| 	OnlyAddValueListByOrderNo(context.Context, *OnlyAddValueListByOrderNoRequest) (*OnlyAddValueListByOrderNoResp, error) | ||||
| 	// 增值套餐
 | ||||
| 	//增值套餐
 | ||||
| 	CreateValueAddBundle(context.Context, *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) | ||||
| 	ValueAddBundleList(context.Context, *ValueAddBundleListRequest) (*ValueAddBundleListResponse, error) | ||||
| 	ValueAddBundleDetail(context.Context, *ValueAddBundleDetailRequest) (*ValueAddBundleDetailResponse, error) | ||||
| 	// 新增值服务
 | ||||
| 	//新增值服务
 | ||||
| 	SaveValueAddService(context.Context, *ValueAddServiceLang) (*SaveResponse, error) | ||||
| 	ValueAddServiceList(context.Context, *ValueAddServiceListRequest) (*ValueAddServiceListResponse, error) | ||||
| 	ValueAddServiceDetail(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) | ||||
| @ -571,7 +571,7 @@ type BundleServer interface { | ||||
| 	GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | ||||
| 	ToBeComfirmedWorks(context.Context, *ToBeComfirmedWorksReq) (*ToBeComfirmedWorksResp, error) | ||||
| 	ConfirmWork(context.Context, *ConfirmWorkReq) (*ConfirmWorkResp, error) | ||||
| 	// 对账单
 | ||||
| 	//对账单
 | ||||
| 	GetReconciliationList(context.Context, *GetReconciliationListReq) (*GetReconciliationListResp, error) | ||||
| 	CreateReconciliation(context.Context, *ReconciliationInfo) (*CommonResponse, error) | ||||
| 	UpdateReconciliation(context.Context, *ReconciliationInfo) (*CommonResponse, error) | ||||
|  | ||||
| @ -4,13 +4,20 @@ import ( | ||||
| 	apiCast "fonchain-fiee/api/cast" | ||||
| ) | ||||
| 
 | ||||
| type AccountInfo struct { | ||||
| 	NickName  string `json:"nickName"` | ||||
| 	AccountId string `json:"accountId"` | ||||
| } | ||||
| type ArtistAccount struct { | ||||
| 	Name    string                            `json:"name"` | ||||
| 	Account map[apiCast.PlatformIDENUM]string `json:"account"` | ||||
| 	Index   string                                 `json:"index"` | ||||
| 	Name    string                                 `json:"name"` | ||||
| 	SubNum  string                                 `json:"subNum"` | ||||
| 	Account map[apiCast.PlatformIDENUM]AccountInfo `json:"account"` | ||||
| } | ||||
| type ArtistMedia struct { | ||||
| 	Id        string `json:"id"` | ||||
| 	Name      string `json:"name"` | ||||
| 	SubNum    string `json:"subNum"` | ||||
| 	Title     string `json:"title"` | ||||
| 	Img       string `json:"img"` | ||||
| 	Video     string `json:"video"` | ||||
| @ -31,6 +38,8 @@ type ArtistVideoDetail struct { | ||||
| 	Youtube    string `json:"youtube"` | ||||
| 	Instagram  string `json:"instagram"` | ||||
| 	TikTok     string `json:"tiktok"` | ||||
| 	ArtistId   string `json:"artistId"` | ||||
| 	SubNum     string `json:"subNum"` | ||||
| } | ||||
| type CreateRequest struct { | ||||
| 	Type             string            `json:"Type"` | ||||
|  | ||||
| @ -13,6 +13,7 @@ import ( | ||||
| 	modelCast "fonchain-fiee/pkg/model/cast" | ||||
| 	"fonchain-fiee/pkg/service" | ||||
| 	"fonchain-fiee/pkg/service/cast" | ||||
| 	"fonchain-fiee/pkg/service/upload" | ||||
| 	"log" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| @ -23,11 +24,9 @@ import ( | ||||
| 	"github.com/xuri/excelize/v2" | ||||
| ) | ||||
| 
 | ||||
| type artu struct { | ||||
| } | ||||
| 
 | ||||
| func ImportBind(c *gin.Context) { | ||||
| 	var failedRecords []FailedRecord | ||||
| 	var record []*apiCast.UpdateMediaAccountReq | ||||
| 	// 1. 上传文件
 | ||||
| 	excelFile, err := c.FormFile("excel") | ||||
| 	if err != nil { | ||||
| @ -58,7 +57,8 @@ func ImportBind(c *gin.Context) { | ||||
| 				} | ||||
| 			} | ||||
| 			res, err := service.AccountFieeProvider.UserList(context.Background(), &account.UserListRequest{ | ||||
| 				Name: artist.Name, | ||||
| 				Name:   artist.Name, | ||||
| 				SubNum: artist.SubNum, | ||||
| 			}) | ||||
| 			if err != nil { | ||||
| 				failedRecords = append(failedRecords, FailedRecord{ | ||||
| @ -119,11 +119,11 @@ func ImportBind(c *gin.Context) { | ||||
| 					log.Printf(fmt.Sprintf("增加账户数量失败: %s", err.Error())) | ||||
| 					continue | ||||
| 				} | ||||
| 				_, err = service.CastProvider.UpdateMediaAccount(c, &apiCast.UpdateMediaAccountReq{ | ||||
| 				mediaAccountInfoRes, err := service.CastProvider.UpdateMediaAccount(c, &apiCast.UpdateMediaAccountReq{ | ||||
| 					ArtistUuid:          strconv.FormatUint(res.UserList[0].Id, 10), | ||||
| 					PlatformID:          accountType, | ||||
| 					PlatformUserName:    artist.Name, | ||||
| 					PlatformUserID:      accountInfo, | ||||
| 					PlatformUserName:    accountInfo.NickName, | ||||
| 					PlatformUserID:      accountInfo.AccountId, | ||||
| 					ArtistName:          infoResp.Name, | ||||
| 					ArtistPhone:         infoResp.TelNum, | ||||
| 					ArtistPhoneAreaCode: infoResp.TelAreaCode, | ||||
| @ -144,13 +144,26 @@ func ImportBind(c *gin.Context) { | ||||
| 					}) | ||||
| 					log.Println(fmt.Sprintf("绑定失败后减少余额失败: %s", err.Error()), errors.New(e.GetMsg(e.InvalidParams))) | ||||
| 					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. 返回结果
 | ||||
| 	service.Success(c, failedRecords) | ||||
| 	service.Success(c, map[string]interface{}{ | ||||
| 		"excelUrl":      excelUrl, | ||||
| 		"failedRecords": failedRecords, | ||||
| 	}) | ||||
| } | ||||
| 
 | ||||
| func readArtistAccountInfo(excelPath string) ([]ArtistAccount, error) { | ||||
| @ -171,29 +184,96 @@ func readArtistAccountInfo(excelPath string) ([]ArtistAccount, error) { | ||||
| 		if i == 0 || len(row) < 2 { | ||||
| 			continue | ||||
| 		} | ||||
| 		if i == 58 { | ||||
| 			break | ||||
| 		} | ||||
| 		tmp := ArtistAccount{ | ||||
| 			Account: make(map[apiCast.PlatformIDENUM]string), | ||||
| 			Account: make(map[apiCast.PlatformIDENUM]AccountInfo), | ||||
| 			Index:   strings.TrimSpace(row[0]), | ||||
| 			Name:    strings.TrimSpace(row[1]), | ||||
| 			SubNum:  strings.TrimSpace(row[2]), | ||||
| 		} | ||||
| 		youtube, _ := f.GetCellValue(sheetName, fmt.Sprintf("C%d", i+1)) | ||||
| 		if youtube != "" { | ||||
| 			tmp.Account[2] = strings.TrimSpace(youtube) | ||||
| 		youtubeId, _ := f.GetCellValue(sheetName, fmt.Sprintf("D%d", i+1)) | ||||
| 		youtubeNickName, _ := f.GetCellValue(sheetName, fmt.Sprintf("E%d", i+1)) | ||||
| 		youtube := AccountInfo{ | ||||
| 			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), | ||||
| 		} | ||||
| 		ins, _ := f.GetCellValue(sheetName, fmt.Sprintf("D%d", i+1)) | ||||
| 		if ins != "" { | ||||
| 			tmp.Account[3] = strings.TrimSpace(ins) | ||||
| 		tmp.Account[3] = 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), | ||||
| 		} | ||||
| 		tiktok, _ := f.GetCellValue(sheetName, fmt.Sprintf("E%d", i+1)) | ||||
| 		if tiktok != "" { | ||||
| 			tmp.Account[1] = strings.TrimSpace(tiktok) | ||||
| 		tmp.Account[1] = tiktok | ||||
| 
 | ||||
| 		} | ||||
| 		artists = append(artists, tmp) | ||||
| 	} | ||||
| 	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,38 +2,47 @@ package imports | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	account "fonchain-fiee/api/accountFiee" | ||||
| 	"fonchain-fiee/api/bundle" | ||||
| 	apiCast "fonchain-fiee/api/cast" | ||||
| 	"fonchain-fiee/pkg/service" | ||||
| 	"fonchain-fiee/pkg/service/cast" | ||||
| 	"log" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/xuri/excelize/v2" | ||||
| ) | ||||
| 
 | ||||
| func WorkConfirm(c *gin.Context) { // 确认作品并扣除余量
 | ||||
| 	newCtx := cast.NewCtxWithUserInfo(c) | ||||
| 	list, err := service.CastProvider.WorkList(newCtx, &apiCast.WorkListReq{ | ||||
| 		WorkStatus: 4, | ||||
| 		Page:       1, | ||||
| 		PageSize:   999, | ||||
| 	}) | ||||
| 	excelFile, err := c.FormFile("excel") | ||||
| 	if err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		c.JSON(400, gin.H{"error": "缺少 Excel 文件 excel"}) | ||||
| 		return | ||||
| 	} | ||||
| 	if len(list.Data) == 0 { | ||||
| 		service.Error(c, errors.New("没有待确认的作品")) | ||||
| 	// 2. 保存临时文件
 | ||||
| 	tempDir := "tmp" | ||||
| 	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 | ||||
| 	} | ||||
| 	//遍历更新状态
 | ||||
| 	var failedRecords []FailedRecord | ||||
| 	for _, v := range list.Data { | ||||
| 	for _, v := range artists { | ||||
| 		res, err := service.AccountFieeProvider.UserList(context.Background(), &account.UserListRequest{ | ||||
| 			Name: v.ArtistName, | ||||
| 			Name:   v.ArtistName, | ||||
| 			SubNum: v.SubNum, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			failedRecords = append(failedRecords, FailedRecord{ | ||||
| @ -76,3 +85,30 @@ func WorkConfirm(c *gin.Context) { // 确认作品并扣除余量 | ||||
| 	} | ||||
| 	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[2]), | ||||
| 		} | ||||
| 		artistVideos = append(artistVideos, tmp) | ||||
| 	} | ||||
| 	return artistVideos, nil | ||||
| } | ||||
|  | ||||
| @ -1,12 +1,9 @@ | ||||
| package imports | ||||
| 
 | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"context" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"fonchain-fiee/api/accountFiee" | ||||
| 	"fonchain-fiee/api/bundle" | ||||
| 	apiCast "fonchain-fiee/api/cast" | ||||
| 	"fonchain-fiee/api/files" | ||||
| 	"fonchain-fiee/pkg/config" | ||||
| @ -15,9 +12,7 @@ import ( | ||||
| 	"fonchain-fiee/pkg/service" | ||||
| 	"fonchain-fiee/pkg/service/cast" | ||||
| 	"fonchain-fiee/pkg/service/upload" | ||||
| 	"io" | ||||
| 	"log" | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"strconv" | ||||
| @ -96,7 +91,8 @@ func ImportPublish(c *gin.Context) { | ||||
| 		var infoResp *accountFiee.UserInfoResponse | ||||
| 		var err error | ||||
| 		list, err := service.AccountFieeProvider.UserList(context.Background(), &accountFiee.UserListRequest{ | ||||
| 			Name: artist.Name, | ||||
| 			Name:   artist.Name, | ||||
| 			SubNum: artist.SubNum, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			failedRecords = append(failedRecords, FailedRecord{ | ||||
| @ -215,6 +211,7 @@ func ImportPublish(c *gin.Context) { | ||||
| 		artistResp = append(artistResp, ArtistVideoDetail{ | ||||
| 			Id:         artist.Id, | ||||
| 			ArtistName: artist.Name, | ||||
| 			SubNum:     artist.SubNum, | ||||
| 			Title:      artist.Title, | ||||
| 			WorkUuid:   resp.WorkUuid, | ||||
| 			Youtube:    artist.Youtube, | ||||
| @ -222,7 +219,7 @@ func ImportPublish(c *gin.Context) { | ||||
| 			TikTok:     artist.TikTok, | ||||
| 		}) | ||||
| 	} | ||||
| 	excelUrl, err := exportRecordsToExcel(artistResp) | ||||
| 	excelUrl, err := exportPublishRecordsToExcel(artistResp) | ||||
| 	if err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| @ -280,6 +277,10 @@ func readArtistVideoInfo(excelPath, unzipPath string) ([]ArtistMedia, error) { | ||||
| 		if 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{ | ||||
| 			Id:        id, | ||||
| 			Name:      artistName, | ||||
| @ -287,6 +288,7 @@ func readArtistVideoInfo(excelPath, unzipPath string) ([]ArtistMedia, error) { | ||||
| 			Youtube:   youtube, | ||||
| 			Instagram: instagram, | ||||
| 			TikTok:    tiktok, | ||||
| 			SubNum:    subNum, | ||||
| 		}) | ||||
| 	} | ||||
| 	artists, err = matchArtistMedia(artists, unzipPath) | ||||
| @ -355,6 +357,7 @@ func matchArtistMedia(artists []ArtistMedia, unzipPath string) ([]ArtistMedia, e | ||||
| 		tmp.Img = imgUrl | ||||
| 		//tmp.Video = filepath.ToSlash(videoPath)
 | ||||
| 		tmp.Video = videoUrl | ||||
| 		tmp.SubNum = artist.SubNum | ||||
| 		res = append(res, tmp) | ||||
| 	} | ||||
| 	return res, nil | ||||
| @ -392,148 +395,71 @@ func UploadToAnotherService(ctx context.Context, fileData []byte, path string) e | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func exportRecordsToExcel(artistInfos []ArtistVideoDetail) (string, error) { | ||||
| 	f := excelize.NewFile() | ||||
| func exportPublishRecordsToExcel(artistInfos []ArtistVideoDetail) (string, error) { | ||||
| 	fileDir := "./runtime/import/" | ||||
| 	filename := "画家视频详情记录0922.xlsx" | ||||
| 	filePath := filepath.Join(fileDir, filename) | ||||
| 
 | ||||
| 	_ = os.MkdirAll(fileDir, os.ModePerm) | ||||
| 
 | ||||
| 	var f *excelize.File | ||||
| 	sheet := "Sheet1" | ||||
| 	f.NewSheet(sheet) | ||||
| 
 | ||||
| 	// 写表头
 | ||||
| 	headers := []string{"序号", "画家名", "标题", "uuid", "youtube", "instagram", "tiktok"} | ||||
| 	// 判断文件是否存在
 | ||||
| 	if _, err := os.Stat(filePath); os.IsNotExist(err) { | ||||
| 		// 文件不存在,新建文件和Sheet
 | ||||
| 		f = excelize.NewFile() | ||||
| 		f.SetSheetName(f.GetSheetName(0), sheet) | ||||
| 
 | ||||
| 	for col, h := range headers { | ||||
| 		_ = f.SetCellValue(sheet, string(rune('A'+col))+"1", h) | ||||
| 		// 写表头
 | ||||
| 		headers := []string{"序号", "画家名", "标题", "uuid", "youtube", "instagram", "tiktok"} | ||||
| 		for col, h := range headers { | ||||
| 			_ = f.SetCellValue(sheet, string('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 { | ||||
| 		row := i + 2 | ||||
| 		_ = f.SetCellValue(sheet, "A"+strconv.Itoa(row), artistInfo.Id) | ||||
| 		row := startRow + i | ||||
| 		_ = f.SetCellValue(sheet, "A"+strconv.Itoa(row), row-1) // 序号连续
 | ||||
| 		_ = f.SetCellValue(sheet, "B"+strconv.Itoa(row), artistInfo.ArtistName) | ||||
| 		_ = f.SetCellValue(sheet, "C"+strconv.Itoa(row), artistInfo.Title) | ||||
| 		_ = f.SetCellValue(sheet, "D"+strconv.Itoa(row), artistInfo.WorkUuid) | ||||
| 		_ = f.SetCellValue(sheet, "E"+strconv.Itoa(row), artistInfo.Youtube) | ||||
| 		_ = f.SetCellValue(sheet, "F"+strconv.Itoa(row), artistInfo.Instagram) | ||||
| 		_ = f.SetCellValue(sheet, "G"+strconv.Itoa(row), artistInfo.TikTok) | ||||
| 		_ = f.SetCellValue(sheet, "H"+strconv.Itoa(row), artistInfo.SubNum) | ||||
| 	} | ||||
| 
 | ||||
| 	// 保存文件
 | ||||
| 	filename := "画家视频详情记录.xlsx" | ||||
| 	fileDir := "./runtime/import/" // 自定义目录
 | ||||
| 	_ = os.MkdirAll(fileDir, os.ModePerm) | ||||
| 	filePath := filepath.Join(fileDir, filename) | ||||
| 	if err := f.SaveAs(filePath); err != nil { | ||||
| 	if err = f.SaveAs(filePath); err != nil { | ||||
| 		fmt.Println("saveAs err: ", err) | ||||
| 		return "", err | ||||
| 	} | ||||
| 
 | ||||
| 	// 上传
 | ||||
| 	excelUrl, err := upload.PutBos(filePath, "excel", true) | ||||
| 	if err != nil { | ||||
| 		return "", err | ||||
| 
 | ||||
| 	} | ||||
| 	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