红包发放调试

This commit is contained in:
李子铭 2024-09-18 14:21:26 +08:00
parent e8d8ec626f
commit 77125628fa
8 changed files with 29 additions and 29 deletions

View File

@ -45,13 +45,13 @@ func alipayOrderRedPack() {
log.Fatalln(err)
}
request := &proto.OrderRequest{
Config: config(),
Config: getAlpayRedConf(),
Order: &proto.OrderRequest_Order{
OrderNo: "lsxd202406071545141534",
Account: "18512869479",
Account: "18666173766",
Quantity: 1,
Amount: 0.01,
Extra: []byte(`{"name":"樊波"}`),
Extra: []byte(`{"name":"李子铭"}`),
},
Product: &proto.OrderRequest_Product{
ProductNo: "",
@ -76,8 +76,8 @@ func alipayQueryRedPack() {
queryRequest := &proto.QueryRequest{
Config: getAlpayRedConf(),
Order: &proto.QueryRequest_Order{
OrderNo: "lsxd202306071545141532",
TradeNo: "20230607110070000006320086925897",
OrderNo: "lsxd202406071545141534",
TradeNo: "20240918020070011550480064889781",
Account: "",
Extra: []byte(``),
},

View File

@ -3,5 +3,6 @@ package main
// main 这只是一个演示
func main() {
//wechatCpn()
alipayOrderRedPack()
//alipayOrderRedPack()
alipayQueryRedPack()
}

2
go.mod
View File

@ -3,7 +3,7 @@ module plugins
go 1.22.2
require (
gitea.cdlsxd.cn/sdk/plugin v0.0.0-20240830100334-2e99a5df732b
gitea.cdlsxd.cn/sdk/plugin v0.0.0-20240911021858-7f3ba37bbbca
plugins/utils v0.0.0-00010101000000-000000000000
)

4
go.sum
View File

@ -1,5 +1,5 @@
gitea.cdlsxd.cn/sdk/plugin v0.0.0-20240830100334-2e99a5df732b h1:x8Gf1EJ6oLHEIgK/SilgMZ5EDgcEknef9zhGrFvXXMg=
gitea.cdlsxd.cn/sdk/plugin v0.0.0-20240830100334-2e99a5df732b/go.mod h1:cd+ZFTmd/ZxrrVc1OZCkrh2wAMPDaAa8ce13FAAkBg0=
gitea.cdlsxd.cn/sdk/plugin v0.0.0-20240911021858-7f3ba37bbbca h1:snL161P7OynMA8hRVMLDjwnzZA2Q4mePg/iT/dyIfzA=
gitea.cdlsxd.cn/sdk/plugin v0.0.0-20240911021858-7f3ba37bbbca/go.mod h1:cd+ZFTmd/ZxrrVc1OZCkrh2wAMPDaAa8ce13FAAkBg0=
github.com/agiledragon/gomonkey v2.0.2+incompatible h1:eXKi9/piiC3cjJD1658mEE2o3NjkJ5vDLgYjCQu0Xlw=
github.com/agiledragon/gomonkey v2.0.2+incompatible/go.mod h1:2NGfXu1a80LLr2cmWXGBDaHEjb1idR6+FVlX5T3D9hw=
github.com/bufbuild/protocompile v0.4.0 h1:LbFKd2XowZvQ/kajzguUp2DC9UEIQhIq77fZZlaQsNA=

View File

@ -48,7 +48,7 @@ func (s *AlipayRedPackService) Order(ctx context.Context, request *proto.OrderRe
}
var sp string
err = requests.URL(baseUri).Post().BodyForm(uv).ToString(&sp).Fetch(ctx)
err = requests.URL(baseUri).Post().Params(uv).ToString(&sp).Fetch(ctx)
var response *po.OrderResp
sp = helper.ToChinese(sp)

View File

@ -8,6 +8,7 @@ import (
"plugins/alipay_redpack/internal/po"
"plugins/alipay_redpack/internal/vo"
"plugins/utils/alipay"
"plugins/utils/helper"
"time"
)
@ -64,13 +65,13 @@ func orderReq(order *proto.OrderRequest_Order, product *proto.OrderRequest_Produ
Identity: order.Account,
IdentityType: "ALIPAY_USER_ID",
}
if isValidPhoneNumber(order.Account) || isEmailValid(order.Account) {
type OrderExtra struct {
Name string `json:"name"`
}
if helper.IsPhoneNumber(order.Account) || helper.IsEmail(order.Account) {
if order.Extra == nil {
return nil, fmt.Errorf("order extra is nil")
}
type OrderExtra struct {
Name string `json:"name"`
}
var orderExtra OrderExtra
err = json.Unmarshal(order.Extra, &orderExtra)
if err != nil {
@ -82,8 +83,7 @@ func orderReq(order *proto.OrderRequest_Order, product *proto.OrderRequest_Produ
payeeInfo.IdentityType = "ALIPAY_LOGON_ID"
payeeInfo.Name = orderExtra.Name
}
o := &po.OrderReq{
return &po.OrderReq{
OutBizNo: order.OrderNo,
TransAmount: order.Amount,
ProductCode: "STD_RED_PACKET",
@ -92,8 +92,7 @@ func orderReq(order *proto.OrderRequest_Order, product *proto.OrderRequest_Produ
Remark: productExtra.Wishing,
PayeeInfo: &payeeInfo,
BusinessParams: `{"sub_biz_scene":"REDPACKET"}`,
}
return o, nil
}, nil
}
func orderResp(request *proto.OrderRequest, resp *po.OrderResp) *proto.OrderResponse {

View File

@ -13,20 +13,9 @@ import (
"gitea.cdlsxd.cn/sdk/plugin/utils"
"net/url"
"plugins/alipay_redpack/internal/po"
"regexp"
"strings"
)
func isValidPhoneNumber(phoneNumber string) bool {
phoneRegex := `^1[34578]\d{9}$`
return regexp.MustCompile(phoneRegex).MatchString(phoneNumber)
}
func isEmailValid(email string) bool {
var emailRegex = regexp.MustCompile(`[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$`)
return emailRegex.MatchString(email)
}
func req(config *Config, req *po.Param) (url.Values, error) {
var strToBeSigned strings.Builder
uv := url.Values{}

View File

@ -4,6 +4,7 @@ import (
"golang.org/x/text/encoding/simplifiedchinese"
"golang.org/x/text/transform"
"os"
"regexp"
)
func FileExists(filePath string) bool {
@ -17,3 +18,13 @@ func ToChinese(s string) string {
encodedName, _, _ := transform.String(encoder, s)
return encodedName
}
func IsPhoneNumber(phoneNumber string) bool {
phoneRegex := `^1[34578]\d{9}$`
return regexp.MustCompile(phoneRegex).MatchString(phoneNumber)
}
func IsEmail(email string) bool {
var emailRegex = regexp.MustCompile(`[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$`)
return emailRegex.MatchString(email)
}