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-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-05-27 09:48:09 -04:00
|
|
|
func (c *Client) ListMyOrgs(opt ListOrgsOptions) ([]*Organization, error) {
|
|
|
|
opt.setDefaults()
|
|
|
|
orgs := make([]*Organization, 0, opt.PageSize)
|
|
|
|
return orgs, c.getParsedResponse("GET", fmt.Sprintf("/user/orgs?%s", opt.getURLQuery().Encode()), nil, nil, &orgs)
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// ListUserOrgs list all of some user's organizations
|
2020-05-27 09:48:09 -04:00
|
|
|
func (c *Client) ListUserOrgs(user string, opt ListOrgsOptions) ([]*Organization, error) {
|
|
|
|
opt.setDefaults()
|
|
|
|
orgs := make([]*Organization, 0, opt.PageSize)
|
|
|
|
return orgs, c.getParsedResponse("GET", fmt.Sprintf("/users/%s/orgs?%s", user, opt.getURLQuery().Encode()), nil, nil, &orgs)
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetOrg get one organization by name
|
|
|
|
func (c *Client) GetOrg(orgname string) (*Organization, error) {
|
|
|
|
org := new(Organization)
|
|
|
|
return org, c.getParsedResponse("GET", fmt.Sprintf("/orgs/%s", orgname), nil, nil, org)
|
|
|
|
}
|
|
|
|
|
|
|
|
// CreateOrgOption options for creating an organization
|
|
|
|
type CreateOrgOption struct {
|
2019-10-13 11:13:33 -04:00
|
|
|
UserName string `json:"username"`
|
|
|
|
FullName string `json:"full_name"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Website string `json:"website"`
|
|
|
|
Location string `json:"location"`
|
|
|
|
// possible values are `public` (default), `limited` or `private`
|
|
|
|
// enum: public,limited,private
|
|
|
|
Visibility string `json:"visibility"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// CreateOrg creates an organization
|
|
|
|
func (c *Client) CreateOrg(opt CreateOrgOption) (*Organization, error) {
|
|
|
|
body, err := json.Marshal(&opt)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
org := new(Organization)
|
|
|
|
return org, c.getParsedResponse("POST", "/orgs", jsonHeader, bytes.NewReader(body), org)
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// EditOrgOption options for editing an organization
|
|
|
|
type EditOrgOption struct {
|
|
|
|
FullName string `json:"full_name"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Website string `json:"website"`
|
|
|
|
Location string `json:"location"`
|
2019-10-13 11:13:33 -04:00
|
|
|
// possible values are `public`, `limited` or `private`
|
|
|
|
// enum: public,limited,private
|
|
|
|
Visibility string `json:"visibility"`
|
2019-04-25 13:06:53 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// EditOrg modify one organization via options
|
|
|
|
func (c *Client) EditOrg(orgname string, opt EditOrgOption) error {
|
|
|
|
body, err := json.Marshal(&opt)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
_, err = c.getResponse("PATCH", fmt.Sprintf("/orgs/%s", orgname), jsonHeader, bytes.NewReader(body))
|
|
|
|
return err
|
|
|
|
}
|
2019-10-13 11:13:33 -04:00
|
|
|
|
|
|
|
// DeleteOrg deletes an organization
|
|
|
|
func (c *Client) DeleteOrg(orgname string) error {
|
|
|
|
_, err := c.getResponse("DELETE", fmt.Sprintf("/orgs/%s", orgname), nil, nil)
|
|
|
|
return err
|
|
|
|
}
|