2019-04-15 22:58:32 +02:00
|
|
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
2019-04-15 22:40:27 +02:00
|
|
|
// Use of this source code is governed by a MIT-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
|
2019-05-06 18:21:41 +02:00
|
|
|
"code.gitea.io/sdk/gitea"
|
|
|
|
|
2019-04-15 22:40:27 +02:00
|
|
|
"github.com/urfave/cli"
|
|
|
|
)
|
|
|
|
|
|
|
|
// CmdRepos represents to login a gitea server.
|
|
|
|
var CmdRepos = cli.Command{
|
|
|
|
Name: "repos",
|
|
|
|
Usage: "Operate with repositories",
|
|
|
|
Description: `Operate with repositories`,
|
2019-05-06 18:21:41 +02:00
|
|
|
Action: runReposList,
|
|
|
|
Subcommands: []cli.Command{
|
|
|
|
CmdReposList,
|
|
|
|
CmdReposFork,
|
|
|
|
},
|
2019-04-15 22:40:27 +02:00
|
|
|
Flags: []cli.Flag{
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "login, l",
|
|
|
|
Usage: "Indicate one login, optional when inside a gitea repository",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2019-05-06 18:21:41 +02:00
|
|
|
// CmdReposList represents a sub command of issues to list issues
|
|
|
|
var CmdReposList = cli.Command{
|
|
|
|
Name: "ls",
|
|
|
|
Usage: "List available repositories",
|
|
|
|
Description: `List available repositories`,
|
|
|
|
Action: runReposList,
|
|
|
|
}
|
|
|
|
|
|
|
|
func runReposList(ctx *cli.Context) error {
|
2019-04-15 22:40:27 +02:00
|
|
|
login := initCommandLoginOnly(ctx)
|
|
|
|
|
|
|
|
rps, err := login.Client().ListMyRepos()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(rps) == 0 {
|
|
|
|
fmt.Println("No repositories found")
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-04-25 15:59:41 +02:00
|
|
|
fmt.Println("Name | Type/Mode | SSH-URL | Owner")
|
2019-04-15 22:40:27 +02:00
|
|
|
for _, rp := range rps {
|
|
|
|
var mode = "source"
|
|
|
|
if rp.Fork {
|
|
|
|
mode = "fork"
|
|
|
|
}
|
|
|
|
if rp.Mirror {
|
|
|
|
mode = "mirror"
|
|
|
|
}
|
2019-04-25 15:59:41 +02:00
|
|
|
fmt.Printf("%s | %s | %s | %s\n", rp.FullName, mode, rp.SSHURL, rp.Owner.UserName)
|
2019-04-15 22:40:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-05-06 18:21:41 +02:00
|
|
|
// CmdReposFork represents a sub command of issues to list issues
|
|
|
|
var CmdReposFork = cli.Command{
|
|
|
|
Name: "fork",
|
|
|
|
Usage: "fork repository",
|
|
|
|
Description: `fork repository`,
|
|
|
|
Action: runReposFork,
|
|
|
|
Flags: []cli.Flag{
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "login, l",
|
|
|
|
Usage: "Indicate one login, optional when inside a gitea repository",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "repo, r",
|
|
|
|
Usage: "Indicate one repo, optional when inside a gitea repository",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "org",
|
|
|
|
Usage: "Organization to fork the repository for (optional, default = logged in user)",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func runReposFork(ctx *cli.Context) error {
|
|
|
|
login, owner, repo := initCommand(ctx)
|
|
|
|
forkOptions := gitea.CreateForkOption{}
|
|
|
|
if org := ctx.String("org"); org != "" {
|
|
|
|
forkOptions = gitea.CreateForkOption{
|
|
|
|
Organization: &org,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_, err := login.Client().CreateFork(owner, repo, forkOptions)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
user, _ := login.Client().GetMyUserInfo()
|
|
|
|
|
|
|
|
fmt.Printf("Forked '%s/%s' to '%s/%s'\n", owner, repo, user.UserName, repo)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-04-28 14:27:33 +02:00
|
|
|
func initCommandLoginOnly(ctx *cli.Context) *Login {
|
2019-04-15 22:40:27 +02:00
|
|
|
err := loadConfig(yamlConfigPath)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal("load config file failed", yamlConfigPath)
|
|
|
|
}
|
|
|
|
|
|
|
|
var login *Login
|
|
|
|
if loginFlag := getGlobalFlag(ctx, "login"); loginFlag == "" {
|
|
|
|
login, err = getActiveLogin()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
login = getLoginByName(loginFlag)
|
|
|
|
if login == nil {
|
|
|
|
log.Fatal("indicated login name", loginFlag, "does not exist")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return login
|
|
|
|
}
|