mirror of https://github.com/dtm-labs/dtm.git
csharpjavadistributed-transactionsdtmgogolangmicroservicenodejsphpdatabasesagaseatatcctransactiontransactionsxapythondistributed
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
1.8 KiB
63 lines
1.8 KiB
package dtmcli
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
|
|
"github.com/go-resty/resty/v2"
|
|
"github.com/yedf/dtm/common"
|
|
)
|
|
|
|
// MustGenGid generate a new gid
|
|
func MustGenGid(server string) string {
|
|
res := common.MS{}
|
|
resp, err := common.RestyClient.R().SetResult(&res).Get(server + "/newGid")
|
|
if err != nil || res["gid"] == "" {
|
|
panic(fmt.Errorf("newGid error: %v, resp: %s", err, resp))
|
|
}
|
|
return res["gid"]
|
|
}
|
|
|
|
// IsFailure 如果err非空,或者ret是http的响应且包含FAILURE,那么返回true。此时认为业务调用失败
|
|
func IsFailure(res interface{}, err error) bool {
|
|
resp, ok := res.(*resty.Response)
|
|
return err != nil || // 包含错误
|
|
ok && (resp.IsError() || strings.Contains(resp.String(), "FAILURE")) || // resp包含failure
|
|
!ok && res != nil && strings.Contains(common.MustMarshalString(res), "FAILURE") // 结果中包含failure
|
|
}
|
|
|
|
// PanicIfFailure 如果err非空,或者ret是http的响应且包含FAILURE,那么Panic。此时认为业务调用失败
|
|
func PanicIfFailure(res interface{}, err error) {
|
|
if IsFailure(res, err) {
|
|
panic(fmt.Errorf("dtm failure ret: %v err %v", res, err))
|
|
}
|
|
}
|
|
|
|
// CheckDtmResponse check the response of dtm, if not ok ,generate error
|
|
func CheckDtmResponse(resp *resty.Response, err error) error {
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if !strings.Contains(resp.String(), "SUCCESS") || resp.IsError() {
|
|
return fmt.Errorf("dtm response failed: %s", resp.String())
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// IDGenerator used to generate a branch id
|
|
type IDGenerator struct {
|
|
parentID string
|
|
branchID int
|
|
}
|
|
|
|
// NewBranchID generate a branch id
|
|
func (g *IDGenerator) NewBranchID() string {
|
|
if g.branchID >= 99 {
|
|
panic(fmt.Errorf("branch id is larger than 99"))
|
|
}
|
|
if len(g.parentID) >= 20 {
|
|
panic(fmt.Errorf("total branch id is longer than 20"))
|
|
}
|
|
g.branchID = g.branchID + 1
|
|
return g.parentID + fmt.Sprintf("%02d", g.branchID)
|
|
}
|
|
|