2016-11-07 14:53:13 +01:00
// 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.
package gitea
import (
"bytes"
"encoding/json"
"fmt"
"time"
)
// Permission represents a API permission.
type Permission struct {
Admin bool ` json:"admin" `
Push bool ` json:"push" `
Pull bool ` json:"pull" `
}
// Repository represents a API repository.
2017-05-02 15:35:59 +02:00
// swagger:response Repository
2016-11-07 14:53:13 +01:00
type Repository struct {
ID int64 ` json:"id" `
Owner * User ` json:"owner" `
Name string ` json:"name" `
FullName string ` json:"full_name" `
Description string ` json:"description" `
2017-05-05 04:55:54 +02:00
Empty bool ` json:"empty" `
2016-11-07 14:53:13 +01:00
Private bool ` json:"private" `
Fork bool ` json:"fork" `
2017-05-12 05:09:26 +02:00
Parent * Repository ` json:"parent" `
2017-02-22 20:53:33 -03:00
Mirror bool ` json:"mirror" `
2017-05-05 04:55:54 +02:00
Size int ` json:"size" `
2016-11-07 14:53:13 +01:00
HTMLURL string ` json:"html_url" `
SSHURL string ` json:"ssh_url" `
CloneURL string ` json:"clone_url" `
Website string ` json:"website" `
Stars int ` json:"stars_count" `
Forks int ` json:"forks_count" `
Watchers int ` json:"watchers_count" `
OpenIssues int ` json:"open_issues_count" `
DefaultBranch string ` json:"default_branch" `
Created time . Time ` json:"created_at" `
Updated time . Time ` json:"updated_at" `
Permissions * Permission ` json:"permissions,omitempty" `
}
2017-05-02 15:35:59 +02:00
// RepositoryList represents a list of API repository.
// swagger:response RepositoryList
type RepositoryList [ ] * Repository
2016-11-07 14:53:13 +01:00
// ListMyRepos lists all repositories for the authenticated user that has access to.
func ( c * Client ) ListMyRepos ( ) ( [ ] * Repository , error ) {
repos := make ( [ ] * Repository , 0 , 10 )
return repos , c . getParsedResponse ( "GET" , "/user/repos" , nil , nil , & repos )
}
2016-11-29 09:09:17 +01:00
// ListUserRepos list all repositories of one user by user's name
2016-11-07 14:53:13 +01:00
func ( c * Client ) ListUserRepos ( user string ) ( [ ] * Repository , error ) {
repos := make ( [ ] * Repository , 0 , 10 )
return repos , c . getParsedResponse ( "GET" , fmt . Sprintf ( "/users/%s/repos" , user ) , nil , nil , & repos )
}
2016-11-29 09:09:17 +01:00
// ListOrgRepos list all repositories of one organization by organization's name
2016-11-07 14:53:13 +01:00
func ( c * Client ) ListOrgRepos ( org string ) ( [ ] * Repository , error ) {
repos := make ( [ ] * Repository , 0 , 10 )
return repos , c . getParsedResponse ( "GET" , fmt . Sprintf ( "/orgs/%s/repos" , org ) , nil , nil , & repos )
}
2016-11-29 09:09:17 +01:00
// CreateRepoOption options when creating repository
2017-08-21 13:13:47 +02:00
//swagger:parameters createOrgRepo adminCreateRepo createCurrentUserRepo
2016-11-07 14:53:13 +01:00
type CreateRepoOption struct {
2017-05-02 15:35:59 +02:00
// Name of the repository to create
//
// in: body
// unique: true
Name string ` json:"name" binding:"Required;AlphaDashDot;MaxSize(100)" `
// Description of the repository to create
//
// in: body
2016-11-07 14:53:13 +01:00
Description string ` json:"description" binding:"MaxSize(255)" `
2017-05-02 15:35:59 +02:00
// Is the repository to create private ?
//
// in: body
Private bool ` json:"private" `
// Init the repository to create ?
//
// in: body
AutoInit bool ` json:"auto_init" `
// Gitignores to use
//
// in: body
Gitignores string ` json:"gitignores" `
// License to use
//
// in: body
License string ` json:"license" `
// Readme of the repository to create
//
// in: body
Readme string ` json:"readme" `
2016-11-07 14:53:13 +01:00
}
// CreateRepo creates a repository for authenticated user.
func ( c * Client ) CreateRepo ( opt CreateRepoOption ) ( * Repository , error ) {
body , err := json . Marshal ( & opt )
if err != nil {
return nil , err
}
repo := new ( Repository )
return repo , c . getParsedResponse ( "POST" , "/user/repos" , jsonHeader , bytes . NewReader ( body ) , repo )
}
// CreateOrgRepo creates an organization repository for authenticated user.
func ( c * Client ) CreateOrgRepo ( org string , opt CreateRepoOption ) ( * Repository , error ) {
body , err := json . Marshal ( & opt )
if err != nil {
return nil , err
}
repo := new ( Repository )
return repo , c . getParsedResponse ( "POST" , fmt . Sprintf ( "/org/%s/repos" , org ) , jsonHeader , bytes . NewReader ( body ) , repo )
}
// GetRepo returns information of a repository of given owner.
func ( c * Client ) GetRepo ( owner , reponame string ) ( * Repository , error ) {
repo := new ( Repository )
return repo , c . getParsedResponse ( "GET" , fmt . Sprintf ( "/repos/%s/%s" , owner , reponame ) , nil , nil , repo )
}
// DeleteRepo deletes a repository of user or organization.
func ( c * Client ) DeleteRepo ( owner , repo string ) error {
_ , err := c . getResponse ( "DELETE" , fmt . Sprintf ( "/repos/%s/%s" , owner , repo ) , nil , nil )
return err
}
2016-11-29 09:09:17 +01:00
// MigrateRepoOption options when migrate repository from an external place
2017-08-21 13:13:47 +02:00
// swagger:parameters repoMigrate
2016-11-07 14:53:13 +01:00
type MigrateRepoOption struct {
2017-08-21 13:13:47 +02:00
// in: body
CloneAddr string ` json:"clone_addr" binding:"Required" `
// in: body
2016-11-07 14:53:13 +01:00
AuthUsername string ` json:"auth_username" `
2017-08-21 13:13:47 +02:00
// in: body
2016-11-07 14:53:13 +01:00
AuthPassword string ` json:"auth_password" `
2017-08-21 13:13:47 +02:00
// in: body
UID int ` json:"uid" binding:"Required" `
// in: body
RepoName string ` json:"repo_name" binding:"Required" `
// in: body
Mirror bool ` json:"mirror" `
// in: body
Private bool ` json:"private" `
// in: body
Description string ` json:"description" `
2016-11-07 14:53:13 +01:00
}
// MigrateRepo migrates a repository from other Git hosting sources for the
// authenticated user.
//
// To migrate a repository for a organization, the authenticated user must be a
// owner of the specified organization.
func ( c * Client ) MigrateRepo ( opt MigrateRepoOption ) ( * Repository , error ) {
body , err := json . Marshal ( & opt )
if err != nil {
return nil , err
}
repo := new ( Repository )
return repo , c . getParsedResponse ( "POST" , "/repos/migrate" , jsonHeader , bytes . NewReader ( body ) , repo )
}
2017-05-05 04:55:54 +02:00
// MirrorSync adds a mirrored repository to the mirror sync queue.
func ( c * Client ) MirrorSync ( owner , repo string ) error {
_ , err := c . getResponse ( "POST" , fmt . Sprintf ( "/repos/%s/%s/mirror-sync" , owner , repo ) , nil , nil )
return err
}