- CBGetUserInfo
This commit is contained in:
@@ -6,6 +6,25 @@ const (
|
|||||||
MaxRemarkByteCount = 30
|
MaxRemarkByteCount = 30
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type CBUserInfo struct {
|
||||||
|
Subscribe int `json:"subscribe"`
|
||||||
|
OpenID string `json:"openid"`
|
||||||
|
Nickname string `json:"nickname"`
|
||||||
|
Sex int `json:"sex"`
|
||||||
|
Language string `json:"language"`
|
||||||
|
City string `json:"city"`
|
||||||
|
Province string `json:"province"`
|
||||||
|
Country string `json:"country"`
|
||||||
|
HeadImgURL string `json:"headimgurl"`
|
||||||
|
SubscribeTime int64 `json:"subscribe_time"`
|
||||||
|
UnionID string `json:"unionid"`
|
||||||
|
Remark string `json:"remark"`
|
||||||
|
TagIDList []int `json:"tagid_list"`
|
||||||
|
SubscribeScene string `json:"subscribe_scene"`
|
||||||
|
QRScene int `json:"qr_scene"`
|
||||||
|
QRSceneStr string `json:"qr_scene_str"`
|
||||||
|
}
|
||||||
|
|
||||||
func (a *API) CBSetToken(newToken string) bool {
|
func (a *API) CBSetToken(newToken string) bool {
|
||||||
curToken := a.CBGetToken()
|
curToken := a.CBGetToken()
|
||||||
if curToken != newToken {
|
if curToken != newToken {
|
||||||
@@ -62,3 +81,15 @@ func (a *API) CBUpdateRemark(userOpenID, remark string) (err error) {
|
|||||||
_, err = a.AccessAPI("cgi-bin/user/info/updateremark", nil, string(utils.MustMarshal(bodyJson)))
|
_, err = a.AccessAPI("cgi-bin/user/info/updateremark", nil, string(utils.MustMarshal(bodyJson)))
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (a *API) CBGetUserInfo(userOpenID string) (userInfo *CBUserInfo, err error) {
|
||||||
|
bodyJson := map[string]interface{}{
|
||||||
|
"openid": userOpenID,
|
||||||
|
"lang": "zh_CN",
|
||||||
|
}
|
||||||
|
result, err := a.AccessAPI("cgi-bin/user/info", bodyJson, "")
|
||||||
|
if err == nil {
|
||||||
|
err = utils.Map2StructByJson(result, &userInfo, false)
|
||||||
|
}
|
||||||
|
return userInfo, err
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,6 +1,10 @@
|
|||||||
package weixinapi
|
package weixinapi
|
||||||
|
|
||||||
import "testing"
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"git.rosy.net.cn/baseapi/utils"
|
||||||
|
)
|
||||||
|
|
||||||
func TestCBRetrieveToken(t *testing.T) {
|
func TestCBRetrieveToken(t *testing.T) {
|
||||||
result, err := api.CBRetrieveToken()
|
result, err := api.CBRetrieveToken()
|
||||||
@@ -38,3 +42,11 @@ func TestCBUpdateRemark(t *testing.T) {
|
|||||||
t.Log(err)
|
t.Log(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestCBGetUserInfo(t *testing.T) {
|
||||||
|
userInfo, err := api.CBGetUserInfo("oYN_ust9hXKEvEv0X6Mq6nlAWs_E")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
t.Log(utils.Format4Output(userInfo, false))
|
||||||
|
}
|
||||||
|
|||||||
@@ -6,6 +6,32 @@ import (
|
|||||||
"git.rosy.net.cn/baseapi/utils"
|
"git.rosy.net.cn/baseapi/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type SNSTokenInfo struct {
|
||||||
|
AccessToken string `json:"access_token"`
|
||||||
|
ExpiresIn int `json:"expires_in"`
|
||||||
|
RefreshToken string `json:"refresh_token"`
|
||||||
|
OpenID string `json:"openid"`
|
||||||
|
Scope string `json:"scope"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type SNSUserInfo struct {
|
||||||
|
OpenID string `json:"openid"`
|
||||||
|
NickName string `json:"nickname"`
|
||||||
|
Sex int `json:"sex"`
|
||||||
|
Province string `json:"province"`
|
||||||
|
City string `json:"city"`
|
||||||
|
Country string `json:"country"`
|
||||||
|
HeadImgURL string `json:"headimgurl"`
|
||||||
|
Privilege interface{} `json:"privilege"`
|
||||||
|
UnionID string `json:"unionid"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type SessionInfo struct {
|
||||||
|
OpenID string `json:"openid"`
|
||||||
|
SessionKey string `json:"session_key"`
|
||||||
|
UnionID string `json:"unionid"`
|
||||||
|
}
|
||||||
|
|
||||||
func mapData2SNSToken(result map[string]interface{}) *SNSTokenInfo {
|
func mapData2SNSToken(result map[string]interface{}) *SNSTokenInfo {
|
||||||
return &SNSTokenInfo{
|
return &SNSTokenInfo{
|
||||||
AccessToken: utils.Interface2String(result["access_token"]),
|
AccessToken: utils.Interface2String(result["access_token"]),
|
||||||
|
|||||||
@@ -40,32 +40,6 @@ type API struct {
|
|||||||
msgKey string
|
msgKey string
|
||||||
}
|
}
|
||||||
|
|
||||||
type SNSTokenInfo struct {
|
|
||||||
AccessToken string `json:"access_token"`
|
|
||||||
ExpiresIn int `json:"expires_in"`
|
|
||||||
RefreshToken string `json:"refresh_token"`
|
|
||||||
OpenID string `json:"openid"`
|
|
||||||
Scope string `json:"scope"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type SNSUserInfo struct {
|
|
||||||
OpenID string `json:"openid"`
|
|
||||||
NickName string `json:"nickname"`
|
|
||||||
Sex int `json:"sex"`
|
|
||||||
Province string `json:"province"`
|
|
||||||
City string `json:"city"`
|
|
||||||
Country string `json:"country"`
|
|
||||||
HeadImgURL string `json:"headimgurl"`
|
|
||||||
Privilege interface{} `json:"privilege"`
|
|
||||||
UnionID string `json:"unionid"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type SessionInfo struct {
|
|
||||||
OpenID string `json:"openid"`
|
|
||||||
SessionKey string `json:"session_key"`
|
|
||||||
UnionID string `json:"unionid"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func New(appID, secret string, config ...*platformapi.APIConfig) *API {
|
func New(appID, secret string, config ...*platformapi.APIConfig) *API {
|
||||||
curConfig := platformapi.DefAPIConfig
|
curConfig := platformapi.DefAPIConfig
|
||||||
if len(config) > 0 {
|
if len(config) > 0 {
|
||||||
|
|||||||
Reference in New Issue
Block a user