Files
gitea-api/main.go

181 lines
4.9 KiB
Go

package main
import (
_ "embed"
"flag"
"os"
"path"
"code.gitea.io/sdk/gitea"
"github.com/go-git/go-git/v5"
"github.com/go-git/go-git/v5/config"
"golang.design/x/clipboard"
logger "git.site.quack-lab.dev/dave/cylogger"
)
var Version = "1.0.0"
func main() {
name := flag.String("name", "", "Name of the repository")
flag.String("n", "", "Name of the repository")
private := flag.Bool("private", false, "Make the repository private")
flag.Bool("p", false, "Make the repository private (shorthand)")
noinit := flag.Bool("noinit", false, "Do not add remote to the new repo")
flag.Bool("ni", false, "Do not add remote to the new repo (shorthand)")
forceInit := flag.Bool("f", false, "Force assignment of the remote (deletes existing origin)")
remote := flag.String("remote", "origin", "Name of the remote to create for the new repository")
flag.String("r", "origin", "Name of the remote to create for the new repository (shorthand)")
version := flag.Bool("v", false, "Show version")
flag.Bool("version", false, "Show version")
help := flag.Bool("h", false, "Show help")
flag.Bool("help", false, "Show help")
flag.Parse()
logger.InitFlag()
logger.Info("Starting repo %s", Version)
if *version {
logger.Info("Version: %s", Version)
return
}
if *help {
flag.PrintDefaults()
return
}
err := clipboard.Init()
if err != nil {
logger.Error("Error initializing clipboard: %v", err)
return
}
username, ok := os.LookupEnv("GITEA_USER")
if !ok {
logger.Error("GITEA_USER environment variable is required")
return
}
password, ok := os.LookupEnv("GITEA_PASSWORD")
if !ok {
logger.Error("GITEA_PASSWORD environment variable is required")
return
}
url, ok := os.LookupEnv("GITEA_URL")
if !ok {
logger.Error("GITEA_URL environment variable is required")
return
}
if username == "" || password == "" {
logger.Error("GITEA_USER and GITEA_PASSWORD environment variables are required")
return
}
if flag.NArg() > 0 {
*name = flag.Arg(0)
}
if *name == "" {
logger.Error("Repository name is required")
return
}
logger.Info("Username: %s", username)
logger.Info("URL: %s", url)
logger.Info("Name: %s", *name)
logger.Info("Private: %t", *private)
logger.Info("Noinit: %t", *noinit)
logger.Info("ForceInit: %t", *forceInit)
logger.Info("Remote: %s", *remote)
client, err := gitea.NewClient(url)
if err != nil {
logger.Error("Error creating client: %v", err)
return
}
client.SetBasicAuth(username, password)
logger.Info("Getting repository...")
repo, _, err := client.GetRepo(username, *name)
if err == nil {
logger.Info("Repository already exists at:\n%s", repo.CloneURL)
clipboard.Write(clipboard.FmtText, []byte(repo.CloneURL))
} else {
logger.Info("Repository does not exist, creating...")
repo, _, err = client.CreateRepo(gitea.CreateRepoOption{
Name: *name,
Private: *private,
DefaultBranch: "master",
})
if err != nil {
logger.Error("Error creating repository: %v", err)
return
}
logger.Info("Repository created at: %s", repo.CloneURL)
clipboard.Write(clipboard.FmtText, []byte(repo.CloneURL))
}
if !*noinit {
logger.Info("Adding remote to local repository...")
cwd, err := os.Getwd()
if err != nil {
logger.Error("Error getting current working directory: %v", err)
return
}
cwd = path.Clean(cwd)
var localRepo *git.Repository
logger.Info("Checking if local repository exists at %s/.git...", cwd)
_, err = os.Stat(path.Join(cwd, ".git"))
if err == nil {
localRepo, err = git.PlainOpen(cwd)
if err != nil {
logger.Error("Error opening git repository: %v", err)
return
}
} else {
localRepo, err = git.PlainInit(cwd, false)
if err != nil {
logger.Error("Error initializing git repository: %v", err)
return
}
}
logger.Info("Checking if remote %s exists in local repository...", *remote)
_, err = localRepo.Remote(*remote)
if err == nil {
logger.Info("Remote %s exists in local repository", *remote)
if *forceInit {
logger.Info("Deleting remote %s from local repository...", *remote)
err = localRepo.DeleteRemote(*remote)
if err != nil {
logger.Error("Error deleting remote %s from local repository: %v", *remote, err)
return
}
logger.Info("Remote %s deleted from local repository", *remote)
} else {
logger.Error("Remote %s already exists in local repository", *remote)
return
}
}
logger.Info("Adding remote %s to local repository...", *remote)
_, err = localRepo.CreateRemote(&config.RemoteConfig{
Name: *remote,
URLs: []string{repo.CloneURL},
})
if err != nil {
logger.Error("Error adding remote %s to local repository: %v", *remote, err)
return
}
logger.Info("Remote added to local repository")
}
logger.Info("Done")
}