// Copyright 2014 The Gogs Authors. All rights reserved. // Copyright 2019 The Gitea Authors. All rights reserved. // Use of this source code is governed by a MIT-style // license that can be found in the LICENSE file. package gitea import ( "bytes" "encoding/base64" "encoding/json" "fmt" "net/http" "code.gitea.io/gitea/modules/structs" ) // BasicAuthEncode generate base64 of basic auth head func BasicAuthEncode(user, pass string) string { return base64.StdEncoding.EncodeToString([]byte(user + ":" + pass)) } // AccessToken is equal to structs.AccessToken type AccessToken = structs.AccessToken // ListAccessTokens lista all the access tokens of user func (c *Client) ListAccessTokens(user, pass string) ([]*AccessToken, error) { tokens := make([]*AccessToken, 0, 10) return tokens, c.getParsedResponse("GET", fmt.Sprintf("/users/%s/tokens", user), http.Header{"Authorization": []string{"Basic " + BasicAuthEncode(user, pass)}}, nil, &tokens) } // CreateAccessToken create one access token with options func (c *Client) CreateAccessToken(user, pass string, opt structs.CreateAccessTokenOption) (*AccessToken, error) { body, err := json.Marshal(&opt) if err != nil { return nil, err } t := new(AccessToken) return t, c.getParsedResponse("POST", fmt.Sprintf("/users/%s/tokens", user), http.Header{ "content-type": []string{"application/json"}, "Authorization": []string{"Basic " + BasicAuthEncode(user, pass)}}, bytes.NewReader(body), t) } // DeleteAccessToken delete token with key id func (c *Client) DeleteAccessToken(user string, keyID int64) error { _, err := c.getResponse("DELETE", fmt.Sprintf("/user/%s/tokens/%d", user, keyID), nil, nil) return err }