package authorization import ( "encoding/json" "errors" "net/url" wxerr "gitee.com/yansen_zh/wxcomponent/errors" "gitee.com/yansen_zh/wxcomponent/utils/request" ) // AuthorizerInfoParam 获取授权帐号信息参数 type AuthorizerInfoParam struct { ComponentAppId string `json:"component_appid"` AuthorizerAppId string `json:"authorizer_appid"` } // AuthorizerInfoResult 获取授权帐号信息结果 type AuthorizerInfoResult struct { wxerr.Error AuthorizationInfo AuthorizationInfo `json:"authorization_info"` AuthorizerInfo AuthorizerInfo `json:"authorizer_info"` } const ( apiGetAuthorizerInfo = "https://apies.weixin.qq.com/cgi-bin/component/api_get_authorizer_info" ) // GetAuthorizerInfo 获取授权帐号信息 func GetAuthorizerInfo(componentAccessToken string, data AuthorizerInfoParam) (*AuthorizerInfoResult, error) { if componentAccessToken == "" { return nil, errors.New("获取授权帐号信息 第三方平台的 component_access_token 不能为空") } if data.ComponentAppId == "" { return nil, errors.New("获取授权帐号信息 第三方平台的 appid 不能为空") } if data.AuthorizerAppId == "" { return nil, errors.New("获取授权帐号信息 授权方 appid 不能为空") } queryParam := url.Values{} queryParam.Set("component_access_token", componentAccessToken) apiUrl, _ := request.ParseURL(apiGetAuthorizerInfo, &queryParam) resp, e2 := request.PostJSON(apiUrl.String(), data) if e2 != nil { return nil, e2 } result := AuthorizerInfoResult{} if err := json.Unmarshal(resp, &result); err != nil { return nil, err } if result.Code != 0 { return &result, result.Error } return &result, nil }