forked from Shiloh/githaven
fd8e8a421a
* Add swagger comment for adminCreateOrg * Add swagger comment for admin route * add hook swagger doc * Add tags * Add auth * Fix name of responses * Edit name method * Update vendor * make generate-swagger
75 lines
2.2 KiB
Go
75 lines
2.2 KiB
Go
// Copyright 2015 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.
|
|
|
|
package gitea
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"fmt"
|
|
)
|
|
|
|
// Organization a group of some repositories, users and teams
|
|
// swagger:response Organization
|
|
type Organization struct {
|
|
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"`
|
|
}
|
|
|
|
// ListMyOrgs list all of current user's organizations
|
|
func (c *Client) ListMyOrgs() ([]*Organization, error) {
|
|
orgs := make([]*Organization, 0, 5)
|
|
return orgs, c.getParsedResponse("GET", "/user/orgs", nil, nil, &orgs)
|
|
}
|
|
|
|
// ListUserOrgs list all of some user's organizations
|
|
func (c *Client) ListUserOrgs(user string) ([]*Organization, error) {
|
|
orgs := make([]*Organization, 0, 5)
|
|
return orgs, c.getParsedResponse("GET", fmt.Sprintf("/users/%s/orgs", user), nil, nil, &orgs)
|
|
}
|
|
|
|
// 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 create one organization options
|
|
// swagger:parameters adminCreateOrg
|
|
type CreateOrgOption struct {
|
|
// in: body
|
|
UserName string `json:"username" binding:"Required"`
|
|
// in: body
|
|
FullName string `json:"full_name"`
|
|
// in: body
|
|
Description string `json:"description"`
|
|
// in: body
|
|
Website string `json:"website"`
|
|
// in: body
|
|
Location string `json:"location"`
|
|
}
|
|
|
|
// EditOrgOption edit one organization options
|
|
type EditOrgOption struct {
|
|
FullName string `json:"full_name"`
|
|
Description string `json:"description"`
|
|
Website string `json:"website"`
|
|
Location string `json:"location"`
|
|
}
|
|
|
|
// 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
|
|
}
|