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.
 | // Code generated by protoc-gen-go-triple. DO NOT EDIT.
 | ||||||
| // versions:
 | // versions:
 | ||||||
| // - protoc-gen-go-triple v1.0.5
 | // - protoc-gen-go-triple v1.0.8
 | ||||||
| // - protoc             v6.32.0
 | // - protoc             v3.20.3
 | ||||||
| // source: pb/bundle.proto
 | // source: pb/bundle.proto
 | ||||||
| 
 | 
 | ||||||
| package bundle | package bundle | ||||||
| @ -50,11 +50,11 @@ type BundleClient interface { | |||||||
| 	OrderRecordsListV2(ctx context.Context, in *OrderRecordsRequestV2, opts ...grpc_go.CallOption) (*OrderRecordsResponseV2, common.ErrorWithAttachment) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	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) | 	OrderRecordsListV2(context.Context, *OrderRecordsRequestV2) (*OrderRecordsResponseV2, error) | ||||||
| 	OrderListByOrderNo(context.Context, *OrderInfoByOrderNoRequest) (*OrderInfoByOrderNoResp, error) | 	OrderListByOrderNo(context.Context, *OrderInfoByOrderNoRequest) (*OrderInfoByOrderNoResp, error) | ||||||
| 	OnlyAddValueListByOrderNo(context.Context, *OnlyAddValueListByOrderNoRequest) (*OnlyAddValueListByOrderNoResp, error) | 	OnlyAddValueListByOrderNo(context.Context, *OnlyAddValueListByOrderNoRequest) (*OnlyAddValueListByOrderNoResp, error) | ||||||
| 	// 增值套餐
 | 	//增值套餐
 | ||||||
| 	CreateValueAddBundle(context.Context, *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) | 	CreateValueAddBundle(context.Context, *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) | ||||||
| 	ValueAddBundleList(context.Context, *ValueAddBundleListRequest) (*ValueAddBundleListResponse, error) | 	ValueAddBundleList(context.Context, *ValueAddBundleListRequest) (*ValueAddBundleListResponse, error) | ||||||
| 	ValueAddBundleDetail(context.Context, *ValueAddBundleDetailRequest) (*ValueAddBundleDetailResponse, error) | 	ValueAddBundleDetail(context.Context, *ValueAddBundleDetailRequest) (*ValueAddBundleDetailResponse, error) | ||||||
| 	// 新增值服务
 | 	//新增值服务
 | ||||||
| 	SaveValueAddService(context.Context, *ValueAddServiceLang) (*SaveResponse, error) | 	SaveValueAddService(context.Context, *ValueAddServiceLang) (*SaveResponse, error) | ||||||
| 	ValueAddServiceList(context.Context, *ValueAddServiceListRequest) (*ValueAddServiceListResponse, error) | 	ValueAddServiceList(context.Context, *ValueAddServiceListRequest) (*ValueAddServiceListResponse, error) | ||||||
| 	ValueAddServiceDetail(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) | 	ValueAddServiceDetail(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) | ||||||
| @ -571,7 +571,7 @@ type BundleServer interface { | |||||||
| 	GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | 	GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | ||||||
| 	ToBeComfirmedWorks(context.Context, *ToBeComfirmedWorksReq) (*ToBeComfirmedWorksResp, error) | 	ToBeComfirmedWorks(context.Context, *ToBeComfirmedWorksReq) (*ToBeComfirmedWorksResp, error) | ||||||
| 	ConfirmWork(context.Context, *ConfirmWorkReq) (*ConfirmWorkResp, error) | 	ConfirmWork(context.Context, *ConfirmWorkReq) (*ConfirmWorkResp, error) | ||||||
| 	// 对账单
 | 	//对账单
 | ||||||
| 	GetReconciliationList(context.Context, *GetReconciliationListReq) (*GetReconciliationListResp, error) | 	GetReconciliationList(context.Context, *GetReconciliationListReq) (*GetReconciliationListResp, error) | ||||||
| 	CreateReconciliation(context.Context, *ReconciliationInfo) (*CommonResponse, error) | 	CreateReconciliation(context.Context, *ReconciliationInfo) (*CommonResponse, error) | ||||||
| 	UpdateReconciliation(context.Context, *ReconciliationInfo) (*CommonResponse, error) | 	UpdateReconciliation(context.Context, *ReconciliationInfo) (*CommonResponse, error) | ||||||
|  | |||||||
| @ -4,13 +4,20 @@ 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"` | ||||||
| 	Account map[apiCast.PlatformIDENUM]string `json:"account"` | 	SubNum  string                                 `json:"subNum"` | ||||||
|  | 	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"` | ||||||
| @ -31,6 +38,8 @@ 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,6 +13,7 @@ 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" | ||||||
| @ -23,11 +24,9 @@ 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 { | ||||||
| @ -59,6 +58,7 @@ 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{ | ||||||
| @ -119,11 +119,11 @@ func ImportBind(c *gin.Context) { | |||||||
| 					log.Printf(fmt.Sprintf("增加账户数量失败: %s", err.Error())) | 					log.Printf(fmt.Sprintf("增加账户数量失败: %s", err.Error())) | ||||||
| 					continue | 					continue | ||||||
| 				} | 				} | ||||||
| 				_, err = service.CastProvider.UpdateMediaAccount(c, &apiCast.UpdateMediaAccountReq{ | 				mediaAccountInfoRes, 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:    artist.Name, | 					PlatformUserName:    accountInfo.NickName, | ||||||
| 					PlatformUserID:      accountInfo, | 					PlatformUserID:      accountInfo.AccountId, | ||||||
| 					ArtistName:          infoResp.Name, | 					ArtistName:          infoResp.Name, | ||||||
| 					ArtistPhone:         infoResp.TelNum, | 					ArtistPhone:         infoResp.TelNum, | ||||||
| 					ArtistPhoneAreaCode: infoResp.TelAreaCode, | 					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))) | 					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, failedRecords) | 	service.Success(c, map[string]interface{}{ | ||||||
|  | 		"excelUrl":      excelUrl, | ||||||
|  | 		"failedRecords": failedRecords, | ||||||
|  | 	}) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func readArtistAccountInfo(excelPath string) ([]ArtistAccount, error) { | func readArtistAccountInfo(excelPath string) ([]ArtistAccount, error) { | ||||||
| @ -171,29 +184,96 @@ 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]string), | 			Account: make(map[apiCast.PlatformIDENUM]AccountInfo), | ||||||
|  | 			Index:   strings.TrimSpace(row[0]), | ||||||
| 			Name:    strings.TrimSpace(row[1]), | 			Name:    strings.TrimSpace(row[1]), | ||||||
|  | 			SubNum:  strings.TrimSpace(row[2]), | ||||||
| 		} | 		} | ||||||
| 		youtube, _ := f.GetCellValue(sheetName, fmt.Sprintf("C%d", i+1)) | 		youtubeId, _ := f.GetCellValue(sheetName, fmt.Sprintf("D%d", i+1)) | ||||||
| 		if youtube != "" { | 		youtubeNickName, _ := f.GetCellValue(sheetName, fmt.Sprintf("E%d", i+1)) | ||||||
| 			tmp.Account[2] = strings.TrimSpace(youtube) | 		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)) | 		tmp.Account[3] = ins | ||||||
| 		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), | ||||||
| 		} | 		} | ||||||
| 		tiktok, _ := f.GetCellValue(sheetName, fmt.Sprintf("E%d", i+1)) | 		tmp.Account[1] = tiktok | ||||||
| 		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,38 +2,47 @@ 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) { // 确认作品并扣除余量
 | ||||||
| 	newCtx := cast.NewCtxWithUserInfo(c) | 	excelFile, err := c.FormFile("excel") | ||||||
| 	list, err := service.CastProvider.WorkList(newCtx, &apiCast.WorkListReq{ |  | ||||||
| 		WorkStatus: 4, |  | ||||||
| 		Page:       1, |  | ||||||
| 		PageSize:   999, |  | ||||||
| 	}) |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		service.Error(c, err) | 		c.JSON(400, gin.H{"error": "缺少 Excel 文件 excel"}) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	if len(list.Data) == 0 { | 	// 2. 保存临时文件
 | ||||||
| 		service.Error(c, errors.New("没有待确认的作品")) | 	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 | 		return | ||||||
| 	} | 	} | ||||||
| 	//遍历更新状态
 | 	//遍历更新状态
 | ||||||
| 	var failedRecords []FailedRecord | 	var failedRecords []FailedRecord | ||||||
| 	for _, v := range list.Data { | 	for _, v := range artists { | ||||||
| 		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{ | ||||||
| @ -76,3 +85,30 @@ 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[2]), | ||||||
|  | 		} | ||||||
|  | 		artistVideos = append(artistVideos, tmp) | ||||||
|  | 	} | ||||||
|  | 	return artistVideos, nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -1,12 +1,9 @@ | |||||||
| 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" | ||||||
| @ -15,9 +12,7 @@ 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" | ||||||
| @ -97,6 +92,7 @@ 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{ | ||||||
| @ -215,6 +211,7 @@ 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, | ||||||
| @ -222,7 +219,7 @@ func ImportPublish(c *gin.Context) { | |||||||
| 			TikTok:     artist.TikTok, | 			TikTok:     artist.TikTok, | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 	excelUrl, err := exportRecordsToExcel(artistResp) | 	excelUrl, err := exportPublishRecordsToExcel(artistResp) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		service.Error(c, err) | 		service.Error(c, err) | ||||||
| 		return | 		return | ||||||
| @ -280,6 +277,10 @@ 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, | ||||||
| @ -287,6 +288,7 @@ 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) | ||||||
| @ -355,6 +357,7 @@ 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 | ||||||
| @ -392,148 +395,71 @@ func UploadToAnotherService(ctx context.Context, fileData []byte, path string) e | |||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| func exportRecordsToExcel(artistInfos []ArtistVideoDetail) (string, error) { | func exportPublishRecordsToExcel(artistInfos []ArtistVideoDetail) (string, error) { | ||||||
| 	f := excelize.NewFile() | 	fileDir := "./runtime/import/" | ||||||
|  | 	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(rune('A'+col))+"1", h) | 			_ = 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 { | 	for i, artistInfo := range artistInfos { | ||||||
| 		row := i + 2 | 		row := startRow + i | ||||||
| 		_ = f.SetCellValue(sheet, "A"+strconv.Itoa(row), artistInfo.Id) | 		_ = f.SetCellValue(sheet, "A"+strconv.Itoa(row), row-1) // 序号连续
 | ||||||
| 		_ = 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) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	// 保存文件
 | 	// 保存文件
 | ||||||
| 	filename := "画家视频详情记录.xlsx" | 	if err = f.SaveAs(filePath); err != nil { | ||||||
| 	fileDir := "./runtime/import/" // 自定义目录
 | 		fmt.Println("saveAs err: ", err) | ||||||
| 	_ = 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