mirror of
https://github.com/larksuite/cli.git
synced 2026-07-04 06:29:52 +08:00
* feat(auth): add response logging and centralize path constants * refactor(auth): improve response logging and error handling * fix(auth): ensure log cleanup runs only once per process Add flag to track if cleanup has run and prevent duplicate executions Add test to verify cleanup only runs once * refactor(auth): simplify log writer and cleanup logic * docs(auth): add comments to auth paths and logging functions * style(auth): fix indentation in path constants * docs(auth): add missing function comments across auth package * docs(tests): add descriptive comments to auth test functions * test(auth): rename test case and cleanup unused params * fix(auth): handle file close error in auth response logging * fix(auth): ensure log cleanup runs only once * refactor(auth): replace custom log writer with standard logger * feat(auth): add structured logging for keychain errors * fix(auth): remove goroutine from auth log cleanup to prevent race condition * fix(auth): remove goroutine from auth log cleanup to prevent race condition * refactor(auth): move auth logging logic to keychain package
41 lines
1.1 KiB
Go
41 lines
1.1 KiB
Go
// Copyright (c) 2026 Lark Technologies Pte. Ltd.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package auth
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"fmt"
|
|
"net/http"
|
|
|
|
lark "github.com/larksuite/oapi-sdk-go/v3"
|
|
larkcore "github.com/larksuite/oapi-sdk-go/v3/core"
|
|
)
|
|
|
|
// VerifyUserToken calls /authen/v1/user_info to confirm the token is accepted server-side.
|
|
// Returns nil on success or an error describing why the server rejected the token.
|
|
func VerifyUserToken(ctx context.Context, sdk *lark.Client, accessToken string) error {
|
|
apiResp, err := sdk.Do(ctx, &larkcore.ApiReq{
|
|
HttpMethod: http.MethodGet,
|
|
ApiPath: PathUserInfoV1,
|
|
SupportedAccessTokenTypes: []larkcore.AccessTokenType{larkcore.AccessTokenTypeUser},
|
|
}, larkcore.WithUserAccessToken(accessToken))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
logSDKResponse(PathUserInfoV1, apiResp)
|
|
|
|
var resp struct {
|
|
Code int `json:"code"`
|
|
Msg string `json:"msg"`
|
|
}
|
|
if err := json.Unmarshal(apiResp.RawBody, &resp); err != nil {
|
|
return fmt.Errorf("failed to parse response: %v", err)
|
|
}
|
|
if resp.Code != 0 {
|
|
return fmt.Errorf("[%d] %s", resp.Code, resp.Msg)
|
|
}
|
|
return nil
|
|
}
|