123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- package aliyun
- import (
- "encoding/json"
- "errors"
- "fmt"
- avatar20220130 "github.com/alibabacloud-go/avatar-20220130/v2/client"
- openapi "github.com/alibabacloud-go/darabonba-openapi/v2/client"
- util "github.com/alibabacloud-go/tea-utils/v2/service"
- "github.com/alibabacloud-go/tea/tea"
- "strings"
- "wechat-api/internal/utils/jwt"
- )
- func CreateClient(accessKeyId, accessKeySecret string) (_result *avatar20220130.Client, _err error) {
-
-
- config := &openapi.Config{
-
- AccessKeyId: tea.String(accessKeyId),
-
- AccessKeySecret: tea.String(accessKeySecret),
- }
-
- config.Endpoint = tea.String("avatar.cn-zhangjiakou.aliyuncs.com")
- _result = &avatar20220130.Client{}
- _result, _err = avatar20220130.NewClient(config)
- return _result, _err
- }
- func StartInstance(userId, bizId string) (*avatar20220130.StartInstanceResponseBodyData, error) {
- accessKeyId := GetAccessKeyId()
- accessKeySecret := GetAccessKeySecret()
- tenantId := GetTenantId()
- appId := GetAppId()
- client, _err := CreateClient(accessKeyId, accessKeySecret)
- if _err != nil {
- return nil, _err
- }
- startInstanceRequest := &avatar20220130.StartInstanceRequest{
- TenantId: tea.Int64(tenantId),
- App: &avatar20220130.StartInstanceRequestApp{
- AppId: tea.String(appId),
- },
- User: &avatar20220130.StartInstanceRequestUser{
- UserId: tea.String(userId),
- },
- BizId: tea.String(bizId),
- }
- _result, _err := client.StartInstance(startInstanceRequest)
- if _err != nil {
- return nil, _err
- }
- if *_result.Body.Success {
- fmt.Println(_result.Body.Data)
- return _result.Body.Data, nil
- }
- return nil, errors.New(*_result.Body.Message)
- }
- func _main(args []*string) (_err error) {
- client, _err := CreateClient("", "")
- if _err != nil {
- return _err
- }
- sendMessageRequest := &avatar20220130.SendMessageRequest{
- SessionId: tea.String("your_value"),
- TenantId: tea.Int64(1),
- Feedback: tea.Bool(false),
- }
- tryErr := func() (_e error) {
- defer func() {
- if r := tea.Recover(recover()); r != nil {
- _e = r
- }
- }()
-
- _, _err = client.SendMessageWithOptions(sendMessageRequest, &util.RuntimeOptions{})
- if _err != nil {
- return _err
- }
- return nil
- }()
- if tryErr != nil {
- var error = &tea.SDKError{}
- if _t, ok := tryErr.(*tea.SDKError); ok {
- error = _t
- } else {
- error.Message = tea.String(tryErr.Error())
- }
-
-
- fmt.Println(tea.StringValue(error.Message))
-
- var data interface{}
- d := json.NewDecoder(strings.NewReader(tea.StringValue(error.Data)))
- d.Decode(&data)
- if m, ok := data.(map[string]interface{}); ok {
- recommend, _ := m["Recommend"]
- fmt.Println(recommend)
- }
- _, _err = util.AssertAsString(error.Message)
- if _err != nil {
- return _err
- }
- }
- return _err
- }
- func GetBizID(userId uint64) string {
- return jwt.HashidsEncode(int(userId))
- }
- func GetAccessKeyId() string {
- return "LTAI5tET2mMQVTcMDftuM8Cp"
- }
- func GetAccessKeySecret() string {
- return "AmGsD8VzwEuj8njZpUCUYnK7uUBTJa"
- }
- func GetAppId() string {
- return "3dt553bl52"
- }
- func GetTenantId() int64 {
- return int64(27174)
- }
|