2019-04-25 13:06:53 -04:00
|
|
|
// Copyright 2015 The Gogs Authors. All rights reserved.
|
2019-10-13 11:13:33 -04:00
|
|
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
2019-04-25 13:06:53 -04:00
|
|
|
// 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/json"
|
|
|
|
"fmt"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Organization represents an organization
|
|
|
|
type Organization struct {
|
2019-10-13 11:13:33 -04:00
|
|
|
ID int64 `json:"id"`
|
|
|
|
UserName string `json:"username"`
|
|
|
|
FullName string `json:"full_name"`
|
|
|
|
AvatarURL string `json:"avatar_url"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Website string `json:"website"`
|
|
|
|
Location string `json:"location"`
|
|
|
|
Visibility string `json:"visibility"`
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
2020-09-15 22:01:41 -04:00
|
|
|
// VisibleType defines the visibility
|
|
|
|
type VisibleType string
|
|
|
|
|
|
|
|
const (
|
|
|
|
// VisibleTypePublic Visible for everyone
|
|
|
|
VisibleTypePublic VisibleType = "public"
|
|
|
|
|
|
|
|
// VisibleTypeLimited Visible for every connected user
|
|
|
|
VisibleTypeLimited VisibleType = "limited"
|
|
|
|
|
|
|
|
// VisibleTypePrivate Visible only for organization's members
|
|
|
|
VisibleTypePrivate VisibleType = "private"
|
|
|
|
)
|
|
|
|
|
2020-05-27 09:48:09 -04:00
|
|
|
// ListOrgsOptions options for listing organizations
|
|
|
|
type ListOrgsOptions struct {
|
|
|
|
ListOptions
|
|
|
|
}
|
|
|
|
|
2019-04-25 13:06:53 -04:00
|
|
|
// ListMyOrgs list all of current user's organizations
|
2020-09-15 22:01:41 -04:00
|
|
|
func (c *Client) ListMyOrgs(opt ListOrgsOptions) ([]*Organization, *Response, error) {
|
2020-05-27 09:48:09 -04:00
|
|
|
opt.setDefaults()
|
|
|
|
orgs := make([]*Organization, 0, opt.PageSize)
|
2020-09-15 22:01:41 -04:00
|
|
|
resp, err := c.getParsedResponse("GET", fmt.Sprintf("/user/orgs?%s", opt.getURLQuery().Encode()), nil, nil, &orgs)
|
|
|
|
return orgs, resp, err
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// ListUserOrgs list all of some user's organizations
|
2020-09-15 22:01:41 -04:00
|
|
|
func (c *Client) ListUserOrgs(user string, opt ListOrgsOptions) ([]*Organization, *Response, error) {
|
2020-05-27 09:48:09 -04:00
|
|
|
opt.setDefaults()
|
|
|
|
orgs := make([]*Organization, 0, opt.PageSize)
|
2020-09-15 22:01:41 -04:00
|
|
|
resp, err := c.getParsedResponse("GET", fmt.Sprintf("/users/%s/orgs?%s", user, opt.getURLQuery().Encode()), nil, nil, &orgs)
|
|
|
|
return orgs, resp, err
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetOrg get one organization by name
|
2020-09-15 22:01:41 -04:00
|
|
|
func (c *Client) GetOrg(orgname string) (*Organization, *Response, error) {
|
2019-04-25 13:06:53 -04:00
|
|
|
org := new(Organization)
|
2020-09-15 22:01:41 -04:00
|
|
|
resp, err := c.getParsedResponse("GET", fmt.Sprintf("/orgs/%s", orgname), nil, nil, org)
|
|
|
|
return org, resp, err
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// CreateOrgOption options for creating an organization
|
|
|
|
type CreateOrgOption struct {
|
2020-09-15 22:01:41 -04:00
|
|
|
Name string `json:"username"`
|
|
|
|
FullName string `json:"full_name"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Website string `json:"website"`
|
|
|
|
Location string `json:"location"`
|
|
|
|
Visibility VisibleType `json:"visibility"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// checkVisibilityOpt check if mode exist
|
|
|
|
func checkVisibilityOpt(v VisibleType) bool {
|
|
|
|
return v == VisibleTypePublic || v == VisibleTypeLimited || v == VisibleTypePrivate
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate the CreateOrgOption struct
|
|
|
|
func (opt CreateOrgOption) Validate() error {
|
|
|
|
if len(opt.Name) == 0 {
|
|
|
|
return fmt.Errorf("empty org name")
|
|
|
|
}
|
|
|
|
if len(opt.Visibility) != 0 && !checkVisibilityOpt(opt.Visibility) {
|
|
|
|
return fmt.Errorf("infalid bisibility option")
|
|
|
|
}
|
|
|
|
return nil
|
2019-10-13 11:13:33 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// CreateOrg creates an organization
|
2020-09-15 22:01:41 -04:00
|
|
|
func (c *Client) CreateOrg(opt CreateOrgOption) (*Organization, *Response, error) {
|
|
|
|
if err := opt.Validate(); err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
2019-10-13 11:13:33 -04:00
|
|
|
body, err := json.Marshal(&opt)
|
|
|
|
if err != nil {
|
2020-09-15 22:01:41 -04:00
|
|
|
return nil, nil, err
|
2019-10-13 11:13:33 -04:00
|
|
|
}
|
|
|
|
org := new(Organization)
|
2020-09-15 22:01:41 -04:00
|
|
|
resp, err := c.getParsedResponse("POST", "/orgs", jsonHeader, bytes.NewReader(body), org)
|
|
|
|
return org, resp, err
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// EditOrgOption options for editing an organization
|
|
|
|
type EditOrgOption struct {
|
2020-09-15 22:01:41 -04:00
|
|
|
FullName string `json:"full_name"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Website string `json:"website"`
|
|
|
|
Location string `json:"location"`
|
|
|
|
Visibility VisibleType `json:"visibility"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate the EditOrgOption struct
|
|
|
|
func (opt EditOrgOption) Validate() error {
|
|
|
|
if len(opt.Visibility) != 0 && !checkVisibilityOpt(opt.Visibility) {
|
|
|
|
return fmt.Errorf("infalid bisibility option")
|
|
|
|
}
|
|
|
|
return nil
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// EditOrg modify one organization via options
|
2020-09-15 22:01:41 -04:00
|
|
|
func (c *Client) EditOrg(orgname string, opt EditOrgOption) (*Response, error) {
|
|
|
|
if err := opt.Validate(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2019-04-25 13:06:53 -04:00
|
|
|
body, err := json.Marshal(&opt)
|
|
|
|
if err != nil {
|
2020-09-15 22:01:41 -04:00
|
|
|
return nil, err
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
2020-09-15 22:01:41 -04:00
|
|
|
_, resp, err := c.getResponse("PATCH", fmt.Sprintf("/orgs/%s", orgname), jsonHeader, bytes.NewReader(body))
|
|
|
|
return resp, err
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
2019-10-13 11:13:33 -04:00
|
|
|
|
|
|
|
// DeleteOrg deletes an organization
|
2020-09-15 22:01:41 -04:00
|
|
|
func (c *Client) DeleteOrg(orgname string) (*Response, error) {
|
|
|
|
_, resp, err := c.getResponse("DELETE", fmt.Sprintf("/orgs/%s", orgname), jsonHeader, nil)
|
|
|
|
return resp, err
|
2019-10-13 11:13:33 -04:00
|
|
|
}
|