mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	* add migrations * fix package dependency * fix lints * implements migrations except pull requests * add releases * migrating releases * fix bug * fix lint * fix migrate releases * fix tests * add rollback * pull request migtations * fix import * fix go module vendor * add tests for upload to gitea * more migrate options * fix swagger-check * fix misspell * add options on migration UI * fix log error * improve UI options on migrating * add support for username password when migrating from github * fix tests * remove comments and fix migrate limitation * improve error handles * migrate API will also support migrate milestones/labels/issues/pulls/releases * fix tests and remove unused codes * add DownloaderFactory and docs about how to create a new Downloader * fix misspell * fix migration docs * Add hints about migrate options on migration page * fix tests
		
			
				
	
	
		
			436 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			436 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2015 The go-github AUTHORS. All rights reserved.
 | ||
| //
 | ||
| // Use of this source code is governed by a BSD-style
 | ||
| // license that can be found in the LICENSE file.
 | ||
| 
 | ||
| package github
 | ||
| 
 | ||
| import (
 | ||
| 	"context"
 | ||
| 	"fmt"
 | ||
| )
 | ||
| 
 | ||
| // Scope models a GitHub authorization scope.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth/#scopes
 | ||
| type Scope string
 | ||
| 
 | ||
| // This is the set of scopes for GitHub API V3
 | ||
| const (
 | ||
| 	ScopeNone           Scope = "(no scope)" // REVISIT: is this actually returned, or just a documentation artifact?
 | ||
| 	ScopeUser           Scope = "user"
 | ||
| 	ScopeUserEmail      Scope = "user:email"
 | ||
| 	ScopeUserFollow     Scope = "user:follow"
 | ||
| 	ScopePublicRepo     Scope = "public_repo"
 | ||
| 	ScopeRepo           Scope = "repo"
 | ||
| 	ScopeRepoDeployment Scope = "repo_deployment"
 | ||
| 	ScopeRepoStatus     Scope = "repo:status"
 | ||
| 	ScopeDeleteRepo     Scope = "delete_repo"
 | ||
| 	ScopeNotifications  Scope = "notifications"
 | ||
| 	ScopeGist           Scope = "gist"
 | ||
| 	ScopeReadRepoHook   Scope = "read:repo_hook"
 | ||
| 	ScopeWriteRepoHook  Scope = "write:repo_hook"
 | ||
| 	ScopeAdminRepoHook  Scope = "admin:repo_hook"
 | ||
| 	ScopeAdminOrgHook   Scope = "admin:org_hook"
 | ||
| 	ScopeReadOrg        Scope = "read:org"
 | ||
| 	ScopeWriteOrg       Scope = "write:org"
 | ||
| 	ScopeAdminOrg       Scope = "admin:org"
 | ||
| 	ScopeReadPublicKey  Scope = "read:public_key"
 | ||
| 	ScopeWritePublicKey Scope = "write:public_key"
 | ||
| 	ScopeAdminPublicKey Scope = "admin:public_key"
 | ||
| 	ScopeReadGPGKey     Scope = "read:gpg_key"
 | ||
| 	ScopeWriteGPGKey    Scope = "write:gpg_key"
 | ||
| 	ScopeAdminGPGKey    Scope = "admin:gpg_key"
 | ||
| )
 | ||
| 
 | ||
| // AuthorizationsService handles communication with the authorization related
 | ||
| // methods of the GitHub API.
 | ||
| //
 | ||
| // This service requires HTTP Basic Authentication; it cannot be accessed using
 | ||
| // an OAuth token.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/
 | ||
| type AuthorizationsService service
 | ||
| 
 | ||
| // Authorization represents an individual GitHub authorization.
 | ||
| type Authorization struct {
 | ||
| 	ID             *int64            `json:"id,omitempty"`
 | ||
| 	URL            *string           `json:"url,omitempty"`
 | ||
| 	Scopes         []Scope           `json:"scopes,omitempty"`
 | ||
| 	Token          *string           `json:"token,omitempty"`
 | ||
| 	TokenLastEight *string           `json:"token_last_eight,omitempty"`
 | ||
| 	HashedToken    *string           `json:"hashed_token,omitempty"`
 | ||
| 	App            *AuthorizationApp `json:"app,omitempty"`
 | ||
| 	Note           *string           `json:"note,omitempty"`
 | ||
| 	NoteURL        *string           `json:"note_url,omitempty"`
 | ||
| 	UpdatedAt      *Timestamp        `json:"updated_at,omitempty"`
 | ||
| 	CreatedAt      *Timestamp        `json:"created_at,omitempty"`
 | ||
| 	Fingerprint    *string           `json:"fingerprint,omitempty"`
 | ||
| 
 | ||
| 	// User is only populated by the Check and Reset methods.
 | ||
| 	User *User `json:"user,omitempty"`
 | ||
| }
 | ||
| 
 | ||
| func (a Authorization) String() string {
 | ||
| 	return Stringify(a)
 | ||
| }
 | ||
| 
 | ||
| // AuthorizationApp represents an individual GitHub app (in the context of authorization).
 | ||
| type AuthorizationApp struct {
 | ||
| 	URL      *string `json:"url,omitempty"`
 | ||
| 	Name     *string `json:"name,omitempty"`
 | ||
| 	ClientID *string `json:"client_id,omitempty"`
 | ||
| }
 | ||
| 
 | ||
| func (a AuthorizationApp) String() string {
 | ||
| 	return Stringify(a)
 | ||
| }
 | ||
| 
 | ||
| // Grant represents an OAuth application that has been granted access to an account.
 | ||
| type Grant struct {
 | ||
| 	ID        *int64            `json:"id,omitempty"`
 | ||
| 	URL       *string           `json:"url,omitempty"`
 | ||
| 	App       *AuthorizationApp `json:"app,omitempty"`
 | ||
| 	CreatedAt *Timestamp        `json:"created_at,omitempty"`
 | ||
| 	UpdatedAt *Timestamp        `json:"updated_at,omitempty"`
 | ||
| 	Scopes    []string          `json:"scopes,omitempty"`
 | ||
| }
 | ||
| 
 | ||
| func (g Grant) String() string {
 | ||
| 	return Stringify(g)
 | ||
| }
 | ||
| 
 | ||
| // AuthorizationRequest represents a request to create an authorization.
 | ||
| type AuthorizationRequest struct {
 | ||
| 	Scopes       []Scope `json:"scopes,omitempty"`
 | ||
| 	Note         *string `json:"note,omitempty"`
 | ||
| 	NoteURL      *string `json:"note_url,omitempty"`
 | ||
| 	ClientID     *string `json:"client_id,omitempty"`
 | ||
| 	ClientSecret *string `json:"client_secret,omitempty"`
 | ||
| 	Fingerprint  *string `json:"fingerprint,omitempty"`
 | ||
| }
 | ||
| 
 | ||
| func (a AuthorizationRequest) String() string {
 | ||
| 	return Stringify(a)
 | ||
| }
 | ||
| 
 | ||
| // AuthorizationUpdateRequest represents a request to update an authorization.
 | ||
| //
 | ||
| // Note that for any one update, you must only provide one of the "scopes"
 | ||
| // fields. That is, you may provide only one of "Scopes", or "AddScopes", or
 | ||
| // "RemoveScopes".
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#update-an-existing-authorization
 | ||
| type AuthorizationUpdateRequest struct {
 | ||
| 	Scopes       []string `json:"scopes,omitempty"`
 | ||
| 	AddScopes    []string `json:"add_scopes,omitempty"`
 | ||
| 	RemoveScopes []string `json:"remove_scopes,omitempty"`
 | ||
| 	Note         *string  `json:"note,omitempty"`
 | ||
| 	NoteURL      *string  `json:"note_url,omitempty"`
 | ||
| 	Fingerprint  *string  `json:"fingerprint,omitempty"`
 | ||
| }
 | ||
| 
 | ||
| func (a AuthorizationUpdateRequest) String() string {
 | ||
| 	return Stringify(a)
 | ||
| }
 | ||
| 
 | ||
| // List the authorizations for the authenticated user.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#list-your-authorizations
 | ||
| func (s *AuthorizationsService) List(ctx context.Context, opt *ListOptions) ([]*Authorization, *Response, error) {
 | ||
| 	u := "authorizations"
 | ||
| 	u, err := addOptions(u, opt)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("GET", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	var auths []*Authorization
 | ||
| 	resp, err := s.client.Do(ctx, req, &auths)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 	return auths, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // Get a single authorization.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#get-a-single-authorization
 | ||
| func (s *AuthorizationsService) Get(ctx context.Context, id int64) (*Authorization, *Response, error) {
 | ||
| 	u := fmt.Sprintf("authorizations/%d", id)
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("GET", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	a := new(Authorization)
 | ||
| 	resp, err := s.client.Do(ctx, req, a)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 	return a, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // Create a new authorization for the specified OAuth application.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#create-a-new-authorization
 | ||
| func (s *AuthorizationsService) Create(ctx context.Context, auth *AuthorizationRequest) (*Authorization, *Response, error) {
 | ||
| 	u := "authorizations"
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("POST", u, auth)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	a := new(Authorization)
 | ||
| 	resp, err := s.client.Do(ctx, req, a)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 	return a, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // GetOrCreateForApp creates a new authorization for the specified OAuth
 | ||
| // application, only if an authorization for that application doesn’t already
 | ||
| // exist for the user.
 | ||
| //
 | ||
| // If a new token is created, the HTTP status code will be "201 Created", and
 | ||
| // the returned Authorization.Token field will be populated. If an existing
 | ||
| // token is returned, the status code will be "200 OK" and the
 | ||
| // Authorization.Token field will be empty.
 | ||
| //
 | ||
| // clientID is the OAuth Client ID with which to create the token.
 | ||
| //
 | ||
| // GitHub API docs:
 | ||
| // https://developer.github.com/v3/oauth_authorizations/#get-or-create-an-authorization-for-a-specific-app
 | ||
| // https://developer.github.com/v3/oauth_authorizations/#get-or-create-an-authorization-for-a-specific-app-and-fingerprint
 | ||
| func (s *AuthorizationsService) GetOrCreateForApp(ctx context.Context, clientID string, auth *AuthorizationRequest) (*Authorization, *Response, error) {
 | ||
| 	var u string
 | ||
| 	if auth.Fingerprint == nil || *auth.Fingerprint == "" {
 | ||
| 		u = fmt.Sprintf("authorizations/clients/%v", clientID)
 | ||
| 	} else {
 | ||
| 		u = fmt.Sprintf("authorizations/clients/%v/%v", clientID, *auth.Fingerprint)
 | ||
| 	}
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("PUT", u, auth)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	a := new(Authorization)
 | ||
| 	resp, err := s.client.Do(ctx, req, a)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return a, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // Edit a single authorization.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#update-an-existing-authorization
 | ||
| func (s *AuthorizationsService) Edit(ctx context.Context, id int64, auth *AuthorizationUpdateRequest) (*Authorization, *Response, error) {
 | ||
| 	u := fmt.Sprintf("authorizations/%d", id)
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("PATCH", u, auth)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	a := new(Authorization)
 | ||
| 	resp, err := s.client.Do(ctx, req, a)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return a, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // Delete a single authorization.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#delete-an-authorization
 | ||
| func (s *AuthorizationsService) Delete(ctx context.Context, id int64) (*Response, error) {
 | ||
| 	u := fmt.Sprintf("authorizations/%d", id)
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("DELETE", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return s.client.Do(ctx, req, nil)
 | ||
| }
 | ||
| 
 | ||
| // Check if an OAuth token is valid for a specific app.
 | ||
| //
 | ||
| // Note that this operation requires the use of BasicAuth, but where the
 | ||
| // username is the OAuth application clientID, and the password is its
 | ||
| // clientSecret. Invalid tokens will return a 404 Not Found.
 | ||
| //
 | ||
| // The returned Authorization.User field will be populated.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#check-an-authorization
 | ||
| func (s *AuthorizationsService) Check(ctx context.Context, clientID string, token string) (*Authorization, *Response, error) {
 | ||
| 	u := fmt.Sprintf("applications/%v/tokens/%v", clientID, token)
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("GET", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	a := new(Authorization)
 | ||
| 	resp, err := s.client.Do(ctx, req, a)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return a, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // Reset is used to reset a valid OAuth token without end user involvement.
 | ||
| // Applications must save the "token" property in the response, because changes
 | ||
| // take effect immediately.
 | ||
| //
 | ||
| // Note that this operation requires the use of BasicAuth, but where the
 | ||
| // username is the OAuth application clientID, and the password is its
 | ||
| // clientSecret. Invalid tokens will return a 404 Not Found.
 | ||
| //
 | ||
| // The returned Authorization.User field will be populated.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#reset-an-authorization
 | ||
| func (s *AuthorizationsService) Reset(ctx context.Context, clientID string, token string) (*Authorization, *Response, error) {
 | ||
| 	u := fmt.Sprintf("applications/%v/tokens/%v", clientID, token)
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("POST", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	a := new(Authorization)
 | ||
| 	resp, err := s.client.Do(ctx, req, a)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return a, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // Revoke an authorization for an application.
 | ||
| //
 | ||
| // Note that this operation requires the use of BasicAuth, but where the
 | ||
| // username is the OAuth application clientID, and the password is its
 | ||
| // clientSecret. Invalid tokens will return a 404 Not Found.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#revoke-an-authorization-for-an-application
 | ||
| func (s *AuthorizationsService) Revoke(ctx context.Context, clientID string, token string) (*Response, error) {
 | ||
| 	u := fmt.Sprintf("applications/%v/tokens/%v", clientID, token)
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("DELETE", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return s.client.Do(ctx, req, nil)
 | ||
| }
 | ||
| 
 | ||
| // ListGrants lists the set of OAuth applications that have been granted
 | ||
| // access to a user's account. This will return one entry for each application
 | ||
| // that has been granted access to the account, regardless of the number of
 | ||
| // tokens an application has generated for the user.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#list-your-grants
 | ||
| func (s *AuthorizationsService) ListGrants(ctx context.Context, opt *ListOptions) ([]*Grant, *Response, error) {
 | ||
| 	u, err := addOptions("applications/grants", opt)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	req, err := s.client.NewRequest("GET", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	grants := []*Grant{}
 | ||
| 	resp, err := s.client.Do(ctx, req, &grants)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return grants, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // GetGrant gets a single OAuth application grant.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#get-a-single-grant
 | ||
| func (s *AuthorizationsService) GetGrant(ctx context.Context, id int64) (*Grant, *Response, error) {
 | ||
| 	u := fmt.Sprintf("applications/grants/%d", id)
 | ||
| 	req, err := s.client.NewRequest("GET", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	grant := new(Grant)
 | ||
| 	resp, err := s.client.Do(ctx, req, grant)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return grant, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // DeleteGrant deletes an OAuth application grant. Deleting an application's
 | ||
| // grant will also delete all OAuth tokens associated with the application for
 | ||
| // the user.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/v3/oauth_authorizations/#delete-a-grant
 | ||
| func (s *AuthorizationsService) DeleteGrant(ctx context.Context, id int64) (*Response, error) {
 | ||
| 	u := fmt.Sprintf("applications/grants/%d", id)
 | ||
| 	req, err := s.client.NewRequest("DELETE", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return s.client.Do(ctx, req, nil)
 | ||
| }
 | ||
| 
 | ||
| // CreateImpersonation creates an impersonation OAuth token.
 | ||
| //
 | ||
| // This requires admin permissions. With the returned Authorization.Token
 | ||
| // you can e.g. create or delete a user's public SSH key. NOTE: creating a
 | ||
| // new token automatically revokes an existing one.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/enterprise/v3/enterprise-admin/users/#create-an-impersonation-oauth-token
 | ||
| func (s *AuthorizationsService) CreateImpersonation(ctx context.Context, username string, authReq *AuthorizationRequest) (*Authorization, *Response, error) {
 | ||
| 	u := fmt.Sprintf("admin/users/%v/authorizations", username)
 | ||
| 	req, err := s.client.NewRequest("POST", u, authReq)
 | ||
| 	if err != nil {
 | ||
| 		return nil, nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	a := new(Authorization)
 | ||
| 	resp, err := s.client.Do(ctx, req, a)
 | ||
| 	if err != nil {
 | ||
| 		return nil, resp, err
 | ||
| 	}
 | ||
| 	return a, resp, nil
 | ||
| }
 | ||
| 
 | ||
| // DeleteImpersonation deletes an impersonation OAuth token.
 | ||
| //
 | ||
| // NOTE: there can be only one at a time.
 | ||
| //
 | ||
| // GitHub API docs: https://developer.github.com/enterprise/v3/enterprise-admin/users/#delete-an-impersonation-oauth-token
 | ||
| func (s *AuthorizationsService) DeleteImpersonation(ctx context.Context, username string) (*Response, error) {
 | ||
| 	u := fmt.Sprintf("admin/users/%v/authorizations", username)
 | ||
| 	req, err := s.client.NewRequest("DELETE", u, nil)
 | ||
| 	if err != nil {
 | ||
| 		return nil, err
 | ||
| 	}
 | ||
| 
 | ||
| 	return s.client.Do(ctx, req, nil)
 | ||
| }
 |