Compare commits
	
		
			No commits in common. "1dd8ccf3b7f0f876da674ad37043543295801ef5" and "4b9e6eb7bd0b8218c07580a544266f05883b67de" have entirely different histories.
		
	
	
		
			1dd8ccf3b7
			...
			4b9e6eb7bd
		
	
		
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -5,11 +5,11 @@ package bundle | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	fmt "fmt" | 	fmt "fmt" | ||||||
|  | 	math "math" | ||||||
| 	proto "github.com/golang/protobuf/proto" | 	proto "github.com/golang/protobuf/proto" | ||||||
|  | 	_ "google.golang.org/protobuf/types/descriptorpb" | ||||||
| 	_ "github.com/mwitkow/go-proto-validators" | 	_ "github.com/mwitkow/go-proto-validators" | ||||||
| 	github_com_mwitkow_go_proto_validators "github.com/mwitkow/go-proto-validators" | 	github_com_mwitkow_go_proto_validators "github.com/mwitkow/go-proto-validators" | ||||||
| 	_ "google.golang.org/protobuf/types/descriptorpb" |  | ||||||
| 	math "math" |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // Reference imports to suppress errors if they are not otherwise used.
 | // Reference imports to suppress errors if they are not otherwise used.
 | ||||||
|  | |||||||
| @ -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.8
 | // - protoc-gen-go-triple v1.0.8
 | ||||||
| // - protoc             v4.24.0--rc1
 | // - protoc             v3.20.3
 | ||||||
| // source: pb/bundle.proto
 | // source: pb/bundle.proto
 | ||||||
| 
 | 
 | ||||||
| package bundle | package bundle | ||||||
| @ -47,11 +47,11 @@ type BundleClient interface { | |||||||
| 	PackagePriceAndTime(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*PackagePriceAndTimeResponse, common.ErrorWithAttachment) | 	PackagePriceAndTime(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*PackagePriceAndTimeResponse, common.ErrorWithAttachment) | ||||||
| 	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) | ||||||
| 	//增值套餐
 | 	// 增值套餐
 | ||||||
| 	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) | ||||||
| @ -69,7 +69,7 @@ type BundleClient interface { | |||||||
| 	GetImageWorkDetail(ctx context.Context, in *GetImageWorkDetailReq, opts ...grpc_go.CallOption) (*GetImageWorkDetailResp, common.ErrorWithAttachment) | 	GetImageWorkDetail(ctx context.Context, in *GetImageWorkDetailReq, opts ...grpc_go.CallOption) (*GetImageWorkDetailResp, common.ErrorWithAttachment) | ||||||
| 	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) | ||||||
| 	//对账单
 | 	// 对账单
 | ||||||
| 	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) | ||||||
| @ -397,11 +397,11 @@ type BundleServer interface { | |||||||
| 	PackagePriceAndTime(context.Context, *OrderRecord) (*PackagePriceAndTimeResponse, error) | 	PackagePriceAndTime(context.Context, *OrderRecord) (*PackagePriceAndTimeResponse, error) | ||||||
| 	OrderRecordsListV2(context.Context, *OrderRecordsRequestV2) (*OrderRecordsResponseV2, error) | 	OrderRecordsListV2(context.Context, *OrderRecordsRequestV2) (*OrderRecordsResponseV2, error) | ||||||
| 	OrderListByOrderNo(context.Context, *OrderInfoByOrderNoRequest) (*OrderInfoByOrderNoResp, error) | 	OrderListByOrderNo(context.Context, *OrderInfoByOrderNoRequest) (*OrderInfoByOrderNoResp, 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) | ||||||
| @ -419,7 +419,7 @@ type BundleServer interface { | |||||||
| 	GetImageWorkDetail(context.Context, *GetImageWorkDetailReq) (*GetImageWorkDetailResp, error) | 	GetImageWorkDetail(context.Context, *GetImageWorkDetailReq) (*GetImageWorkDetailResp, error) | ||||||
| 	GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | 	GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | ||||||
| 	ToBeComfirmedWorks(context.Context, *ToBeComfirmedWorksReq) (*ToBeComfirmedWorksResp, error) | 	ToBeComfirmedWorks(context.Context, *ToBeComfirmedWorksReq) (*ToBeComfirmedWorksResp, 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,8 +4,8 @@ dubbo: | |||||||
|       protocol: zookeeper |       protocol: zookeeper | ||||||
|       timeout: 3s |       timeout: 3s | ||||||
|       #      address: 121.229.45.214:9004 |       #      address: 121.229.45.214:9004 | ||||||
|       address: 172.16.100.93:2181 | #      address: 172.16.100.93:2181 | ||||||
| #      address: 127.0.0.1:2181 |       address: 127.0.0.1:2181 | ||||||
|   #      address: 114.218.158.24:2181 |   #      address: 114.218.158.24:2181 | ||||||
|   consumer: |   consumer: | ||||||
|     filter: tracing |     filter: tracing | ||||||
| @ -37,9 +37,11 @@ dubbo: | |||||||
|         interface: com.fontree.microservices.common.micro.account.fiee |         interface: com.fontree.microservices.common.micro.account.fiee | ||||||
| #        filter: echo,metrics,token,accesslog,sign,tps,generic_service,execute,pshutdown,auth,fonValidateFilter | #        filter: echo,metrics,token,accesslog,sign,tps,generic_service,execute,pshutdown,auth,fonValidateFilter | ||||||
|       PaymentCentClientImpl: |       PaymentCentClientImpl: | ||||||
|         protocol: tri |         interface: com.fontree.microservices.common.payment # must be compatible with grpc or dubbo-java | ||||||
|         retries: 0 |         filter: cshutdown,sign,auth | ||||||
|         interface: com.fontree.microservices.common.payment.cent # must be compatible with grpc or dubbo-java |         params: | ||||||
|  |           .accessKeyId: "Paymentksl" | ||||||
|  |           .secretAccessKey: "BSDY-FDF1-Fontree_payment" | ||||||
|       CastClientImpl: |       CastClientImpl: | ||||||
|         protocol: tri |         protocol: tri | ||||||
|         interface: com.fontree.microservices.fiee.multicast |         interface: com.fontree.microservices.fiee.multicast | ||||||
|  | |||||||
| @ -2,7 +2,6 @@ package bundle | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
| 	"dubbo.apache.org/dubbo-go/v3/common/logger" |  | ||||||
| 	"encoding/json" | 	"encoding/json" | ||||||
| 	"errors" | 	"errors" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| @ -142,174 +141,72 @@ func CreateAntomPay(c *gin.Context) { | |||||||
| 	// 获取 用户信息
 | 	// 获取 用户信息
 | ||||||
| 	userInfo := login.GetUserInfoFromC(c) | 	userInfo := login.GetUserInfoFromC(c) | ||||||
| 
 | 
 | ||||||
| 	// outTradeNo就是orderNo,根据这个去查询子表的source,如果是2就时单独的子套餐,如果是1就是主套餐
 | 	// 检查 订单信息
 | ||||||
| 	orderLimit, err := service.BundleProvider.OrderListByOrderNo(context.Background(), &bundle.OrderInfoByOrderNoRequest{ | 	detail, detailErr := service.BundleProvider.OrderRecordsDetail(context.Background(), &bundle.OrderRecordsDetailRequest{ | ||||||
| 		OrderNo: req.OutTradeNo, | 		OrderNo: req.OutTradeNo, | ||||||
| 	}) | 	}) | ||||||
| 	if err != nil { | 
 | ||||||
| 		fmt.Println("=============== antom创建支付,查询订单source报错:", err) | 	if detailErr != nil { | ||||||
| 		logger.Errorf("=============== antom创建支付,查询订单source报错:", err) | 		service.Error(c, detailErr) | ||||||
| 		service.Error(c, err) |  | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if orderLimit != nil && orderLimit.Type == 1 { // 这儿的type实际就是source
 | 	fmt.Println("detail.OrderRecord.CustomerID :", detail.OrderRecord.CustomerID) | ||||||
| 		// 检查 订单信息 type是1说明既有主套餐又有增值服务
 |  | ||||||
| 		detail, detailErr := service.BundleProvider.OrderRecordsDetail(context.Background(), &bundle.OrderRecordsDetailRequest{ |  | ||||||
| 			OrderNo: req.OutTradeNo, |  | ||||||
| 		}) |  | ||||||
| 		if detailErr != nil { |  | ||||||
| 			fmt.Println("=============== antom创建支付,查询主订单信息报错:", detailErr) |  | ||||||
| 			logger.Errorf("=============== antom创建支付,查询主订单信息报错:", detailErr) |  | ||||||
| 			service.Error(c, detailErr) |  | ||||||
| 			return |  | ||||||
| 		} |  | ||||||
| 
 | 
 | ||||||
| 		fmt.Println("detail.OrderRecord.Status :", detail.OrderRecord.Status) | 	// 判断 是否是 本人操作
 | ||||||
| 		fmt.Println("detail.OrderRecord.CheckoutSessionId :", detail.OrderRecord.CheckoutSessionId) | 	if strconv.FormatUint(userInfo.ID, 10) != detail.OrderRecord.CustomerID { | ||||||
| 		fmt.Println("detail.OrderRecord.PayTime :", detail.OrderRecord.PayTime) | 		service.Error(c, errors.New(common.NotMatchOrderInfo)) | ||||||
| 		// 主套餐
 | 		return | ||||||
| 		// 如果 当前订单 是 已签未支付  且 存在 checkoutSessionId 需要 查询 支付结果
 |  | ||||||
| 		if detail.OrderRecord.Status == bundleModel.OrderSigned && detail.OrderRecord.CheckoutSessionId != "" && detail.OrderRecord.PayTime == "" { |  | ||||||
| 			// 查询支付结果
 |  | ||||||
| 			stripeInfosRes, stripeInfosErr := service.PaymentProvider.QueryAntomPayByCheckoutSessionId(context.Background(), &payment.AntomPayQueryRequest{ |  | ||||||
| 				CheckoutSessionIds: []string{detail.OrderRecord.CheckoutSessionId}, |  | ||||||
| 			}) |  | ||||||
| 
 |  | ||||||
| 			if stripeInfosErr != nil { |  | ||||||
| 				service.Error(c, errors.New(common.ErrorQueryStripeInfo)) |  | ||||||
| 				return |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			if stripeInfosRes != nil && len(stripeInfosRes.Infos) > 0 { |  | ||||||
| 				for _, info := range stripeInfosRes.Infos { |  | ||||||
| 					if info.OutTradeNo == detail.OrderRecord.OrderNo && info.Status == "paid" { |  | ||||||
| 						// 更新主套餐和子套餐 TODO
 |  | ||||||
| 						// 更新子套餐,TODO
 |  | ||||||
| 						_, updateStatusErr := service.BundleProvider.UpdateOrderRecordByOrderNo(context.Background(), &bundle.OrderRecord{ |  | ||||||
| 							OrderNo: req.OutTradeNo, |  | ||||||
| 							PayTime: common.GetBeijingTime(), |  | ||||||
| 							Status:  bundleModel.OrderPaid, |  | ||||||
| 						}) |  | ||||||
| 						fmt.Println("detail.OrderRecord.Uuid :", detail.OrderRecord.Uuid) |  | ||||||
| 						if updateStatusErr != nil { |  | ||||||
| 							fmt.Println("=============== antom创建支付,更新主套餐和子套餐支付状态报错:", updateStatusErr) |  | ||||||
| 							logger.Errorf("=============== antom创建支付,更新主套餐和子套餐支付状态报错:", updateStatusErr) |  | ||||||
| 							service.Error(c, updateStatusErr) |  | ||||||
| 							return |  | ||||||
| 						} |  | ||||||
| 						service.Success(c, &service.Response{ |  | ||||||
| 							Msg:  common.HadPay, |  | ||||||
| 							Code: 0, |  | ||||||
| 						}) |  | ||||||
| 						return |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		fmt.Println("detail.OrderRecord.CustomerID :", detail.OrderRecord.CustomerID) |  | ||||||
| 
 |  | ||||||
| 		// 判断 是否是 本人操作
 |  | ||||||
| 		if strconv.FormatUint(userInfo.ID, 10) != detail.OrderRecord.CustomerID { |  | ||||||
| 			service.Error(c, errors.New(common.NotMatchOrderInfo)) |  | ||||||
| 			return |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		fmt.Println("detail.OrderRecord.TotalAmount :", detail.OrderRecord.TotalAmount) |  | ||||||
| 		fmt.Println("req.ProductAllPrice :", req.ProductAllPrice) |  | ||||||
| 		fmt.Println("detail.OrderRecord.TotalAmount*100 :", detail.OrderRecord.TotalAmount*100) |  | ||||||
| 
 |  | ||||||
| 		//金额校验
 |  | ||||||
| 		orderAmountInCents := int64(math.Round(float64(detail.OrderRecord.TotalAmount * 100))) |  | ||||||
| 		reqAmountInCents := int64(math.Round(float64(req.ProductAllPrice))) |  | ||||||
| 		if orderAmountInCents != reqAmountInCents { |  | ||||||
| 			fmt.Println("111111111111111111111111111111111111") |  | ||||||
| 			service.Error(c, errors.New(common.InvalidOrderAmount)) |  | ||||||
| 			return |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if orderLimit != nil && orderLimit.Type == 2 { | 	fmt.Println("detail.OrderRecord.TotalAmount :", detail.OrderRecord.TotalAmount) | ||||||
| 		valueAddList, listErr := service.BundleProvider.OrderRecordsListV2(context.Background(), &bundle.OrderRecordsRequestV2{ | 	fmt.Println("req.ProductAllPrice :", req.ProductAllPrice) | ||||||
| 			OrderNo:  req.OutTradeNo, | 	fmt.Println("detail.OrderRecord.TotalAmount*100 :", detail.OrderRecord.TotalAmount*100) | ||||||
| 			Page:     1, | 
 | ||||||
| 			PageSize: 10, | 	//金额校验
 | ||||||
|  | 	orderAmountInCents := int64(math.Round(float64(detail.OrderRecord.TotalAmount * 100))) | ||||||
|  | 	reqAmountInCents := int64(math.Round(float64(req.ProductAllPrice))) | ||||||
|  | 	if orderAmountInCents != reqAmountInCents { | ||||||
|  | 		fmt.Println("111111111111111111111111111111111111") | ||||||
|  | 		service.Error(c, errors.New(common.InvalidOrderAmount)) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fmt.Println("detail.OrderRecord.Status :", detail.OrderRecord.Status) | ||||||
|  | 	fmt.Println("detail.OrderRecord.CheckoutSessionId :", detail.OrderRecord.CheckoutSessionId) | ||||||
|  | 	fmt.Println("detail.OrderRecord.PayTime :", detail.OrderRecord.PayTime) | ||||||
|  | 
 | ||||||
|  | 	// 如果 当前订单 是 已签未支付  且 存在 checkoutSessionId 需要 查询 支付结果
 | ||||||
|  | 	if detail.OrderRecord.Status == bundleModel.OrderSigned && detail.OrderRecord.CheckoutSessionId != "" && detail.OrderRecord.PayTime == "" { | ||||||
|  | 		// 查询支付结果
 | ||||||
|  | 		stripeInfosRes, stripeInfosErr := service.PaymentProvider.QueryAntomPayByCheckoutSessionId(context.Background(), &payment.AntomPayQueryRequest{ | ||||||
|  | 			CheckoutSessionIds: []string{detail.OrderRecord.CheckoutSessionId}, | ||||||
| 		}) | 		}) | ||||||
| 		if listErr != nil { | 
 | ||||||
| 			fmt.Println("=============== antom创建支付,查询单独增值服务列表报错:", listErr) | 		if stripeInfosErr != nil { | ||||||
| 			logger.Errorf("=============== antom创建支付,查询单独增值服务列表报错:", listErr) | 			service.Error(c, errors.New(common.ErrorQueryStripeInfo)) | ||||||
| 			service.Error(c, listErr) |  | ||||||
| 			return | 			return | ||||||
| 		} | 		} | ||||||
| 		if valueAddList != nil && len(valueAddList.BundleInfo) > 0 && len(valueAddList.BundleInfo[0].AddBundleInfo) > 0 { |  | ||||||
| 			firstAddBundle := valueAddList.BundleInfo[0].AddBundleInfo[0] |  | ||||||
| 			// 如果 当前订单 是 已签未支付  且 存在 checkoutSessionId 需要 查询 支付结果
 |  | ||||||
| 			if firstAddBundle.AddPayStatus == bundleModel.OrderSigned && firstAddBundle.CheckoutSessionId != "" { |  | ||||||
| 				// 查询支付结果
 |  | ||||||
| 				stripeInfosRes, stripeInfosErr := service.PaymentProvider.QueryAntomPayByCheckoutSessionId(context.Background(), &payment.AntomPayQueryRequest{ |  | ||||||
| 					CheckoutSessionIds: []string{firstAddBundle.CheckoutSessionId}, |  | ||||||
| 				}) |  | ||||||
| 
 | 
 | ||||||
| 				if stripeInfosErr != nil { | 		if stripeInfosRes != nil && len(stripeInfosRes.Infos) > 0 { | ||||||
| 					service.Error(c, errors.New(common.ErrorQueryStripeInfo)) | 			for _, info := range stripeInfosRes.Infos { | ||||||
|  | 				if info.OutTradeNo == detail.OrderRecord.OrderNo && info.Status == "paid" { | ||||||
|  | 					_, updateOrderRecordErr := service.BundleProvider.UpdateOrderRecord(context.Background(), &bundle.OrderRecord{ | ||||||
|  | 						Uuid:    detail.OrderRecord.Uuid, | ||||||
|  | 						Status:  bundleModel.OrderPaid, | ||||||
|  | 						PayTime: common.GetBeijingTime(), | ||||||
|  | 					}) | ||||||
|  | 					fmt.Println("detail.OrderRecord.Uuid :", detail.OrderRecord.Uuid) | ||||||
|  | 					if updateOrderRecordErr != nil { | ||||||
|  | 						service.Error(c, detailErr) | ||||||
|  | 						return | ||||||
|  | 					} | ||||||
|  | 					service.Success(c, &service.Response{ | ||||||
|  | 						Msg:  common.HadPay, | ||||||
|  | 						Code: 0, | ||||||
|  | 					}) | ||||||
| 					return | 					return | ||||||
| 				} | 				} | ||||||
| 
 |  | ||||||
| 				if stripeInfosRes != nil && len(stripeInfosRes.Infos) > 0 { |  | ||||||
| 					for _, info := range stripeInfosRes.Infos { |  | ||||||
| 						if info.OutTradeNo == firstAddBundle.OrderAddNo && info.Status == "paid" { |  | ||||||
| 							// 更新子套餐,TODO
 |  | ||||||
| 							_, updateStatusErr := service.BundleProvider.UpdateOrderRecordByOrderNo(context.Background(), &bundle.OrderRecord{ |  | ||||||
| 								OrderNo: req.OutTradeNo, |  | ||||||
| 								PayTime: common.GetBeijingTime(), |  | ||||||
| 								Status:  bundleModel.OrderPaid, |  | ||||||
| 							}) |  | ||||||
| 							fmt.Println("req.OutTradeNo :", req.OutTradeNo) |  | ||||||
| 							if updateStatusErr != nil { |  | ||||||
| 								fmt.Println("=============== antom创建支付,更新子套餐支付状态报错:", updateStatusErr) |  | ||||||
| 								logger.Errorf("=============== antom创建支付,更新子套餐支付状态报错:", updateStatusErr) |  | ||||||
| 								service.Error(c, updateStatusErr) |  | ||||||
| 								return |  | ||||||
| 							} |  | ||||||
| 							service.Success(c, &service.Response{ |  | ||||||
| 								Msg:  common.HadPay, |  | ||||||
| 								Code: 0, |  | ||||||
| 							}) |  | ||||||
| 							return |  | ||||||
| 						} |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			fmt.Println("firstAddBundle.CustomerID :", firstAddBundle.CustomerID) |  | ||||||
| 
 |  | ||||||
| 			// 判断 是否是 本人操作
 |  | ||||||
| 			if strconv.FormatUint(userInfo.ID, 10) != firstAddBundle.CustomerID { |  | ||||||
| 				service.Error(c, errors.New(common.NotMatchOrderInfo)) |  | ||||||
| 				return |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			orderAmountInCents := int64(0.0) |  | ||||||
| 			for _, info := range valueAddList.BundleInfo[0].AddBundleInfo { |  | ||||||
| 				temp := int64(math.Round(float64(info.Amount * 100))) |  | ||||||
| 				orderAmountInCents += temp |  | ||||||
| 			} |  | ||||||
| 			if orderAmountInCents == 0 { |  | ||||||
| 				fmt.Println("子套餐金额加起来是0,orderAmountInCents:", orderAmountInCents) |  | ||||||
| 				service.Error(c, errors.New(common.InvalidOrderAmount)) |  | ||||||
| 				return |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			fmt.Println("orderAmountInCents :", orderAmountInCents) |  | ||||||
| 			fmt.Println("req.ProductAllPrice :", req.ProductAllPrice) |  | ||||||
| 
 |  | ||||||
| 			//金额校验
 |  | ||||||
| 			reqAmountInCents := int64(math.Round(float64(req.ProductAllPrice))) |  | ||||||
| 			if orderAmountInCents != reqAmountInCents { |  | ||||||
| 				fmt.Println("111111111111111111111111111111111111") |  | ||||||
| 				service.Error(c, errors.New(common.InvalidOrderAmount)) |  | ||||||
| 				return |  | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @ -336,9 +233,9 @@ func CreateAntomPay(c *gin.Context) { | |||||||
| 	fmt.Println("result.CheckoutSessionId :", result.CheckoutSessionId) | 	fmt.Println("result.CheckoutSessionId :", result.CheckoutSessionId) | ||||||
| 	fmt.Println("result.Url :", result.Url) | 	fmt.Println("result.Url :", result.Url) | ||||||
| 
 | 
 | ||||||
| 	//更新订单url和checkSessionId
 | 	//更新订单状态
 | ||||||
| 	_, updateStatusErr := service.BundleProvider.UpdateOrderRecordByOrderNo(context.Background(), &bundle.OrderRecord{ | 	_, updateOrderRecordErr := service.BundleProvider.UpdateOrderRecord(context.Background(), &bundle.OrderRecord{ | ||||||
| 		OrderNo:            req.OutTradeNo, | 		Uuid:               detail.OrderRecord.Uuid, | ||||||
| 		CheckoutSessionId:  result.CheckoutSessionId, | 		CheckoutSessionId:  result.CheckoutSessionId, | ||||||
| 		CheckoutSessionUrl: result.Url, | 		CheckoutSessionUrl: result.Url, | ||||||
| 	}) | 	}) | ||||||
| @ -346,15 +243,13 @@ func CreateAntomPay(c *gin.Context) { | |||||||
| 	resp := &order.CreateStripeCheckoutSessionResponse{} | 	resp := &order.CreateStripeCheckoutSessionResponse{} | ||||||
| 	resp.CheckoutSessionUrl = result.Url | 	resp.CheckoutSessionUrl = result.Url | ||||||
| 	resp.CheckoutSessionId = result.CheckoutSessionId | 	resp.CheckoutSessionId = result.CheckoutSessionId | ||||||
| 	fmt.Println("req.OutTradeNo :", req.OutTradeNo) |  | ||||||
| 	if updateStatusErr != nil { |  | ||||||
| 		fmt.Println("=============== antom创建支付,更新订单的请求id报错:", updateStatusErr) |  | ||||||
| 		logger.Errorf("=============== antom创建支付,更新订单的请求id报错:", updateStatusErr) |  | ||||||
| 		service.Error(c, updateStatusErr) |  | ||||||
| 		return |  | ||||||
| 	} |  | ||||||
| 	fmt.Println("resp:", resp) | 	fmt.Println("resp:", resp) | ||||||
| 
 | 
 | ||||||
|  | 	if updateOrderRecordErr != nil { | ||||||
|  | 		fmt.Println("有更新报错:", updateOrderRecordErr) | ||||||
|  | 		service.Error(c, updateOrderRecordErr) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
| 	////创建对账单 todo 待修改
 | 	////创建对账单 todo 待修改
 | ||||||
| 	//_, err = service.BundleProvider.CreateReconciliation(context.Background(), &bundle.ReconciliationInfo{
 | 	//_, err = service.BundleProvider.CreateReconciliation(context.Background(), &bundle.ReconciliationInfo{
 | ||||||
| 	//	BundleOrderOn:    detail.OrderRecord.OrderNo,
 | 	//	BundleOrderOn:    detail.OrderRecord.OrderNo,
 | ||||||
|  | |||||||
| @ -1,9 +1,6 @@ | |||||||
| package service | package service | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"dubbo.apache.org/dubbo-go/v3/common/constant" |  | ||||||
| 	"dubbo.apache.org/dubbo-go/v3/config" |  | ||||||
| 	_ "dubbo.apache.org/dubbo-go/v3/imports" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"fonchain-fiee/api/account" | 	"fonchain-fiee/api/account" | ||||||
| 	"fonchain-fiee/api/accountFiee" | 	"fonchain-fiee/api/accountFiee" | ||||||
| @ -17,6 +14,10 @@ import ( | |||||||
| 	"fonchain-fiee/api/secFilings" | 	"fonchain-fiee/api/secFilings" | ||||||
| 	pkConfig "fonchain-fiee/pkg/config" | 	pkConfig "fonchain-fiee/pkg/config" | ||||||
| 	"os" | 	"os" | ||||||
|  | 
 | ||||||
|  | 	"dubbo.apache.org/dubbo-go/v3/common/constant" | ||||||
|  | 	"dubbo.apache.org/dubbo-go/v3/config" | ||||||
|  | 	_ "dubbo.apache.org/dubbo-go/v3/imports" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| var AccountProvider = new(account.AccountClientImpl) | var AccountProvider = new(account.AccountClientImpl) | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user