mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
Output from 'dep status': PROJECT CONSTRAINT VERSION REVISION LATEST PKGS USED cloud.google.com/go v0.23.0 v0.23.0 0fd7230 v0.23.0 1 github.com/briandowns/openweathermap ^0.11.0 0.11 1b87579 0.11 1 github.com/gdamore/encoding branch master branch master b23993c b23993c 1 github.com/gdamore/tcell ^1.0.0 v1.0.0 061d51a v1.0.0 2 github.com/go-test/deep ^1.0.1 v1.0.1 6592d9c v1.0.1 1 github.com/golang/protobuf v1.1.0 v1.1.0 b4deda0 v1.1.0 1 github.com/google/go-github branch master branch master 2ae5df7 2ae5df7 1 github.com/google/go-querystring branch master branch master 53e6ce1 53e6ce1 1 github.com/jessevdk/go-flags ^1.4.0 v1.4.0 c6ca198 v1.4.0 1 github.com/lucasb-eyer/go-colorful v1.0 v1.0 345fbb3 v1.0 1 github.com/mattn/go-runewidth v0.0.2 v0.0.2 9e777a8 v0.0.2 1 github.com/olebedev/config branch master branch master 9a10d05 9a10d05 1 github.com/radovskyb/watcher ^1.0.2 v1.0.2 6145e14 v1.0.2 1 github.com/rivo/tview branch master branch master 71ecf1f 71ecf1f 1 github.com/yfronto/newrelic branch master branch master f7fa0c6 f7fa0c6 1 golang.org/x/net branch master branch master 1e49130 1e49130 2 golang.org/x/oauth2 branch master branch master 1e0a3fa 1e0a3fa 5 golang.org/x/text v0.3.0 v0.3.0 f21a4df v0.3.0 5 google.golang.org/api branch master branch master 00e3bb8 00e3bb8 4 google.golang.org/appengine v1.0.0 v1.0.0 150dc57 v1.0.0 10 gopkg.in/yaml.v2 ^2.2.1 v2.2.1 5420a8b v2.2.1 1 See https://golang.github.io/dep/docs/daily-dep.html
225 lines
7.4 KiB
Go
225 lines
7.4 KiB
Go
// Copyright 2016 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"
|
|
"errors"
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
)
|
|
|
|
// MigrationService provides access to the migration related functions
|
|
// in the GitHub API.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/migration/
|
|
type MigrationService service
|
|
|
|
// Migration represents a GitHub migration (archival).
|
|
type Migration struct {
|
|
ID *int64 `json:"id,omitempty"`
|
|
GUID *string `json:"guid,omitempty"`
|
|
// State is the current state of a migration.
|
|
// Possible values are:
|
|
// "pending" which means the migration hasn't started yet,
|
|
// "exporting" which means the migration is in progress,
|
|
// "exported" which means the migration finished successfully, or
|
|
// "failed" which means the migration failed.
|
|
State *string `json:"state,omitempty"`
|
|
// LockRepositories indicates whether repositories are locked (to prevent
|
|
// manipulation) while migrating data.
|
|
LockRepositories *bool `json:"lock_repositories,omitempty"`
|
|
// ExcludeAttachments indicates whether attachments should be excluded from
|
|
// the migration (to reduce migration archive file size).
|
|
ExcludeAttachments *bool `json:"exclude_attachments,omitempty"`
|
|
URL *string `json:"url,omitempty"`
|
|
CreatedAt *string `json:"created_at,omitempty"`
|
|
UpdatedAt *string `json:"updated_at,omitempty"`
|
|
Repositories []*Repository `json:"repositories,omitempty"`
|
|
}
|
|
|
|
func (m Migration) String() string {
|
|
return Stringify(m)
|
|
}
|
|
|
|
// MigrationOptions specifies the optional parameters to Migration methods.
|
|
type MigrationOptions struct {
|
|
// LockRepositories indicates whether repositories should be locked (to prevent
|
|
// manipulation) while migrating data.
|
|
LockRepositories bool
|
|
|
|
// ExcludeAttachments indicates whether attachments should be excluded from
|
|
// the migration (to reduce migration archive file size).
|
|
ExcludeAttachments bool
|
|
}
|
|
|
|
// startMigration represents the body of a StartMigration request.
|
|
type startMigration struct {
|
|
// Repositories is a slice of repository names to migrate.
|
|
Repositories []string `json:"repositories,omitempty"`
|
|
|
|
// LockRepositories indicates whether repositories should be locked (to prevent
|
|
// manipulation) while migrating data.
|
|
LockRepositories *bool `json:"lock_repositories,omitempty"`
|
|
|
|
// ExcludeAttachments indicates whether attachments should be excluded from
|
|
// the migration (to reduce migration archive file size).
|
|
ExcludeAttachments *bool `json:"exclude_attachments,omitempty"`
|
|
}
|
|
|
|
// StartMigration starts the generation of a migration archive.
|
|
// repos is a slice of repository names to migrate.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/migration/migrations/#start-a-migration
|
|
func (s *MigrationService) StartMigration(ctx context.Context, org string, repos []string, opt *MigrationOptions) (*Migration, *Response, error) {
|
|
u := fmt.Sprintf("orgs/%v/migrations", org)
|
|
|
|
body := &startMigration{Repositories: repos}
|
|
if opt != nil {
|
|
body.LockRepositories = Bool(opt.LockRepositories)
|
|
body.ExcludeAttachments = Bool(opt.ExcludeAttachments)
|
|
}
|
|
|
|
req, err := s.client.NewRequest("POST", u, body)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
// TODO: remove custom Accept header when this API fully launches.
|
|
req.Header.Set("Accept", mediaTypeMigrationsPreview)
|
|
|
|
m := &Migration{}
|
|
resp, err := s.client.Do(ctx, req, m)
|
|
if err != nil {
|
|
return nil, resp, err
|
|
}
|
|
|
|
return m, resp, nil
|
|
}
|
|
|
|
// ListMigrations lists the most recent migrations.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/migration/migrations/#get-a-list-of-migrations
|
|
func (s *MigrationService) ListMigrations(ctx context.Context, org string) ([]*Migration, *Response, error) {
|
|
u := fmt.Sprintf("orgs/%v/migrations", org)
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
// TODO: remove custom Accept header when this API fully launches.
|
|
req.Header.Set("Accept", mediaTypeMigrationsPreview)
|
|
|
|
var m []*Migration
|
|
resp, err := s.client.Do(ctx, req, &m)
|
|
if err != nil {
|
|
return nil, resp, err
|
|
}
|
|
|
|
return m, resp, nil
|
|
}
|
|
|
|
// MigrationStatus gets the status of a specific migration archive.
|
|
// id is the migration ID.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/migration/migrations/#get-the-status-of-a-migration
|
|
func (s *MigrationService) MigrationStatus(ctx context.Context, org string, id int64) (*Migration, *Response, error) {
|
|
u := fmt.Sprintf("orgs/%v/migrations/%v", org, id)
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
// TODO: remove custom Accept header when this API fully launches.
|
|
req.Header.Set("Accept", mediaTypeMigrationsPreview)
|
|
|
|
m := &Migration{}
|
|
resp, err := s.client.Do(ctx, req, m)
|
|
if err != nil {
|
|
return nil, resp, err
|
|
}
|
|
|
|
return m, resp, nil
|
|
}
|
|
|
|
// MigrationArchiveURL fetches a migration archive URL.
|
|
// id is the migration ID.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/migration/migrations/#download-a-migration-archive
|
|
func (s *MigrationService) MigrationArchiveURL(ctx context.Context, org string, id int64) (url string, err error) {
|
|
u := fmt.Sprintf("orgs/%v/migrations/%v/archive", org, id)
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
// TODO: remove custom Accept header when this API fully launches.
|
|
req.Header.Set("Accept", mediaTypeMigrationsPreview)
|
|
|
|
s.client.clientMu.Lock()
|
|
defer s.client.clientMu.Unlock()
|
|
|
|
// Disable the redirect mechanism because AWS fails if the GitHub auth token is provided.
|
|
var loc string
|
|
saveRedirect := s.client.client.CheckRedirect
|
|
s.client.client.CheckRedirect = func(req *http.Request, via []*http.Request) error {
|
|
loc = req.URL.String()
|
|
return errors.New("disable redirect")
|
|
}
|
|
defer func() { s.client.client.CheckRedirect = saveRedirect }()
|
|
|
|
_, err = s.client.Do(ctx, req, nil) // expect error from disable redirect
|
|
if err == nil {
|
|
return "", errors.New("expected redirect, none provided")
|
|
}
|
|
if !strings.Contains(err.Error(), "disable redirect") {
|
|
return "", err
|
|
}
|
|
return loc, nil
|
|
}
|
|
|
|
// DeleteMigration deletes a previous migration archive.
|
|
// id is the migration ID.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/migration/migrations/#delete-a-migration-archive
|
|
func (s *MigrationService) DeleteMigration(ctx context.Context, org string, id int64) (*Response, error) {
|
|
u := fmt.Sprintf("orgs/%v/migrations/%v/archive", org, id)
|
|
|
|
req, err := s.client.NewRequest("DELETE", u, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
// TODO: remove custom Accept header when this API fully launches.
|
|
req.Header.Set("Accept", mediaTypeMigrationsPreview)
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
}
|
|
|
|
// UnlockRepo unlocks a repository that was locked for migration.
|
|
// id is the migration ID.
|
|
// You should unlock each migrated repository and delete them when the migration
|
|
// is complete and you no longer need the source data.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/migration/migrations/#unlock-a-repository
|
|
func (s *MigrationService) UnlockRepo(ctx context.Context, org string, id int64, repo string) (*Response, error) {
|
|
u := fmt.Sprintf("orgs/%v/migrations/%v/repos/%v/lock", org, id, repo)
|
|
|
|
req, err := s.client.NewRequest("DELETE", u, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
// TODO: remove custom Accept header when this API fully launches.
|
|
req.Header.Set("Accept", mediaTypeMigrationsPreview)
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
}
|