go-sdk/gitea/gitea.go

126 lines
3 KiB
Go
Raw Normal View History

2014-11-15 03:37:41 +05:30
// Copyright 2014 The Gogs Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
2015-08-26 19:04:27 +05:30
package gitea
2014-11-15 03:37:41 +05:30
import (
"encoding/json"
"errors"
"fmt"
2014-11-15 03:37:41 +05:30
"io"
"io/ioutil"
"net/http"
"strings"
)
2016-11-10 15:14:00 +05:30
// Version return the library version
2014-11-15 03:37:41 +05:30
func Version() string {
2016-08-25 09:28:09 +05:30
return "0.12.3"
2014-11-15 03:37:41 +05:30
}
// Client represents a Gogs API client.
type Client struct {
url string
accessToken string
2019-02-16 04:02:08 +05:30
sudo string
2014-11-15 03:37:41 +05:30
client *http.Client
}
// NewClient initializes and returns a API client.
func NewClient(url, token string) *Client {
return &Client{
url: strings.TrimSuffix(url, "/"),
accessToken: token,
client: &http.Client{},
}
}
// NewClientWithHTTP creates an API client with a custom http client
func NewClientWithHTTP(url string, httpClient *http.Client) {
client := NewClient(url, "")
client.client = httpClient
}
2015-10-23 03:12:42 +05:30
// SetHTTPClient replaces default http.Client with user given one.
func (c *Client) SetHTTPClient(client *http.Client) {
c.client = client
}
2019-02-16 04:02:08 +05:30
// SetSudo sets username to impersonate.
func (c *Client) SetSudo(sudo string) {
c.sudo = sudo
}
func (c *Client) doRequest(method, path string, header http.Header, body io.Reader) (*http.Response, error) {
2014-11-15 03:37:41 +05:30
req, err := http.NewRequest(method, c.url+"/api/v1"+path, body)
if err != nil {
return nil, err
}
if len(c.accessToken) != 0 {
req.Header.Set("Authorization", "token "+c.accessToken)
}
2019-02-16 04:02:08 +05:30
if c.sudo != "" {
req.Header.Set("Sudo", c.sudo)
}
2014-11-15 03:37:41 +05:30
for k, v := range header {
req.Header[k] = v
}
return c.client.Do(req)
}
func (c *Client) getResponse(method, path string, header http.Header, body io.Reader) ([]byte, error) {
resp, err := c.doRequest(method, path, header, body)
2014-11-15 03:37:41 +05:30
if err != nil {
return nil, err
}
defer resp.Body.Close()
data, err := ioutil.ReadAll(resp.Body)
if err != nil {
return nil, err
}
2014-12-13 06:59:51 +05:30
switch resp.StatusCode {
case 403:
return nil, errors.New("403 Forbidden")
case 404:
return nil, errors.New("404 Not Found")
case 409:
return nil, errors.New("409 Conflict")
case 422:
return nil, fmt.Errorf("422 Unprocessable Entity: %s", string(data))
2014-11-15 03:37:41 +05:30
}
2016-01-04 02:21:12 +05:30
if resp.StatusCode/100 != 2 {
2014-11-15 03:37:41 +05:30
errMap := make(map[string]interface{})
if err = json.Unmarshal(data, &errMap); err != nil {
// when the JSON can't be parsed, data was probably empty or a plain string,
// so we try to return a helpful error anyway
return nil, fmt.Errorf("Unknown API Error: %d %s", resp.StatusCode, string(data))
2014-11-15 03:37:41 +05:30
}
return nil, errors.New(errMap["message"].(string))
}
return data, nil
}
func (c *Client) getParsedResponse(method, path string, header http.Header, body io.Reader, obj interface{}) error {
data, err := c.getResponse(method, path, header, body)
if err != nil {
return err
}
return json.Unmarshal(data, obj)
}
2016-10-12 01:22:07 +05:30
func (c *Client) getStatusCode(method, path string, header http.Header, body io.Reader) (int, error) {
resp, err := c.doRequest(method, path, header, body)
if err != nil {
return -1, err
}
defer resp.Body.Close()
return resp.StatusCode, nil
}