Compare commits
	
		
			13 Commits
		
	
	
		
			88333063d7
			...
			b75a07c4dd
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b75a07c4dd | |||
| eb3e1f809b | |||
| c4e72efcb5 | |||
| 99cfbbf6f7 | |||
| d4b50302fa | |||
| 8449969682 | |||
| a439342ba2 | |||
| 6ae9395add | |||
| 4a30ddad23 | |||
| 449ff68d3a | |||
| 03574bd25f | |||
| db54a355e8 | |||
| 8f4dd8aee0 | 
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -17,10 +17,10 @@ | ||||
| 
 | ||||
| syntax = "proto3"; | ||||
| package accountFiee; | ||||
| import "github.com/mwitkow/go-proto-validators@v0.3.2/validator.proto"; | ||||
| 
 | ||||
| import "github.com/mwitkow/go-proto-validators/validator.proto"; | ||||
| option go_package = "./;accountFiee"; | ||||
| 
 | ||||
| //protoc -I . -I C:\Users\lenovo\go\src  --go_out=. --go-triple_out=. ./accountFiee.proto | ||||
| service AccountFiee { | ||||
|   rpc Login (LoginRequest) returns (TokenInfo) {} | ||||
|   rpc RefreshToken (RefreshTokenRequest) returns (TokenInfo) {} //刷新token | ||||
| @ -62,6 +62,37 @@ service AccountFiee { | ||||
|   rpc VerifySliderCaptcha(VerifySliderCaptchaRequest) returns (VerifySliderCaptchaResponse) {}// 验证滑块验证码位置 | ||||
|   rpc SendNationMsg (SendNationMsgRequest) returns (SendMsgStatusResponse) {} //发送境外国际短信验证码 --艺术商城 | ||||
|   rpc VerifySliderStatus(VerifySliderStatusRequest) returns (VerifySliderStatusResponse) {}// 验证滑块验证码状态 | ||||
| 
 | ||||
|   // submit info | ||||
|   rpc SaveSubmitInfo(SubmitInfoRequest) returns (CommonResponse); | ||||
| 
 | ||||
|   //-----------------------------客服聊天系统-------------------------------- | ||||
|   rpc CreateChatUser ( ChatUserData )returns( CreateChatUserResp ){} //创建聊天用户 | ||||
|   rpc UpdateChatUser ( ChatUserData )returns( CommonMsg ){} //更新聊天用户 | ||||
|   rpc SaveChatUser ( ChatUserData )returns( CommonMsg ){} //覆盖聊天用户 | ||||
|   rpc DeleteChatUser ( DeleteChatUserRequest )returns( CommonMsg ){}   //删除聊天用户 | ||||
|   rpc GetChatUserDetail ( GetChatUserByIdRequest )returns( ChatUserData ){}   //查询聊天用户详情 | ||||
|   rpc GetChatUserList ( GetChatUserListRequest )returns( GetChatUserListResp ){}   //查询聊天用户列表 | ||||
|   rpc GetChatUserList2 ( GetChatUserListRequest2 )returns( GetChatUserListResp2 ){}   //查询聊天用户列表2 | ||||
|   rpc RegisterWaiter ( RegisterWaiterRequest )returns( RegisterWaiterResp ){} //注册客服账号 | ||||
|   rpc CreateChatRecord ( ChatRecordData )returns( CreateChatRecordResp ){} //创建ChatRecord | ||||
|   rpc UpdateChatRecord ( ChatRecordData )returns( CommonMsg ){} //更新ChatRecord | ||||
|   rpc SaveChatRecord ( ChatRecordData )returns( CommonMsg ){} //覆盖ChatRecord | ||||
|   rpc DeleteChatRecord ( DeleteChatRecordRequest )returns( CommonMsg ){}   //删除ChatRecord | ||||
|   rpc GetChatRecordDetail ( GetChatRecordByIdRequest )returns( ChatRecordData ){}   //查询ChatRecord详情 | ||||
|   rpc GetChatRecordList ( GetChatRecordListRequest )returns( GetChatRecordListResp ){}   //查询ChatRecord列表 | ||||
|   rpc CreateChatMedia ( ChatMediaData )returns( CreateChatMediaResp ){} //创建ChatMedia | ||||
|   rpc UpdateChatMedia ( ChatMediaData )returns( CommonMsg ){} //更新ChatMedia | ||||
|   rpc SaveChatMedia ( ChatMediaData )returns( CommonMsg ){} //覆盖ChatMedia | ||||
|   rpc DeleteChatMedia ( DeleteChatMediaRequest )returns( CommonMsg ){}   //删除ChatMedia | ||||
|   rpc GetChatMediaDetail ( GetChatMediaByIdRequest )returns( ChatMediaData ){}   //查询ChatMedia详情 | ||||
|   rpc GetChatMediaList ( GetChatMediaListRequest )returns( GetChatMediaListResp ){}   //查询ChatMedia列表 | ||||
|   rpc CreateChatAutoReplyRuler ( ChatAutoReplyRulerData )returns( CreateChatAutoReplyRulerResp ){} //创建自动回复规则 | ||||
|   rpc UpdateChatAutoReplyRuler ( ChatAutoReplyRulerData )returns( CommonMsg ){} //更新自动回复规则 | ||||
|   rpc SaveChatAutoReplyRuler ( ChatAutoReplyRulerData )returns( CommonMsg ){} //覆盖自动回复规则 | ||||
|   rpc DeleteChatAutoReplyRuler ( DeleteChatAutoReplyRulerRequest )returns( CommonMsg ){}   //删除自动回复规则 | ||||
|   rpc GetChatAutoReplyRulerDetail ( GetChatAutoReplyRulerByIdRequest )returns( ChatAutoReplyRulerData ){}   //查询自动回复规则详情 | ||||
|   rpc GetChatAutoReplyRulerList ( GetChatAutoReplyRulerListRequest )returns( GetChatAutoReplyRulerListResp ){}   //查询自动回复规则列表 | ||||
| } | ||||
| 
 | ||||
| message VerifySliderStatusRequest { | ||||
| @ -153,6 +184,9 @@ message UserListRequest{ | ||||
|   int32 auditStatus = 7; | ||||
|   uint64 page = 8; | ||||
|   uint64 pageSize = 9; | ||||
|   string blurNameTel = 10; | ||||
|   repeated int64 ids = 11; | ||||
|   string nationality = 12; | ||||
| } | ||||
| message UserInfoResponse{ | ||||
|   uint64 id = 1; | ||||
| @ -818,3 +852,206 @@ message ClockLogListResponse{ | ||||
|   repeated ClockLogInfo data =1; | ||||
|   uint64 count = 2; | ||||
| } | ||||
| message SubmitInfoRequest{ | ||||
|   string firstName = 1; | ||||
|   string lastName = 2; | ||||
|   string email = 3; | ||||
|   string company = 4; | ||||
|   string phone = 5; | ||||
| } | ||||
| 
 | ||||
| message CommonMsg{ | ||||
|   string msg = 1; | ||||
| } | ||||
| enum MsgType{ | ||||
|   UnknownMsgType = 0 ;//未知类型 | ||||
|   TextMsgType  = 1   ;//文本 | ||||
|   ImageMsgType = 2   ;//图片 | ||||
|   AudioMsgType = 3   ;//音频 | ||||
|   VideoMsgType = 4   ;//视频 | ||||
|   FileType     = 5   ;//文件 | ||||
| } | ||||
| message ChatRecordData{ | ||||
|   int64 ID=1; | ||||
|   string createdAt=2; | ||||
|   string updatedAt=3; | ||||
|   int64  deletedAt=4; | ||||
|   string sessionId = 5; //会话UID | ||||
|   int64 userId = 6; //用户ID | ||||
|   string name = 7; //名称 | ||||
|   string avatar = 8; //头像 | ||||
|   MsgType msgType = 9; //消息类型 | ||||
|   string content = 10; //消息内容 | ||||
|   repeated ChatMediaData medias = 11; //媒体 | ||||
|   int32 waiterRead=12;//客服是否已读 1=已读 2=未读 (被任意客服读取过均为已读) | ||||
|   int64 localStamp = 13; //本地时间戳 用户端的消息唯一值,用于用户本地的一些逻辑处理 | ||||
|   string domain =14;//域 | ||||
| } | ||||
| message CreateChatRecordResp{ | ||||
|   ChatRecordData data=1; | ||||
|   string msg=2; | ||||
| } | ||||
| message DeleteChatRecordRequest{ | ||||
|   int64 id=1; //二选一,数据id | ||||
|   repeated int64 ids=2;//二选一,数据id列表 | ||||
| } | ||||
| message GetChatRecordByIdRequest{ | ||||
|   int64 id=1; //数据id | ||||
| } | ||||
| message GetChatRecordListRequest{ | ||||
|   ChatRecordData query =1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   string where=4; | ||||
|   string order=5; | ||||
| } | ||||
| message GetChatRecordListResp{ | ||||
|   repeated ChatRecordData list=1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   int64 Total=4; | ||||
| } | ||||
| 
 | ||||
| message RegisterWaiterRequest{ | ||||
|   string origin=1; //来源 | ||||
|   int64  originId=2; //来源对应的用户ID | ||||
|   string nickName=3; //名称 | ||||
|   string avatar=4; //头像 | ||||
|   string telNum=5; //电话 | ||||
|   string invitationCode=6; //邀请码 | ||||
|   string account=7; | ||||
| } | ||||
| message RegisterWaiterResp{ | ||||
|   int64 userId=1; | ||||
| } | ||||
| 
 | ||||
| message ChatMediaData{ | ||||
|   int64 ID=1; | ||||
|   string createdAt=2; | ||||
|   string updatedAt=3; | ||||
|   int64  deletedAt=4; | ||||
|   string url = 5; //url | ||||
|   string md5 = 6; //md5值 | ||||
|   string size = 7; //尺寸 | ||||
|   string ext = 8; //后缀格式 | ||||
|   string convText=9; //语音转文字内容 | ||||
|   int64 duration=10;//时长 | ||||
| } | ||||
| message CreateChatMediaResp{ | ||||
|   ChatMediaData data=1; | ||||
|   string msg=2; | ||||
| } | ||||
| message DeleteChatMediaRequest{ | ||||
|   int64 id=1; //二选一,数据id | ||||
|   repeated int64 ids=2;//二选一,数据id列表 | ||||
| } | ||||
| message GetChatMediaByIdRequest{ | ||||
|   int64 id=1; //数据id | ||||
| } | ||||
| message GetChatMediaListRequest{ | ||||
|   ChatMediaData query =1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   string where=4; | ||||
|   string order=5; | ||||
| } | ||||
| message GetChatMediaListResp{ | ||||
|   repeated ChatMediaData list=1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   int64 Total=4; | ||||
| } | ||||
| message GetChatUserListRequest2{ | ||||
|   int64 page=1; | ||||
|   int64 pageSize=2; | ||||
|   string where=3; | ||||
|   string name=4; | ||||
|   repeated int64 userIdIn=5; | ||||
| } | ||||
| message ChatUser2{ | ||||
|   int64 userId=1; | ||||
|   string name=2; | ||||
|   string avatar=3; | ||||
|   string origin=4; | ||||
|   string originId=5; | ||||
| } | ||||
| message GetChatUserListResp2{ | ||||
|   repeated ChatUser2 list=1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   int64 Total=4; | ||||
|   string where=5; | ||||
| } | ||||
| message ChatAutoReplyRulerData{ | ||||
|   int64 ID = 1; // | ||||
|   string createdAt = 2; // | ||||
|   string updatedAt = 3; // | ||||
|   int64 deletedAt = 4; // | ||||
|   string title = 5; //标题 | ||||
|   string ruler = 6; //规则内容 | ||||
|   int32 status = 7; //规则状态: 1=启用 2=禁用 | ||||
|   string response =8; //回复内容 | ||||
| } | ||||
| 
 | ||||
| message CreateChatAutoReplyRulerResp{ | ||||
|   ChatAutoReplyRulerData data=1; | ||||
|   string msg=2; | ||||
| } | ||||
| message DeleteChatAutoReplyRulerRequest{ | ||||
|   int64 id=1; //二选一,数据id | ||||
|   repeated int64 ids=2;//二选一,数据id列表 | ||||
| } | ||||
| message GetChatAutoReplyRulerByIdRequest{ | ||||
|   int64 id=1; //数据id | ||||
| } | ||||
| message GetChatAutoReplyRulerListRequest{ | ||||
|   ChatAutoReplyRulerData query =1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   string where=4; | ||||
|   string order=5; | ||||
| } | ||||
| message GetChatAutoReplyRulerListResp{ | ||||
|   repeated ChatAutoReplyRulerData list=1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   int64 Total=4; | ||||
| } | ||||
| message ChatUserData{ | ||||
|   int64 ID = 1; // | ||||
|   string createdAt = 2; // | ||||
|   string updatedAt = 3; // | ||||
|   int64 deletedAt = 4; // | ||||
|   string nickName = 5; //昵称 | ||||
|   string account = 6; //账号 | ||||
|   int32 role = 7; //聊天角色 1=用户 2=客服 | ||||
|   string origin = 8; //数据来源 | ||||
|   int64 originId = 9; //数据来源对应的用户ID | ||||
|   string avatar = 10; //头像 | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| message CreateChatUserResp{ | ||||
|   ChatUserData data=1; | ||||
|   string msg=2; | ||||
| } | ||||
| message DeleteChatUserRequest{ | ||||
|   int64 id=1; //二选一,数据id | ||||
|   repeated int64 ids=2;//二选一,数据id列表 | ||||
| } | ||||
| message GetChatUserByIdRequest{ | ||||
|   int64 id=1; //数据id | ||||
| } | ||||
| message GetChatUserListRequest{ | ||||
|   ChatUserData query =1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   string where=4; | ||||
|   string order=5; | ||||
| } | ||||
| message GetChatUserListResp{ | ||||
|   repeated ChatUserData list=1; | ||||
|   int64 page=2; | ||||
|   int64 pageSize=3; | ||||
|   int64 Total=4; | ||||
| } | ||||
| @ -522,3 +522,178 @@ func (this *ClockLogListResponse) Validate() error { | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *SubmitInfoRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *CommonMsg) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ChatRecordData) Validate() error { | ||||
| 	for _, item := range this.Medias { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("Medias", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *CreateChatRecordResp) Validate() error { | ||||
| 	if this.Data != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Data); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *DeleteChatRecordRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatRecordByIdRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatRecordListRequest) Validate() error { | ||||
| 	if this.Query != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Query); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Query", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatRecordListResp) Validate() error { | ||||
| 	for _, item := range this.List { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("List", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *RegisterWaiterRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *RegisterWaiterResp) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ChatMediaData) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *CreateChatMediaResp) Validate() error { | ||||
| 	if this.Data != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Data); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *DeleteChatMediaRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatMediaByIdRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatMediaListRequest) Validate() error { | ||||
| 	if this.Query != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Query); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Query", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatMediaListResp) Validate() error { | ||||
| 	for _, item := range this.List { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("List", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatUserListRequest2) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ChatUser2) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatUserListResp2) Validate() error { | ||||
| 	for _, item := range this.List { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("List", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *ChatAutoReplyRulerData) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *CreateChatAutoReplyRulerResp) Validate() error { | ||||
| 	if this.Data != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Data); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *DeleteChatAutoReplyRulerRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatAutoReplyRulerByIdRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatAutoReplyRulerListRequest) Validate() error { | ||||
| 	if this.Query != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Query); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Query", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatAutoReplyRulerListResp) Validate() error { | ||||
| 	for _, item := range this.List { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("List", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *ChatUserData) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *CreateChatUserResp) Validate() error { | ||||
| 	if this.Data != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Data); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *DeleteChatUserRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatUserByIdRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatUserListRequest) Validate() error { | ||||
| 	if this.Query != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Query); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Query", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetChatUserListResp) Validate() error { | ||||
| 	for _, item := range this.List { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("List", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -17,10 +17,97 @@ var _ = proto.Marshal | ||||
| var _ = fmt.Errorf | ||||
| var _ = math.Inf | ||||
| 
 | ||||
| func (this *GetReconciliationListReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetReconciliationListResp) Validate() error { | ||||
| 	for _, item := range this.List { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("List", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *ReconciliationInfo) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderInfoByOrderNoRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderInfoByOrderNoResp) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderCreateRecord) Validate() error { | ||||
| 	for _, item := range this.AddRecords { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("AddRecords", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderCreateAddRecord) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderRecordsRequestV2) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderRecordsResponseV2) Validate() error { | ||||
| 	for _, item := range this.BundleInfo { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("BundleInfo", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderBundleRecordInfo) Validate() error { | ||||
| 	for _, item := range this.AddBundleInfo { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("AddBundleInfo", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderAddBundleRecordInfo) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *PackagePriceAndTimeResponse) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *CommonResponse) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleProfile) Validate() error { | ||||
| 	for _, item := range this.SelectValueAddService { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("SelectValueAddService", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	for _, item := range this.BundleProfileLang { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("BundleProfileLang", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleProfileLang) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *SaveResponse) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *SelectValueAddService) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *DelBundleRequest) Validate() error { | ||||
| @ -42,6 +129,9 @@ func (this *BundleListResponse) Validate() error { | ||||
| func (this *BundleDetailRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *HandShelfRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleDetailResponse) Validate() error { | ||||
| 	if this.Bundle != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Bundle); err != nil { | ||||
| @ -50,7 +140,38 @@ func (this *BundleDetailResponse) Validate() error { | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleDetailResponseV2) Validate() error { | ||||
| 	if this.Bundle != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.Bundle); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Bundle", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderRecord) Validate() error { | ||||
| 	for _, item := range this.PriceOptionsInfo { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("PriceOptionsInfo", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderAddRecord) Validate() error { | ||||
| 	for _, item := range this.AddPriceOptionsList { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("AddPriceOptionsList", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *AddPriceOptionsInfo) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *PriceOptionsInfo) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *OrderRecordsRequest) Validate() error { | ||||
| @ -119,3 +240,153 @@ func (this *ValueAddBundleDetailResponse) Validate() error { | ||||
| func (this *FinancialConfirmationRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ValueAddService) Validate() error { | ||||
| 	for _, item := range this.ServiceLang { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("ServiceLang", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *ValueAddServiceLang) Validate() error { | ||||
| 	for _, item := range this.Options { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("Options", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *ValueAddPriceOptions) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ValueAddServiceListRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ValueAddServiceListResponse) Validate() error { | ||||
| 	for _, item := range this.ValueAddServiceList { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("ValueAddServiceList", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *ValueAddServiceDetailRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ValueAddServiceDetailResponse) Validate() error { | ||||
| 	if this.ValueAddService != nil { | ||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.ValueAddService); err != nil { | ||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("ValueAddService", err) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *CalculatePriceRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *CalculatePriceResponse) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleExtendRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleExtendResponse) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleExtendRecordsListRequest) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleExtendRecordsListResponse) Validate() error { | ||||
| 	for _, item := range this.Data { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleExtendRecordItem) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetBundleBalanceListReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetBundleBalanceReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *BundleBalanceItem) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetBundleBalanceResp) Validate() error { | ||||
| 	for _, item := range this.Data { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetBundleBalanceListResp) Validate() error { | ||||
| 	for _, item := range this.Data { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *CreateBundleBalanceReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *CreateBundleBalanceResp) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *AddBundleBalanceReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *AddBundleBalanceResp) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetUsedRecordListReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetUsedRecordListResp) Validate() error { | ||||
| 	for _, item := range this.Data { | ||||
| 		if item != nil { | ||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| func (this *WorkCastItem) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetImageWorkDetailReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetVedioWorkDetailReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetImageWorkDetailResp) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *GetVedioeWorkDetailResp) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ToBeComfirmedWorksReq) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
| func (this *ToBeComfirmedWorksResp) Validate() error { | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -57,6 +57,10 @@ var EnMessages = map[string]string{ | ||||
| 	"服务器错误":           "Server error", | ||||
| 	"验证失败,请控制拼图对齐缺口":  "Verification failed, please control puzzle alignment gap", | ||||
| 	"滑块验证状态不存在,请退出重试": "The slider verification status does not exist. Please exit and try again", | ||||
| 	"请先实名":            "Please use your real name first", | ||||
| 	"实名审核中":           "Real-name verification is underway", | ||||
| 	"实名审核失败":          "The real-name verification failed", | ||||
| 	"未知实名状态":          "Unknown real-name status", | ||||
| } | ||||
| 
 | ||||
| var DeDEMessages = map[string]string{ | ||||
| @ -108,6 +112,10 @@ var DeDEMessages = map[string]string{ | ||||
| 	"服务器错误":           "Serverfehler", | ||||
| 	"验证失败,请控制拼图对齐缺口":  "Überprüfung fehlgeschlagen, bitte Steuerung Puzzle-Ausrichtungslücke", | ||||
| 	"滑块验证状态不存在,请退出重试": "Die krümmbestätigung existiert nicht. Bitte beenden sie den vorgang", | ||||
| 	"请先实名":            "Bitte, nur der name", | ||||
| 	"实名审核中":           "Contest läuft", | ||||
| 	"实名审核失败":          "Die confirmation hat versagt", | ||||
| 	"未知实名状态":          "Noch nicht registriert", | ||||
| } | ||||
| 
 | ||||
| var JaJPMessages = map[string]string{ | ||||
| @ -159,6 +167,10 @@ var JaJPMessages = map[string]string{ | ||||
| 	"服务器错误":           "サーバーエラー", | ||||
| 	"验证失败,请控制拼图对齐缺口":  "検証に失敗しました。パズルの整列ギャップを制御してください", | ||||
| 	"滑块验证状态不存在,请退出重试": "スライダー検証状態が存在しません,リトライをログアウトしてください", | ||||
| 	"请先实名":            "まずは実名でお願いします", | ||||
| 	"实名审核中":           "実名審査中です", | ||||
| 	"实名审核失败":          "実名検証失敗です", | ||||
| 	"未知实名状态":          "未知の実名状態です", | ||||
| } | ||||
| 
 | ||||
| var ZhTWMessages = map[string]string{ | ||||
| @ -210,4 +222,8 @@ var ZhTWMessages = map[string]string{ | ||||
| 	"服务器错误":           "服務器錯誤", | ||||
| 	"验证失败,请控制拼图对齐缺口":  "驗證失敗,請控制拼圖對齊缺口", | ||||
| 	"滑块验证状态不存在,请退出重试": "滑塊驗證狀態不存在,請退出重試", | ||||
| 	"请先实名":            "請先實名", | ||||
| 	"实名审核中":           "實名審覈中", | ||||
| 	"实名审核失败":          "實名審覈失敗", | ||||
| 	"未知实名状态":          "未知實名狀態", | ||||
| } | ||||
|  | ||||
| @ -150,6 +150,7 @@ func CheckWebLogin(provider *account.AccountClientImpl) gin.HandlerFunc { | ||||
| 		loginInfo := login.Info{ | ||||
| 			Domain: info.Domain, | ||||
| 			ID:     info.ID, | ||||
| 			Name:   info.NickName, | ||||
| 			//Account:        info.Account,
 | ||||
| 			//NickName:       info.NickName,
 | ||||
| 			//PositionUsers:  qres.PositionUsers,
 | ||||
|  | ||||
| @ -12,17 +12,19 @@ func BundleOrderRouter(r *gin.RouterGroup) { | ||||
| 
 | ||||
| 	r.POST("/stripe-pay/callback", bundle.StripeCheckoutSessionWebhook) | ||||
| 	r.POST("/antom/callback", bundle.AntomWebhook) // Antom回调
 | ||||
| 
 | ||||
| 	r.POST("/home-page/roll", bundle.HomePageRoll) | ||||
| 	bundleOrderRoute := r.Group("bundle-order") | ||||
| 	bundleOrderRoute.Use(middleware.CheckLogin(service.AccountFieeProvider)) | ||||
| 	//bundleOrderWebRoute := r.Group("bundle-order")
 | ||||
| 	//bundleOrderWebRoute.Use(middleware.CheckWebLogin(service.AccountProvider))
 | ||||
| 	bundleOrderWebRoute := r.Group("bundle-order") | ||||
| 	bundleOrderWebRoute.Use(middleware.CheckWebLogin(service.AccountProvider)) | ||||
| 
 | ||||
| 	// 套餐
 | ||||
| 	{ | ||||
| 		bundleOrderClientWebRoute := bundleOrderRoute.Group("common/web") | ||||
| 		bundleOrderClientWebRoute := bundleOrderWebRoute.Group("common/web") | ||||
| 		{ | ||||
| 			bundleOrderClientWebRoute.POST("bundle-order-list", bundle.OrderRecordsList) | ||||
| 			bundleOrderClientWebRoute.POST("bundle-order-list-V2", bundle.OrderRecordsListV2) | ||||
| 			bundleOrderClientWebRoute.POST("reconciliation-list", bundle.GetReconciliationList) | ||||
| 		} | ||||
| 		bundleOrderClientAppRoute := bundleOrderRoute.Group("common/app") | ||||
| 		{ | ||||
| @ -38,6 +40,7 @@ func BundleOrderRouter(r *gin.RouterGroup) { | ||||
| 		bundleOrderAppRoute := bundleOrderRoute.Group("app") | ||||
| 		{ | ||||
| 			bundleOrderAppRoute.POST("order-signature", bundle.CreateBundleOrderSignature) | ||||
| 			bundleOrderAppRoute.POST("order-add-signature", bundle.CreateBundleOrderAddSignature) | ||||
| 			bundleOrderAppRoute.POST("update-pay", bundle.UpdateBundleOrderStatusPaid) | ||||
| 			bundleOrderAppRoute.POST("order-detail", bundle.OrderRecordsDetail) | ||||
| 
 | ||||
|  | ||||
| @ -63,7 +63,7 @@ func NewRouter() *gin.Engine { | ||||
| 		} | ||||
| 		webAcRouter := privateGroup.Group("/user") | ||||
| 		//webAcRouter.Use(middleware.CheckWebLogin(service.AccountProvider))
 | ||||
| 		webAcRouter.Use(middleware.CheckLogin(service.AccountFieeProvider)) | ||||
| 		webAcRouter.Use(middleware.CheckWebLogin(service.AccountProvider)) | ||||
| 		{ | ||||
| 			webAcRouter.POST("list", account.UserList)         //用户列表
 | ||||
| 			webAcRouter.POST("approval", account.UserApproval) //实名审核
 | ||||
|  | ||||
| @ -12,16 +12,166 @@ import ( | ||||
| 	"fonchain-fiee/pkg/service/bundle/common" | ||||
| 	"fonchain-fiee/pkg/service/bundle/logic" | ||||
| 	bundleModel "fonchain-fiee/pkg/service/bundle/model" | ||||
| 	"math/big" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/gin-gonic/gin/binding" | ||||
| ) | ||||
| 
 | ||||
| func CreateBundleOrderAddSignature(c *gin.Context) { | ||||
| 	var req bundle.OrderAddRecord | ||||
| 
 | ||||
| 	if err := c.ShouldBindBodyWith(&req, binding.JSON); err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 	if req.Language == "" { | ||||
| 		req.Language = c.GetHeader("Accept-Language") | ||||
| 		service.Error(c, errors.New(common.MissLanguageTypes)) | ||||
| 		return | ||||
| 	} | ||||
| 	if req.BundleUuid == "" { | ||||
| 		service.Error(c, errors.New(common.MissOrderNo)) | ||||
| 		return | ||||
| 	} | ||||
| 	// 获取用户信息
 | ||||
| 	userInfo := login.GetUserInfoFromC(c) | ||||
| 	if msg, exists := map[int32]string{ | ||||
| 		1: common.Unnamed, | ||||
| 		2: common.UnderReview, | ||||
| 		3: common.ReviewFailed, | ||||
| 	}[userInfo.Status]; userInfo.Status != 4 { | ||||
| 		if exists { | ||||
| 			service.Error(c, errors.New(msg)) | ||||
| 		} else { | ||||
| 			service.Error(c, errors.New(common.UnknownStatus)) | ||||
| 		} | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	// 校验套餐是否已购买
 | ||||
| 	orderRecordReq := bundle.OrderRecordsDetailRequest{ | ||||
| 		BundleUUID: req.BundleUuid, | ||||
| 		CustomerID: strconv.FormatUint(userInfo.ID, 10), | ||||
| 	} | ||||
| 	orderRecordResp, err := service.BundleProvider.OrderRecordsDetail(context.Background(), &orderRecordReq) | ||||
| 	if err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 	if orderRecordResp.OrderRecord.ExpirationTime == "" || orderRecordResp.OrderRecord.ExpirationTime < time.Now().Format("2006-01-02") { | ||||
| 		service.Error(c, errors.New(common.ThePackageHasExpired)) | ||||
| 		return | ||||
| 	} | ||||
| 	// 获取套餐详情(待替换逻辑)
 | ||||
| 	//bundleDetail, err := service.BundleProvider.BundleDetail(context.Background(), &bundle.BundleDetailRequest{
 | ||||
| 	//	Uuid: req.BundleUuid,
 | ||||
| 	//})
 | ||||
| 	//if err != nil {
 | ||||
| 	//	service.Error(c, err)
 | ||||
| 	//	return
 | ||||
| 	//}
 | ||||
| 	// todo 需要判断购买的增值服务是否为可用时长  如果为可以用时长  合同截止日期为购买时长时间  否则合同截止日期为主套餐截止日期
 | ||||
| 	// 处理多个增值服务
 | ||||
| 	type ValueAddServiceInfo struct { | ||||
| 		Service *bundle.ValueAddServiceLang | ||||
| 		Options *bundle.ValueAddPriceOptions | ||||
| 		ID      int32 | ||||
| 	} | ||||
| 	// 计算总金额和确定截止日期
 | ||||
| 	//var expirationDate string
 | ||||
| 	var addPriceList []*bundle.AddPriceOptionsInfo | ||||
| 	var totalAmount float32 | ||||
| 	for _, svc := range req.AddPriceOptionsList { | ||||
| 		valueAddInfo, err := service.BundleProvider.ValueAddServiceLangByUuidAndLanguage(context.Background(), &bundle.ValueAddServiceDetailRequest{ | ||||
| 			Uuid:     svc.ValueUid, | ||||
| 			Language: req.Language, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 		valuePrice, err := service.BundleProvider.CalculatePrice(context.Background(), &bundle.CalculatePriceRequest{ | ||||
| 			Uuid:     svc.ValueUid, | ||||
| 			Num:      svc.Num, | ||||
| 			Language: req.Language, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 		totalAmount += valuePrice.Price | ||||
| 		addPriceList = append(addPriceList, &bundle.AddPriceOptionsInfo{ | ||||
| 			ValueUid:     valueAddInfo.Uuid, | ||||
| 			ServiceType:  valueAddInfo.ServiceType, | ||||
| 			CurrencyType: valueAddInfo.PriceType, | ||||
| 			Amount:       valuePrice.Price, | ||||
| 			Num:          svc.Num, | ||||
| 			Unit:         valueAddInfo.Unit, | ||||
| 		}) | ||||
| 		// 如果是可用时长服务,计算新的截止日期 todo 不需要计算到期时间 在完成支付时添加
 | ||||
| 		/*if valueAddInfo.ServiceType == 5 { | ||||
| 			endDate := orderRecordResp.OrderRecord.ExpirationTime | ||||
| 			if endDate == "9999-12-31" { | ||||
| 				service.Error(c, errors.New(common.ErrorPermanentPackage)) | ||||
| 				return | ||||
| 			} | ||||
| 			t, err := time.Parse("2006-01-02", endDate) | ||||
| 			if err != nil { | ||||
| 				fmt.Println("解析时间出错:", err) | ||||
| 				return | ||||
| 			} | ||||
| 			newDeadline := calculateExpirationDate(t, svc.Num, valueAddInfo.Unit) | ||||
| 			expirationDate = newDeadline | ||||
| 			//}
 | ||||
| 		}*/ | ||||
| 	} | ||||
| 	// 如果没有可用时长服务,使用主套餐截止日期
 | ||||
| 	//if expirationDate == "" {
 | ||||
| 	//	expirationDate = orderRecordResp.OrderRecord.ExpirationTime
 | ||||
| 	//}
 | ||||
| 	req.CustomerNum = userInfo.SubNum | ||||
| 	req.CustomerName = userInfo.Name | ||||
| 	req.CustomerID = strconv.FormatUint(userInfo.ID, 10) | ||||
| 	req.Source = 2 | ||||
| 	//req.SignedTime = common.GetBeijingTime()
 | ||||
| 	//req.ExpirationDate = expirationDate
 | ||||
| 	req.AddPriceOptionsList = addPriceList | ||||
| 	req.OrderUUID = orderRecordResp.OrderRecord.Uuid | ||||
| 	// 当前 未将 签名 写入合同中 todo 购买增值服务取消签约合同
 | ||||
| 	//signContract, signContractErr := logic.SignContractV2(req.CustomerNum, bundleDetail.Bundle.Contract, totalAmount, expirationDate)
 | ||||
| 	//if signContractErr != nil {
 | ||||
| 	//	service.Error(c, signContractErr)
 | ||||
| 	//	return
 | ||||
| 	//}
 | ||||
| 	//req.SignContract = signContract
 | ||||
| 	// 创建增值服务订单记录
 | ||||
| 	res, err := service.BundleProvider.CreateOrderAddRecord(context.Background(), &req) | ||||
| 	if err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 	service.Success(c, res) | ||||
| } | ||||
| 
 | ||||
| // 计算截止日期辅助函数
 | ||||
| func calculateExpirationDate(startDate time.Time, num int32, unit string) string { | ||||
| 	//now := time.Now()
 | ||||
| 	switch unit { | ||||
| 	case "天": | ||||
| 		return startDate.AddDate(0, 0, int(num)).Format("2006-01-02") | ||||
| 	case "月": | ||||
| 		return startDate.AddDate(0, int(num), 0).Format("2006-01-02") | ||||
| 	case "年": | ||||
| 		return startDate.AddDate(int(num), 0, 0).Format("2006-01-02") | ||||
| 	default: | ||||
| 		return "" | ||||
| 	} | ||||
| } | ||||
| func CreateBundleOrderSignature(c *gin.Context) { | ||||
| 	var req bundle.OrderRecord | ||||
| 	var req bundle.OrderCreateRecord | ||||
| 
 | ||||
| 	if err := c.ShouldBindBodyWith(&req, binding.JSON); err != nil { | ||||
| 		service.Error(c, err) | ||||
| @ -32,16 +182,32 @@ func CreateBundleOrderSignature(c *gin.Context) { | ||||
| 		service.Error(c, errors.New(common.MissBundleUUID)) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	if req.Language == "" { | ||||
| 		req.Language = c.GetHeader("Accept-Language") | ||||
| 		service.Error(c, errors.New(common.MissLanguageTypes)) | ||||
| 		return | ||||
| 	} | ||||
| 	// 不去校验 签名
 | ||||
| 	/*if req.Signature == "" { | ||||
| 		service.Error(c, errors.New(common.MissOrderSignature)) | ||||
| 		return | ||||
| 	}*/ | ||||
| 
 | ||||
| 	statusMessages := map[int32]string{ | ||||
| 		1: common.Unnamed, | ||||
| 		2: common.UnderReview, | ||||
| 		3: common.ReviewFailed, | ||||
| 	} | ||||
| 	// 获取 用户信息
 | ||||
| 	userInfo := login.GetUserInfoFromC(c) | ||||
| 
 | ||||
| 	if userInfo.Status != 4 { | ||||
| 		if msg, exists := statusMessages[userInfo.Status]; exists { | ||||
| 			service.Error(c, errors.New(msg)) | ||||
| 			return | ||||
| 		} else { | ||||
| 			service.Error(c, errors.New(common.UnknownStatus)) | ||||
| 			return | ||||
| 		} | ||||
| 	} | ||||
| 	// 校验 当前用户只能买一次套餐
 | ||||
| 	orderRecordsListReq := bundle.OrderRecordsRequest{ | ||||
| 		CustomerID: strconv.FormatUint(userInfo.ID, 10), | ||||
| @ -51,10 +217,10 @@ func CreateBundleOrderSignature(c *gin.Context) { | ||||
| 		service.Error(c, orderRecordsListErr) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	//有套餐并且套餐未过期
 | ||||
| 	if orderRecordsList.OrderRecords != nil { | ||||
| 		for _, order := range orderRecordsList.OrderRecords { | ||||
| 			if order.CustomerID == strconv.FormatUint(userInfo.ID, 10) { | ||||
| 		for _, orderInfo := range orderRecordsList.OrderRecords { | ||||
| 			if orderInfo.CustomerID == strconv.FormatUint(userInfo.ID, 10) && orderInfo.ExpirationTime > time.Now().Format("2006-01-02") { | ||||
| 				service.Error(c, errors.New(common.HadOrder)) | ||||
| 				return | ||||
| 			} | ||||
| @ -71,19 +237,12 @@ func CreateBundleOrderSignature(c *gin.Context) { | ||||
| 		service.Error(c, lastOrderRecordErr) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	lastContractNo := "" | ||||
| 
 | ||||
| 	if lastOrderRecord.OrderRecords != nil { | ||||
| 		for _, lastOrder := range lastOrderRecord.OrderRecords { | ||||
| 			lastContractNo = lastOrder.ContractNo | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	req.CustomerNum = userInfo.SubNum | ||||
| 	req.CustomerName = userInfo.Name | ||||
| 	req.CustomerID = strconv.FormatUint(userInfo.ID, 10) | ||||
| 
 | ||||
| 	// 获取 套餐信息
 | ||||
| 	bundleDetailReq := &bundle.BundleDetailRequest{ | ||||
| 		Uuid: req.BundleUuid, | ||||
| @ -93,62 +252,73 @@ func CreateBundleOrderSignature(c *gin.Context) { | ||||
| 		service.Error(c, detailErr) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	//获取增值套餐信息
 | ||||
| 	if req.ValueAddBundleUuid != "" { | ||||
| 		valueAddBundleDetail, err := service.BundleProvider.ValueAddBundleDetail(context.Background(), &bundle.ValueAddBundleDetailRequest{ | ||||
| 			Uuid: req.ValueAddBundleUuid, | ||||
| 	//获取过期时间和增值服务金额
 | ||||
| 	var addRecords []*bundle.OrderCreateAddRecord | ||||
| 	var addTotalPrice float32 | ||||
| 	var expirationDay string | ||||
| 	for _, i := range req.AddRecords { | ||||
| 		price, err := service.BundleProvider.CalculatePrice(context.Background(), &bundle.CalculatePriceRequest{ | ||||
| 			Uuid:     i.ValueUid, | ||||
| 			Num:      i.Num, | ||||
| 			Language: req.Language, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		req.ValueAddBundleUuid = valueAddBundleDetail.Data.Uuid | ||||
| 		req.ValueAddOriginalPrice = valueAddBundleDetail.Data.OriginalPrice | ||||
| 		req.ValueAddDiscountPrice = valueAddBundleDetail.Data.DiscountPrice | ||||
| 		req.AddBundleCommonUid = valueAddBundleDetail.Data.AddBundleCommonUid | ||||
| 
 | ||||
| 		if valueAddBundleDetail.Data.Choose { // 可选条数
 | ||||
| 			req.ValueAddBundleAmount = valueAddBundleDetail.Data.DiscountPrice * float32(req.Num) | ||||
| 			discount, _ := new(big.Float).Sub(big.NewFloat(float64(valueAddBundleDetail.Data.OriginalPrice)), big.NewFloat(float64(valueAddBundleDetail.Data.DiscountPrice))).Float32() | ||||
| 			req.ValueAddSavedAmount = discount * float32(req.Num) | ||||
| 		} else { // 固定条数
 | ||||
| 			req.ValueAddBundleAmount = valueAddBundleDetail.Data.TotalPrice | ||||
| 			req.ValueAddSavedAmount = valueAddBundleDetail.Data.SavedAmount | ||||
| 		addTotalPrice += price.Price | ||||
| 		addService, err := service.BundleProvider.ValueAddServiceLangByUuidAndLanguage(context.Background(), &bundle.ValueAddServiceDetailRequest{ | ||||
| 			Uuid:     i.ValueUid, | ||||
| 			Language: req.Language, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		req.TotalAmount, _ = new(big.Float).Add(big.NewFloat(float64(req.ValueAddBundleAmount)), big.NewFloat(float64(bundleDetail.Bundle.Price))).Float32() | ||||
| 		addRecords = append(addRecords, &bundle.OrderCreateAddRecord{ | ||||
| 			ServiceType:   addService.ServiceType, | ||||
| 			ValueUid:      i.ValueUid, | ||||
| 			CurrencyType:  addService.PriceType, | ||||
| 			Amount:        price.Price, | ||||
| 			Num:           i.Num, | ||||
| 			Unit:          addService.Unit, | ||||
| 			Source:        1, | ||||
| 			PaymentStatus: 1, | ||||
| 		}) | ||||
| 		//服务类型为时长 计算
 | ||||
| 		if addService.ServiceType == 5 { | ||||
| 			expirationDay = calculateExpirationDate(time.Now(), i.Num, addService.Unit) | ||||
| 		} else { | ||||
| 			expirationDay = time.Now().AddDate(0, 0, 7).Format("2006-01-02") | ||||
| 		} | ||||
| 
 | ||||
| 	req.BundleName = bundleDetail.Bundle.Name | ||||
| 	req.Amount = bundleDetail.Bundle.Price | ||||
| 	req.AmountType = bundleDetail.Bundle.PriceType | ||||
| 	req.BundleCommonUid = bundleDetail.Bundle.BundleCommonUid | ||||
| 	req.TotalAmount = req.Amount + req.ValueAddBundleAmount | ||||
| 	req.PayType = 1 // 默认 人民币
 | ||||
| 
 | ||||
| 	req.ContractNo = common.GenerateContractNo(lastContractNo) | ||||
| 
 | ||||
| 	// 当前 未将 签名 写入合同中
 | ||||
| 	signContract, signContractErr := logic.SignContractV2(req.CustomerNum, bundleDetail.Bundle.Contract, req.TotalAmount, bundleDetail.Bundle.ContractDuration) | ||||
| 	} | ||||
| 	// 当前 未将 签名 写入合同中 todo 金额和有效时间待修改
 | ||||
| 	signContract, signContractErr := logic.SignContractV2(req.CustomerNum, bundleDetail.Bundle.Contract, addTotalPrice, expirationDay) | ||||
| 	if signContractErr != nil { | ||||
| 		service.Error(c, signContractErr) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	req.CustomerNum = userInfo.SubNum | ||||
| 	req.CustomerName = userInfo.Name | ||||
| 	req.CustomerID = strconv.FormatUint(userInfo.ID, 10) | ||||
| 	req.BundleName = bundleDetail.Bundle.Name | ||||
| 	req.Amount = bundleDetail.Bundle.Price | ||||
| 	req.AmountType = bundleDetail.Bundle.PriceType | ||||
| 	req.BundleCommonUid = bundleDetail.Bundle.BundleCommonUid | ||||
| 	req.TotalAmount = bundleDetail.Bundle.Price + addTotalPrice | ||||
| 	req.ContractNo = common.GenerateContractNo(lastContractNo) | ||||
| 	req.SignContract = signContract | ||||
| 
 | ||||
| 	req.SignedTime = common.GetBeijingTime() | ||||
| 
 | ||||
| 	req.Status = bundleModel.OrderSigned | ||||
| 	req.AddRecords = addRecords | ||||
| 	//req.ExpirationTime = expirationDay //过期日期取消 在完成支付是更新
 | ||||
| 	req.PayType = 1 | ||||
| 
 | ||||
| 	res, err := service.BundleProvider.CreateOrderRecord(context.Background(), &req) | ||||
| 	if err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	service.Success(c, res) | ||||
| } | ||||
| 
 | ||||
| @ -230,7 +400,87 @@ func UpdateBundleOrderStatusPaid(c *gin.Context) { | ||||
| 
 | ||||
| 	service.Success(c, nil) | ||||
| } | ||||
| func OrderRecordsListV2(c *gin.Context) { | ||||
| 	var req bundle.OrderRecordsRequestV2 | ||||
| 	if err := c.ShouldBindBodyWith(&req, binding.JSON); err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	res := &bundle.OrderRecordsResponseV2{} | ||||
| 
 | ||||
| 	// Step 1: 如果有姓名/电话筛选,先查用户列表
 | ||||
| 	if req.CustomerName != "" { | ||||
| 		userListResp, err := service.AccountFieeProvider.UserList(context.Background(), &accountFiee.UserListRequest{ | ||||
| 			BlurNameTel: req.CustomerName, | ||||
| 			Domain:      "app", | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		if len(userListResp.UserList) == 0 { | ||||
| 			// 没查到用户,直接返回空结果
 | ||||
| 			res.Page = req.Page | ||||
| 			res.PageSize = req.PageSize | ||||
| 			res.Total = 0 | ||||
| 			service.Success(c, res) | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		// 提取用户ID列表
 | ||||
| 		for _, u := range userListResp.UserList { | ||||
| 			req.UserIds = append(req.UserIds, int64(u.Id)) | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Step 2: 查询订单列表
 | ||||
| 	orderList, err := service.BundleProvider.OrderRecordsListV2(context.Background(), &req) | ||||
| 	if err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	// Step 3: 如果订单不为空,查一次用户信息填充(只查一次)
 | ||||
| 	if len(orderList.BundleInfo) > 0 { | ||||
| 		// 收集订单里的所有用户ID
 | ||||
| 		userIdSet := make(map[int64]struct{}) | ||||
| 		for _, i := range orderList.BundleInfo { | ||||
| 			userIdSet[i.CustomerId] = struct{}{} | ||||
| 		} | ||||
| 
 | ||||
| 		var userIds []int64 | ||||
| 		for id := range userIdSet { | ||||
| 			userIds = append(userIds, id) | ||||
| 		} | ||||
| 
 | ||||
| 		userListResp, err := service.AccountFieeProvider.UserList(context.Background(), &accountFiee.UserListRequest{ | ||||
| 			Ids:    userIds, | ||||
| 			Domain: "app", | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		// 建立用户ID -> 用户信息映射
 | ||||
| 		userMap := make(map[int64]*accountFiee.UserListInfo, len(userListResp.UserList)) | ||||
| 		for _, u := range userListResp.UserList { | ||||
| 			userMap[int64(u.Id)] = u | ||||
| 		} | ||||
| 
 | ||||
| 		// 填充订单中的用户信息
 | ||||
| 		for _, item := range orderList.BundleInfo { | ||||
| 			if u, ok := userMap[item.CustomerId]; ok { | ||||
| 				item.CustomerName = u.Name | ||||
| 				item.TelNum = u.TelNum | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	service.Success(c, orderList) | ||||
| } | ||||
| func OrderRecordsList(c *gin.Context) { | ||||
| 	var req bundle.OrderRecordsRequest | ||||
| 
 | ||||
| @ -286,10 +536,10 @@ func OrderRecordsDetail(c *gin.Context) { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	/*// 获取 用户信息
 | ||||
| 	// 获取 用户信息
 | ||||
| 	userInfo := login.GetUserInfoFromC(c) | ||||
| 
 | ||||
| 	req.CustomerID = strconv.FormatUint(userInfo.ID, 10)*/ | ||||
| 	req.CustomerID = strconv.FormatUint(userInfo.ID, 10) | ||||
| 
 | ||||
| 	res, err := service.BundleProvider.OrderRecordsDetail(context.Background(), &req) | ||||
| 	if err != nil { | ||||
|  | ||||
| @ -11,6 +11,7 @@ const ( | ||||
| const ( | ||||
| 	MissOrderNo       = "缺少订单号" | ||||
| 	MissOrderUUID     = "缺少订单信息" | ||||
| 	MissLanguageTypes = "缺少语言类型" | ||||
| 
 | ||||
| 	NotMatchOrderInfo  = "非当前用户订单信息不可操作" | ||||
| 	InvalidOrderAmount = "订单金额错误" | ||||
| @ -19,8 +20,17 @@ const ( | ||||
| 
 | ||||
| 	HadOrder                 = "您已购买过套餐,无法再次购买" | ||||
| 	InvalidValueAddBundleNum = "套餐数量无效" | ||||
| 	ThePackageHasExpired     = "当前套餐已过期" | ||||
| 	ErrorPermanentPackage    = "永久套餐无需购买" | ||||
| ) | ||||
| const ( | ||||
| 	OrderTypePackage = 1 // 套餐
 | ||||
| 	OrderTypeAddon   = 2 // 增值服务
 | ||||
| 
 | ||||
| 	TimeUnitDay   = 1 | ||||
| 	TimeUnitMonth = 2 | ||||
| 	TimeUnitYear  = 3 | ||||
| ) | ||||
| const ( | ||||
| 	ErrorExportOrderInfo = "导出订单信息失败" | ||||
| ) | ||||
| @ -34,6 +44,12 @@ const ( | ||||
| 	ErrorDownloadFile = "下载文件失败" | ||||
| 	ErrorUploadFile   = "上传文件失败" | ||||
| ) | ||||
| const ( | ||||
| 	Unnamed       = "请先实名" | ||||
| 	UnderReview   = "实名审核中" | ||||
| 	ReviewFailed  = "实名审核失败" | ||||
| 	UnknownStatus = "未知实名状态" | ||||
| ) | ||||
| 
 | ||||
| /*var EnMessages = map[string]string{ | ||||
| 	"创建套餐信息失败":       "Failed to create bundle information", | ||||
|  | ||||
| @ -14,7 +14,7 @@ import ( | ||||
| 	"time" | ||||
| ) | ||||
| 
 | ||||
| func SignContractV2(customerNum, contract string, price float32, contractDuration int64) (outputUrl string, err error) { | ||||
| func SignContractV2(customerNum, contract string, price float32, expirationDate string) (outputUrl string, err error) { | ||||
| 	filePath := model.MediaPath + customerNum + time.Now().Format("20060102150405") + ".pdf" | ||||
| 	downloadFileErr := DownloadFile(filePath, contract) | ||||
| 	if downloadFileErr != nil { | ||||
| @ -31,7 +31,7 @@ func SignContractV2(customerNum, contract string, price float32, contractDuratio | ||||
| 		return outputUrl, errors.New(common.ErrorInsertSignature) | ||||
| 	}*/ | ||||
| 
 | ||||
| 	signErr := InsertSignatureV2(filePath, signFile, price, contractDuration) | ||||
| 	signErr := InsertSignatureV2(filePath, signFile, price, expirationDate) | ||||
| 	if signErr != nil { | ||||
| 		zap.L().Error("insert signature error: ", zap.Error(signErr)) | ||||
| 		return outputUrl, errors.New(common.ErrorInsertSignature) | ||||
| @ -46,7 +46,7 @@ func SignContractV2(customerNum, contract string, price float32, contractDuratio | ||||
| 	return outputUrl, nil | ||||
| } | ||||
| 
 | ||||
| func InsertSignatureV2(templatePath, outputPath string, price float32, contractDuration int64) error { | ||||
| func InsertSignatureV2(templatePath, outputPath string, price float32, expirationDate string) error { | ||||
| 	pdf := gopdf.GoPdf{} | ||||
| 	pdf.Start(gopdf.Config{PageSize: *gopdf.PageSizeA4}) | ||||
| 
 | ||||
| @ -90,22 +90,28 @@ func InsertSignatureV2(templatePath, outputPath string, price float32, contractD | ||||
| 	pdf.SetPage(limitTimePage) | ||||
| 
 | ||||
| 	//  英文格式的时间
 | ||||
| 	t := time.Now().AddDate(int(contractDuration), 0, 0) | ||||
| 	parsedTime, err := time.Parse("2006-01-02", expirationDate) | ||||
| 	if err != nil { | ||||
| 		panic("日期格式错误!") | ||||
| 	} | ||||
| 	year := parsedTime.Format("2006") // "2006"
 | ||||
| 	month := parsedTime.Format("01")  // "01"
 | ||||
| 	day := parsedTime.Format("02")    // "02"
 | ||||
| 	pdf.SetX(160) | ||||
| 	pdf.SetY(387) | ||||
| 	pdf.Cell(nil, t.Format("2006-01-02")) | ||||
| 	pdf.Cell(nil, expirationDate) | ||||
| 
 | ||||
| 	pdf.SetX(330) | ||||
| 	pdf.SetY(403) | ||||
| 	pdf.Cell(nil, t.Format("2006")) | ||||
| 	pdf.Cell(nil, year) | ||||
| 
 | ||||
| 	pdf.SetX(396) | ||||
| 	pdf.SetY(403) | ||||
| 	pdf.Cell(nil, t.Format("01")) | ||||
| 	pdf.Cell(nil, month) | ||||
| 
 | ||||
| 	pdf.SetX(443) | ||||
| 	pdf.SetY(403) | ||||
| 	pdf.Cell(nil, t.Format("02")) | ||||
| 	pdf.Cell(nil, day) | ||||
| 
 | ||||
| 	// 生成新的 PDF
 | ||||
| 	if err = pdf.WritePdf(outputPath); err != nil { | ||||
|  | ||||
| @ -5,6 +5,7 @@ import ( | ||||
| 	"encoding/json" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"fonchain-fiee/api/accountFiee" | ||||
| 	"fonchain-fiee/api/bundle" | ||||
| 	"fonchain-fiee/api/order" | ||||
| 	"fonchain-fiee/api/payment" | ||||
| @ -249,7 +250,18 @@ func CreateAntomPay(c *gin.Context) { | ||||
| 		service.Error(c, updateOrderRecordErr) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	////创建对账单 todo 待修改
 | ||||
| 	//_, err = service.BundleProvider.CreateReconciliation(context.Background(), &bundle.ReconciliationInfo{
 | ||||
| 	//	BundleOrderOn:    detail.OrderRecord.OrderNo,
 | ||||
| 	//	BundleAddOrderOn: detail.OrderRecord.OrderNo,
 | ||||
| 	//	UserName:         userInfo.Name,
 | ||||
| 	//	UserTel:          userInfo.TelNum,
 | ||||
| 	//	BundleName:       detail.OrderRecord.BundleName,
 | ||||
| 	//	Amount:           detail.OrderRecord.TotalAmount,
 | ||||
| 	//	CurrencyType:     int32(detail.OrderRecord.AmountType),
 | ||||
| 	//	PayStatus:        1,
 | ||||
| 	//	UserId:           userInfo.ID,
 | ||||
| 	//})
 | ||||
| 	service.Success(c, resp) | ||||
| 
 | ||||
| } | ||||
| @ -362,7 +374,128 @@ func AntomWebhook(c *gin.Context) { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		//添加余额
 | ||||
| 		orderLimit, err := service.BundleProvider.OrderListByOrderNo(context.Background(), &bundle.OrderInfoByOrderNoRequest{ | ||||
| 			OrderNo: resp.OutTradeNo, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 		//购买套餐
 | ||||
| 		switch orderLimit.Type { | ||||
| 		case common.OrderTypePackage: | ||||
| 			//如果是购买套餐 1:创建新的余量信息CreateBundleBalance 2 添加扩展记录BundleExtend
 | ||||
| 			_, err = service.BundleProvider.CreateBundleBalance(context.Background(), &bundle.CreateBundleBalanceReq{ | ||||
| 				UserId:               int32(orderLimit.UserId), | ||||
| 				OrderUUID:            orderLimit.OrderUUID, | ||||
| 				AccountNumber:        orderLimit.AccountNumber, | ||||
| 				VideoNumber:          orderLimit.VideoNumber, | ||||
| 				ImageNumber:          orderLimit.ImageNumber, | ||||
| 				DataAnalysisNumber:   orderLimit.DataNumber, | ||||
| 				ExpansionPacksNumber: 1, | ||||
| 			}) | ||||
| 			if err != nil { | ||||
| 				service.Error(c, err) | ||||
| 				return | ||||
| 			} | ||||
| 		case common.OrderTypeAddon: | ||||
| 			//如果是购买增值服务 1:修改余量信息AddBundleBalance 2 添加扩展记录BundleExtend
 | ||||
| 			_, err = service.BundleProvider.AddBundleBalance(context.Background(), &bundle.AddBundleBalanceReq{ | ||||
| 				UserId:               int32(orderLimit.UserId), | ||||
| 				OrderUUID:            orderLimit.OrderUUID, | ||||
| 				AccountNumber:        orderLimit.AccountNumber, | ||||
| 				VideoNumber:          orderLimit.VideoNumber, | ||||
| 				ImageNumber:          orderLimit.ImageNumber, | ||||
| 				DataAnalysisNumber:   orderLimit.DataNumber, | ||||
| 				ExpansionPacksNumber: 1, | ||||
| 			}) | ||||
| 			if err != nil { | ||||
| 				service.Error(c, err) | ||||
| 				return | ||||
| 			} | ||||
| 		default: | ||||
| 			service.Error(c, errors.New("无效的订单类型")) | ||||
| 			return | ||||
| 		} | ||||
| 		var timeUnit uint32 | ||||
| 		switch orderLimit.Unit { | ||||
| 		case "天": | ||||
| 			timeUnit = common.TimeUnitDay | ||||
| 		case "月": | ||||
| 			timeUnit = common.TimeUnitMonth | ||||
| 		case "年": | ||||
| 			timeUnit = common.TimeUnitYear | ||||
| 		default: | ||||
| 			timeUnit = 0 | ||||
| 		} | ||||
| 		_, err = service.BundleProvider.BundleExtend(context.Background(), &bundle.BundleExtendRequest{ | ||||
| 			UserId:                      int64(orderLimit.UserId), | ||||
| 			AccountAdditional:           uint32(orderLimit.AccountNumber), | ||||
| 			VideoAdditional:             uint32(orderLimit.VideoNumber), | ||||
| 			ImagesAdditional:            uint32(orderLimit.ImageNumber), | ||||
| 			DataAdditional:              uint32(orderLimit.DataNumber), | ||||
| 			AvailableDurationAdditional: uint32(orderLimit.Duration), | ||||
| 			TimeUnit:                    timeUnit, | ||||
| 			AssociatedorderNumber:       resp.OutTradeNo, //增值服务订单号
 | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			service.Error(c, err) | ||||
| 			return | ||||
| 		} | ||||
| 	} | ||||
| 	service.Success(c) | ||||
| } | ||||
| func HomePageRoll(c *gin.Context) { | ||||
| 	//var req order.HomePageRollRequest
 | ||||
| 	res, err := service.BundleProvider.OrderRecordsListV2(context.Background(), &bundle.OrderRecordsRequestV2{ | ||||
| 		Page:     1, | ||||
| 		PageSize: 5, | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 	if len(res.BundleInfo) == 0 { | ||||
| 		service.Success(c, nil) | ||||
| 		return | ||||
| 	} | ||||
| 	type Roll struct { | ||||
| 		Tel  string `json:"tel"` | ||||
| 		Name string `json:"name"` | ||||
| 	} | ||||
| 	var userIds []int64 | ||||
| 	for _, i := range res.BundleInfo { | ||||
| 		userIds = append(userIds, i.CustomerId) | ||||
| 	} | ||||
| 	userListResp, err := service.AccountFieeProvider.UserList(context.Background(), &accountFiee.UserListRequest{ | ||||
| 		Ids:    userIds, | ||||
| 		Domain: "app", | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	// 建立用户ID -> 用户信息映射
 | ||||
| 	userMap := make(map[int64]*accountFiee.UserListInfo, len(userListResp.UserList)) | ||||
| 	for _, u := range userListResp.UserList { | ||||
| 		userMap[int64(u.Id)] = u | ||||
| 	} | ||||
| 
 | ||||
| 	var roll []Roll | ||||
| 	for _, i := range res.BundleInfo { | ||||
| 		maskedTel := userMap[i.CustomerId].TelNum | ||||
| 		if len(userMap[i.CustomerId].TelNum) >= 11 { // 标准11位手机号
 | ||||
| 			maskedTel = userMap[i.CustomerId].TelNum[:3] + "****" + userMap[i.CustomerId].TelNum[7:] | ||||
| 		} else if len(userMap[i.CustomerId].TelNum) >= 7 { // 短号处理
 | ||||
| 			maskedTel = userMap[i.CustomerId].TelNum[:3] + "****" + userMap[i.CustomerId].TelNum[7:] | ||||
| 		} | ||||
| 		roll = append(roll, Roll{ | ||||
| 			Tel:  maskedTel, | ||||
| 			Name: i.BundleName, | ||||
| 		}) | ||||
| 	} | ||||
| 	service.Success(c, roll) | ||||
| 	return | ||||
| } | ||||
|  | ||||
							
								
								
									
										25
									
								
								pkg/service/bundle/reconciliation.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								pkg/service/bundle/reconciliation.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | ||||
| package bundle | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"fonchain-fiee/api/bundle" | ||||
| 	"fonchain-fiee/pkg/service" | ||||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/gin-gonic/gin/binding" | ||||
| ) | ||||
| 
 | ||||
| func GetReconciliationList(c *gin.Context) { | ||||
| 	var req bundle.GetReconciliationListReq | ||||
| 	if err := c.ShouldBindBodyWith(&req, binding.JSON); err != nil { | ||||
| 		service.Error(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 	detail, detailErr := service.BundleProvider.GetReconciliationList(context.Background(), &req) | ||||
| 	if detailErr != nil { | ||||
| 		service.Error(c, detailErr) | ||||
| 		return | ||||
| 	} | ||||
| 	service.Success(c, detail) | ||||
| 	return | ||||
| 
 | ||||
| } | ||||
| @ -23,9 +23,9 @@ var PaymentProvider = new(payment.PaymentCentClientImpl) | ||||
| 
 | ||||
| func init() { | ||||
| 	config.SetConsumerService(BundleProvider) | ||||
| 	config.SetConsumerService(OrderProvider) | ||||
| 	config.SetConsumerService(AccountProvider) | ||||
| 	config.SetConsumerService(PaymentProvider) | ||||
| 	//config.SetConsumerService(OrderProvider)
 | ||||
| 	//config.SetConsumerService(AccountProvider)
 | ||||
| 	//config.SetConsumerService(PaymentProvider)
 | ||||
| 	config.SetConsumerService(AccountFieeProvider) | ||||
| 
 | ||||
| 	if err := config.Load(); err != nil { | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user