@ -0,0 +1,819 @@ | |||||
package userrpc | |||||
import ( | |||||
"encoding/json" | |||||
"errors" | |||||
"log" | |||||
) | |||||
type GetAddReq struct { | |||||
Req | |||||
UserId string | |||||
Value string | |||||
Memo string | |||||
Source string | |||||
SourceId string | |||||
} | |||||
type GetUpdateReq struct { | |||||
Req | |||||
UserId string | |||||
Value string | |||||
UsedValue string | |||||
} | |||||
type GetLogReq struct { | |||||
Req | |||||
UserId string | |||||
Value string | |||||
Before string | |||||
After string | |||||
Source string | |||||
SourceId string | |||||
OrderSn string | |||||
Target string | |||||
TargetId string | |||||
ProductThumb string | |||||
Memo string | |||||
} | |||||
type GetUpgradeLogReq struct { | |||||
Req | |||||
UserId string | |||||
Upgrade string | |||||
Before string | |||||
After string | |||||
Source string | |||||
Memo string | |||||
} | |||||
type GetCouponReq struct { | |||||
Req | |||||
UserId string | |||||
CouponId string | |||||
ExpireTime string | |||||
OrderSn string | |||||
Remark string | |||||
IsUse string | |||||
Usertime string | |||||
} | |||||
/** | |||||
* 获取用户积分 | |||||
*/ | |||||
func GetUserScore(dbname, userId string, url ...string) (string, error) { | |||||
if dbname == "" || userId == "" { | |||||
return "", errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
defer conn.Close() | |||||
data := GetUserReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
res := &Response{} | |||||
err = conn.GetUserScore(req, res) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
if res_data_de == "" { | |||||
return "", nil | |||||
} | |||||
var score string | |||||
err = json.Unmarshal([]byte(res_data_de), &score) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
return score, nil | |||||
} | |||||
/** | |||||
* 获取用户红包 | |||||
*/ | |||||
func GetUserRedEnvelope(dbname, userId string, url ...string) (string, error) { | |||||
if dbname == "" || userId == "" { | |||||
return "", errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
defer conn.Close() | |||||
data := GetUserReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
res := &Response{} | |||||
err = conn.GetUserRedEnvelope(req, res) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
if res_data_de == "" { | |||||
return "", nil | |||||
} | |||||
var redEnvelope string | |||||
err = json.Unmarshal([]byte(res_data_de), &redEnvelope) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
return redEnvelope, nil | |||||
} | |||||
/** | |||||
* 添加积分 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func AddUserScore(dbname, userId, score, memo string, url ...string) (int64, error) { | |||||
if dbname == "" || userId == "" || score == "" { | |||||
return 0, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetAddReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
data.Value = score | |||||
data.Memo = memo | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("AddUserScore crypter error:", err) | |||||
return 0, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.AddUserScore(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc AddUserScore error:", err) | |||||
return 0, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
if res_data_de == "" { | |||||
return 0, nil | |||||
} | |||||
var insertId int64 | |||||
err = json.Unmarshal([]byte(res_data_de), &insertId) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
return insertId, nil | |||||
} | |||||
/** | |||||
* 更新积分记录 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func UpdateUserScore(dbname, userId, score, used_score string, url ...string) (bool, error) { | |||||
if dbname == "" || userId == "" || score == "" { | |||||
return false, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetUpdateReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
data.Value = score | |||||
data.UsedValue = used_score | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("UpdateUserScore crypter error:", err) | |||||
return false, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.UpdateUserScore(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc UpdateUserScore error:", err) | |||||
return false, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
if res_data_de == "" { | |||||
return false, nil | |||||
} | |||||
var updateres bool | |||||
err = json.Unmarshal([]byte(res_data_de), &updateres) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
return updateres, nil | |||||
} | |||||
/** | |||||
* 增加积分日志 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func AddUserScoreLog(dbname, UserId, Score, Before, After, Source, SourceId, OrderSn, Target, TargetId, ProductThumb, Memo string, url ...string) (int64, error) { | |||||
if dbname == "" || UserId == "" || Score == "" || After == "" { | |||||
return 0, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetLogReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = UserId | |||||
data.Value = Score | |||||
data.Before = Before | |||||
data.After = After | |||||
data.Source = Source | |||||
data.SourceId = SourceId | |||||
data.OrderSn = OrderSn | |||||
data.Target = Target | |||||
data.TargetId = TargetId | |||||
data.ProductThumb = ProductThumb | |||||
data.Memo = Memo | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("AddUserScoreLog crypter error:", err) | |||||
return 0, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.AddUserScoreLog(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc AddUserScoreLog error:", err) | |||||
return 0, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
if res_data_de == "" { | |||||
return 0, nil | |||||
} | |||||
var insertId int64 | |||||
err = json.Unmarshal([]byte(res_data_de), &insertId) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
return insertId, nil | |||||
} | |||||
/** | |||||
* 添加成长值 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func AddUserUpgrade(dbname, userId, upgrade, memo string, url ...string) (int64, error) { | |||||
if dbname == "" || userId == "" || upgrade == "" { | |||||
return 0, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetAddReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
data.Value = upgrade | |||||
data.Memo = memo | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("AddUserUpgrade crypter error:", err) | |||||
return 0, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.AddUserUpgrade(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc AddUserUpgrade error:", err) | |||||
return 0, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
if res_data_de == "" { | |||||
return 0, nil | |||||
} | |||||
var insertId int64 | |||||
err = json.Unmarshal([]byte(res_data_de), &insertId) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
return insertId, nil | |||||
} | |||||
/** | |||||
* 更新成长值记录 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func UpdateUserUpgrade(dbname, userId, upgrade string, url ...string) (bool, error) { | |||||
if dbname == "" || userId == "" || upgrade == "" { | |||||
return false, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetAddReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
data.Value = upgrade | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("UpdateUserUpgrade crypter error:", err) | |||||
return false, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.UpdateUserUpgrade(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc UpdateUserUpgrade error:", err) | |||||
return false, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
if res_data_de == "" { | |||||
return false, nil | |||||
} | |||||
var updateres bool | |||||
err = json.Unmarshal([]byte(res_data_de), &updateres) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
return updateres, nil | |||||
} | |||||
/** | |||||
* 增加成长值日志 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func AddUserUpgradeLog(dbname, UserId, Upgrade, Before, After, Source, Memo string, url ...string) (int64, error) { | |||||
if dbname == "" || UserId == "" || Upgrade == "" || After == "" { | |||||
return 0, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetUpgradeLogReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = UserId | |||||
data.Upgrade = Upgrade | |||||
data.Before = Before | |||||
data.After = After | |||||
data.Source = Source | |||||
data.Memo = Memo | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("AddUserUpgradeLog crypter error:", err) | |||||
return 0, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.AddUserUpgradeLog(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc AddUserUpgradeLog error:", err) | |||||
return 0, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
if res_data_de == "" { | |||||
return 0, nil | |||||
} | |||||
var insertId int64 | |||||
err = json.Unmarshal([]byte(res_data_de), &insertId) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
return insertId, nil | |||||
} | |||||
/** | |||||
* 添加红包 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func AddUserRedEnvelope(dbname, userId, money, memo string, url ...string) (int64, error) { | |||||
if dbname == "" || userId == "" || money == "" { | |||||
return 0, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetAddReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
data.Value = money | |||||
data.Memo = memo | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("AddUserRedEnvelope crypter error:", err) | |||||
return 0, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.AddUserRedEnvelope(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc AddUserRedEnvelope error:", err) | |||||
return 0, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
if res_data_de == "" { | |||||
return 0, nil | |||||
} | |||||
var insertId int64 | |||||
err = json.Unmarshal([]byte(res_data_de), &insertId) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
return insertId, nil | |||||
} | |||||
/** | |||||
* 更新红包记录 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func UpdateUserRedEnvelope(dbname, userId, money, used_money string, url ...string) (bool, error) { | |||||
if dbname == "" || userId == "" || money == "" { | |||||
return false, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetUpdateReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
data.Value = money | |||||
data.UsedValue = used_money | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("UpdateUserRedEnvelope crypter error:", err) | |||||
return false, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.UpdateUserRedEnvelope(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc UpdateUserRedEnvelope error:", err) | |||||
return false, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
if res_data_de == "" { | |||||
return false, nil | |||||
} | |||||
var updateres bool | |||||
err = json.Unmarshal([]byte(res_data_de), &updateres) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
return updateres, nil | |||||
} | |||||
/** | |||||
* 增加红包日志 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func AddUserRedEnvelopeLog(dbname, UserId, Money, Before, After, Source, SourceId, OrderSn, Target, TargetId, Memo string, url ...string) (int64, error) { | |||||
if dbname == "" || UserId == "" || Money == "" || After == "" { | |||||
return 0, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetLogReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = UserId | |||||
data.Value = Money | |||||
data.Before = Before | |||||
data.After = After | |||||
data.Source = Source | |||||
data.SourceId = SourceId | |||||
data.OrderSn = OrderSn | |||||
data.Target = Target | |||||
data.TargetId = TargetId | |||||
data.Memo = Memo | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("AddUserRedEnvelopeLog crypter error:", err) | |||||
return 0, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.AddUserRedEnvelopeLog(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc AddUserRedEnvelopeLog error:", err) | |||||
return 0, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
if res_data_de == "" { | |||||
return 0, nil | |||||
} | |||||
var insertId int64 | |||||
err = json.Unmarshal([]byte(res_data_de), &insertId) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
return insertId, nil | |||||
} | |||||
/** | |||||
* 添加优惠券 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func AddUserCoupon(dbname, userId, couponId, expireTime, orderSn, remark string, url ...string) (int64, error) { | |||||
if dbname == "" || userId == "" || couponId == "" { | |||||
return 0, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetCouponReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
data.CouponId = couponId | |||||
data.ExpireTime = expireTime | |||||
data.OrderSn = orderSn | |||||
data.Remark = remark | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("AddUserCoupon crypter error:", err) | |||||
return 0, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.AddUserCoupon(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc AddUserCoupon error:", err) | |||||
return 0, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
if res_data_de == "" { | |||||
return 0, nil | |||||
} | |||||
var insertId int64 | |||||
err = json.Unmarshal([]byte(res_data_de), &insertId) | |||||
if err != nil { | |||||
return 0, err | |||||
} | |||||
return insertId, nil | |||||
} | |||||
/** | |||||
* 更新优惠券记录 | |||||
* @2021/09/30 | |||||
* @bin | |||||
*/ | |||||
func UpdateUserCoupon(dbname, userId, couponId, remark, orderSn, isUse, usetime string, url ...string) (bool, error) { | |||||
if dbname == "" || userId == "" || couponId == "" { | |||||
return false, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetCouponReq{} | |||||
data.Dbname = dbname | |||||
data.UserId = userId | |||||
data.CouponId = couponId | |||||
data.Remark = remark | |||||
data.OrderSn = orderSn | |||||
data.IsUse = isUse | |||||
data.Usertime = usetime | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
log.Println("UpdateUserCoupon crypter error:", err) | |||||
return false, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.UpdateUserCoupon(req, res) | |||||
if err != nil { | |||||
log.Println("userrpc UpdateUserCoupon error:", err) | |||||
return false, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
if res_data_de == "" { | |||||
return false, nil | |||||
} | |||||
var updateres bool | |||||
err = json.Unmarshal([]byte(res_data_de), &updateres) | |||||
if err != nil { | |||||
return false, err | |||||
} | |||||
return updateres, nil | |||||
} |
@ -0,0 +1,168 @@ | |||||
package userrpc | |||||
import ( | |||||
"strconv" | |||||
"testing" | |||||
"time" | |||||
) | |||||
func Test_GetUserScore(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
id := "2" | |||||
ret, err := GetUserScore(dbname, id) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_GetUserRedEnvelope(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
id := "2" | |||||
ret, err := GetUserRedEnvelope(dbname, id) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_AddUserScore(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "2" | |||||
score := "20" | |||||
ret, err := AddUserScore(dbname, userid, score,"") | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_UpdateUserScore(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "2" | |||||
score := "400" | |||||
used_score := "300" | |||||
ret, err := UpdateUserScore(dbname, userid, score, used_score) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_AddUserScoreLog(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "2" | |||||
score := "100" | |||||
before := "500" | |||||
after := "400" | |||||
Source := "task" | |||||
SourceId := "" | |||||
OrderSn := "" | |||||
Target := "" | |||||
TargetId := "" | |||||
ProductThumb := "" | |||||
Memo := "" | |||||
ret, err := AddUserScoreLog(dbname, userid, score, before, after, Source, SourceId, OrderSn, Target, TargetId, ProductThumb, Memo) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_AddUserUpgrade(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "5" | |||||
upgrade := "100" | |||||
ret, err := AddUserUpgrade(dbname, userid, upgrade,"") | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_UpdateUserUpgrade(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "5" | |||||
upgrade := "100" | |||||
ret, err := UpdateUserUpgrade(dbname, userid, upgrade) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_AddUserUpgradeLog(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "2" | |||||
upgrade := "20" | |||||
before := "11" | |||||
after := "31" | |||||
Source := "task" | |||||
Memo := "" | |||||
ret, err := AddUserUpgradeLog(dbname, userid, upgrade, before, after, Source, Memo) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_AddUserRedEnvelope(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "5" | |||||
money := "20" | |||||
ret, err := AddUserRedEnvelope(dbname, userid, money,"") | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_UpdateUserRedEnvelope(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "2" | |||||
money := "40" | |||||
used_money := "1" | |||||
ret, err := UpdateUserRedEnvelope(dbname, userid, money, used_money) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_AddUserRedEnvelopeLog(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "2" | |||||
money := "-1" | |||||
before := "41" | |||||
after := "40" | |||||
Source := "task" | |||||
SourceId := "" | |||||
OrderSn := "216304042479173922" | |||||
Target := "" | |||||
TargetId := "" | |||||
ProductThumb := "" | |||||
Memo := "" | |||||
ret, err := AddUserRedEnvelopeLog(dbname, userid, money, before, after, Source, SourceId, OrderSn, Target, TargetId, ProductThumb, Memo) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_AddUserCoupon(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "2" | |||||
couponId := "6" | |||||
expired_time := "1634684122" | |||||
order_sn := "" | |||||
remark := "商品券" | |||||
ret, err := AddUserCoupon(dbname, userid, couponId, expired_time,order_sn,remark) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} | |||||
func Test_UpdateUserCoupon(t *testing.T) { | |||||
dbname := "shop_v2_org" | |||||
userid := "2" | |||||
couponId := "6" | |||||
remark := "下单使用优惠券" | |||||
orderSn := "12345678910" | |||||
isUse := "1" | |||||
usetime := strconv.Itoa(int(time.Now().Unix())) | |||||
ret, err := UpdateUserCoupon(dbname, userid, couponId, remark, orderSn, isUse,usetime) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} |
@ -0,0 +1,54 @@ | |||||
package userrpc | |||||
import ( | |||||
"encoding/json" | |||||
"errors" | |||||
) | |||||
func GetAddressInfo(site_id, dbname, address_id string, url ...string) (map[string]string, error) { | |||||
if dbname == "" || address_id == "" { | |||||
return nil, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetAddressReq{} | |||||
data.SiteId = site_id | |||||
data.Dbname = dbname | |||||
data.AddressId = address_id | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.GetAddressInfo(req, res) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
if res_data_de == "" { | |||||
return nil, nil | |||||
} | |||||
var res_arr map[string]string | |||||
err = json.Unmarshal([]byte(res_data_de), &res_arr) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
return res_arr, nil | |||||
} |
@ -0,0 +1,16 @@ | |||||
package userrpc | |||||
import ( | |||||
"testing" | |||||
) | |||||
func Test_GetAddressInfo(t *testing.T) { | |||||
site_id := "" | |||||
dbname := "shop_v2" | |||||
id := "2" | |||||
ret, err := GetAddressInfo(site_id, dbname, id) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} |
@ -0,0 +1,150 @@ | |||||
package userrpc | |||||
import ( | |||||
"encoding/json" | |||||
"errors" | |||||
"strconv" | |||||
"time" | |||||
"git.tetele.net/tgo/crypter" | |||||
"github.com/golang/protobuf/proto" | |||||
) | |||||
/** | |||||
* 查找商户信息 | |||||
* 2021/04/06 | |||||
* gz | |||||
*/ | |||||
func GetBusiness(site_id, dbname, business_id string, url ...string) (*Business, error) { | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetBusinessReq{} | |||||
data.SiteId = site_id | |||||
data.Dbname = dbname | |||||
data.BusinessId = business_id | |||||
data_json, err := json.Marshal(data) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
encryData := crypter.DesEn(string(data_json), DES_KEY) | |||||
now_int64 := time.Now().Unix() | |||||
now := strconv.FormatInt(now_int64, 10) | |||||
sign := Sign(encryData, now) | |||||
req := &Request{ | |||||
proto.String(encryData), | |||||
proto.String(now), | |||||
proto.String(sign), | |||||
nil} | |||||
res := &Response{} | |||||
err = conn.GetBusiness(req, res) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
return HandleGetBusinessRes(res) | |||||
} | |||||
/** | |||||
* 处理返回结果 | |||||
*/ | |||||
func HandleGetBusinessRes(res *Response) (*Business, error) { | |||||
res_data := res.GetData() | |||||
if res_data == "" { | |||||
return nil, errors.New("未收到收据") | |||||
} | |||||
time_int64, err := strconv.ParseInt(res.GetTime(), 10, 64) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
now_int64 := time.Now().Unix() | |||||
if now_int64-time_int64 > 10 || time_int64-now_int64 > 10 { | |||||
//时间误差前后10秒,返回 | |||||
return nil, errors.New("返回时间错误") | |||||
} | |||||
check_sign := CheckSign(res.GetSign(), res_data, res.GetTime()) | |||||
if !check_sign { | |||||
return nil, errors.New("返回数据签名错误") | |||||
} | |||||
//解密 | |||||
res_data_de := crypter.DesDe(res_data, DES_KEY) | |||||
var res_arr Business | |||||
err = json.Unmarshal([]byte(res_data_de), &res_arr) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
return &res_arr, nil | |||||
} | |||||
func GetBusinessInfo(site_id, dbname, id string, url ...string) (map[string]string, error) { | |||||
if dbname == "" || id == "" { | |||||
return nil, errors.New("参数错误") | |||||
} | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
defer conn.Close() | |||||
data := GetBusinessReq{} | |||||
data.SiteId = site_id | |||||
data.Dbname = dbname | |||||
data.BusinessId = id | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.GetBusinessInfo(req, res) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
if res_data_de == "" { | |||||
return nil, nil | |||||
} | |||||
var res_arr map[string]string | |||||
err = json.Unmarshal([]byte(res_data_de), &res_arr) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
return res_arr, nil | |||||
} |
@ -0,0 +1,16 @@ | |||||
package userrpc | |||||
import ( | |||||
"testing" | |||||
) | |||||
func Test_GetBusinessInfo(t *testing.T) { | |||||
site_id := "" | |||||
dbname := "shop_v2" | |||||
id := "5" | |||||
ret, err := GetBusinessInfo(site_id, dbname, id) | |||||
t.Log(ret) | |||||
t.Log(err) | |||||
} |
@ -0,0 +1,106 @@ | |||||
package userrpc | |||||
import ( | |||||
"encoding/json" | |||||
"errors" | |||||
"strconv" | |||||
"time" | |||||
"git.tetele.net/tgo/crypter" | |||||
"github.com/golang/protobuf/proto" | |||||
) | |||||
func SetResData(data interface{}, res *Response) { | |||||
res_data_json, err := json.Marshal(data) | |||||
if err == nil { | |||||
encryData := crypter.DesEn(string(res_data_json), DES_KEY) | |||||
now_str := strconv.FormatInt(time.Now().Unix(), 10) | |||||
res_sign := Sign(encryData, now_str) | |||||
res.Data = proto.String(encryData) | |||||
res.Time = proto.String(now_str) | |||||
res.Sign = proto.String(res_sign) | |||||
} | |||||
} | |||||
func SetReqData(arg interface{}) (*Request, error) { | |||||
data_json, err := json.Marshal(arg) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
now_int64 := time.Now().Unix() | |||||
encryData := crypter.DesEn(string(data_json), DES_KEY) | |||||
now := strconv.FormatInt(now_int64, 10) | |||||
sign := Sign(encryData, now) | |||||
return &Request{proto.String(encryData), proto.String(now), proto.String(sign), nil}, nil | |||||
} | |||||
func GetReqData(req *Request) (string, error) { | |||||
res_data := req.GetData() | |||||
if res_data != "" { | |||||
time_int64, err := strconv.ParseInt(req.GetTime(), 10, 64) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
now_int64 := time.Now().Unix() | |||||
if now_int64-time_int64 > 10 || time_int64-now_int64 > 10 { | |||||
//时间误差前后10秒,返回 | |||||
return "", errors.New("返回时间错误") | |||||
} | |||||
check_sign := CheckSign(req.GetSign(), res_data, req.GetTime()) | |||||
if !check_sign { | |||||
return "", errors.New("返回数据签名错误") | |||||
} | |||||
//解密 | |||||
return crypter.DesDe(res_data, DES_KEY), nil | |||||
} | |||||
return "", nil | |||||
} | |||||
func GetResData(res *Response) (string, error) { | |||||
res_data := res.GetData() | |||||
if res_data != "" { | |||||
time_int64, err := strconv.ParseInt(res.GetTime(), 10, 64) | |||||
if err != nil { | |||||
return "", err | |||||
} | |||||
now_int64 := time.Now().Unix() | |||||
if now_int64-time_int64 > 10 || time_int64-now_int64 > 10 { | |||||
//时间误差前后10秒,返回 | |||||
return "", errors.New("返回时间错误") | |||||
} | |||||
check_sign := CheckSign(res.GetSign(), res_data, res.GetTime()) | |||||
if !check_sign { | |||||
return "", errors.New("返回数据签名错误") | |||||
} | |||||
//解密 | |||||
return crypter.DesDe(res_data, DES_KEY), nil | |||||
} | |||||
return "", nil | |||||
} |
@ -0,0 +1,75 @@ | |||||
package userrpc | |||||
/** | |||||
* 绑定粉丝 | |||||
* 2021/10/23 | |||||
* gz | |||||
*/ | |||||
func Fans(site_id, dbname, user_id, business_id string, url ...string) error { | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return err | |||||
} | |||||
defer conn.Close() | |||||
data := FansReq{} | |||||
data.SiteId = site_id | |||||
data.Dbname = dbname | |||||
data.UserId = user_id | |||||
data.BusinessId = business_id | |||||
data.Lock = false | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
return err | |||||
} | |||||
res := &Response{} | |||||
err = conn.Fans(req, res) | |||||
if err != nil { | |||||
return err | |||||
} | |||||
_, err = GetResData(res) | |||||
return nil | |||||
} | |||||
/** | |||||
* 绑定粉丝 | |||||
* 2021/10/23 | |||||
* gz | |||||
*/ | |||||
func LockFans(site_id, dbname, user_id, business_id string, url ...string) error { | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return err | |||||
} | |||||
defer conn.Close() | |||||
data := FansReq{} | |||||
data.SiteId = site_id | |||||
data.Dbname = dbname | |||||
data.UserId = user_id | |||||
data.BusinessId = business_id | |||||
data.Lock = true | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
return err | |||||
} | |||||
res := &Response{} | |||||
err = conn.Fans(req, res) | |||||
if err != nil { | |||||
return err | |||||
} | |||||
_, err = GetResData(res) | |||||
return nil | |||||
} |
@ -0,0 +1,16 @@ | |||||
package userrpc | |||||
import ( | |||||
"testing" | |||||
) | |||||
func Test_Fans(t *testing.T) { | |||||
dbname := "shop_v2" | |||||
user_id := "6" | |||||
business_id := "5" | |||||
err := LockFans("", dbname, user_id, business_id) | |||||
t.Log(err) | |||||
} |
@ -0,0 +1,56 @@ | |||||
package userrpc | |||||
import ( | |||||
"encoding/json" | |||||
) | |||||
/** | |||||
* 查找第三方平台openid V2版 | |||||
* 2021/09/07 | |||||
* gz | |||||
*/ | |||||
func GetUserThird(site_id, dbname, platform, user_id, field string, url ...string) (map[string]string, error) { | |||||
conn, err := rpc_server_conn(url...) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
defer conn.Close() | |||||
data := map[string]string{ | |||||
"site_id": site_id, | |||||
"dbname": dbname, | |||||
"user_id": user_id, | |||||
"platform": platform, | |||||
"field": field, | |||||
} | |||||
req, err := SetReqData(data) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
res := &Response{} | |||||
err = conn.GetUserThird(req, res) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
res_data_de, err := GetResData(res) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
if res_data_de == "" { | |||||
return nil, nil | |||||
} | |||||
var res_arr map[string]string | |||||
err = json.Unmarshal([]byte(res_data_de), &res_arr) | |||||
if err != nil { | |||||
return nil, err | |||||
} | |||||
return res_arr, nil | |||||
} |
@ -0,0 +1,13 @@ | |||||
package userrpc | |||||
import ( | |||||
"testing" | |||||
) | |||||
func Test_GetUserThird(t *testing.T) { | |||||
org, err := GetUserThird("1", "shop_v2", "miniapp", "2", "id,openid") | |||||
t.Log(org) | |||||
t.Log(err) | |||||
} |