Files
gitea-api/main.go

183 lines
4.8 KiB
Go

package main
import (
"bytes"
_ "embed"
"flag"
"fmt"
"io"
"log"
"os"
"path"
"code.gitea.io/sdk/gitea"
"github.com/go-git/go-git/v5"
"github.com/go-git/go-git/v5/config"
"github.com/joho/godotenv"
"golang.design/x/clipboard"
)
var Error *log.Logger
var Warning *log.Logger
func init() {
log.SetFlags(log.Lmicroseconds | log.Lshortfile)
// logFile, err := os.Create("main.log")
// if err != nil {
// log.Printf("Error creating log file: %v", err)
// os.Exit(1)
// }
logger := io.MultiWriter(os.Stdout)
log.SetOutput(logger)
Error = log.New(io.MultiWriter(os.Stderr, os.Stdout),
fmt.Sprintf("%sERROR:%s ", "\033[0;101m", "\033[0m"),
log.Lmicroseconds|log.Lshortfile)
Warning = log.New(io.MultiWriter(os.Stdout),
fmt.Sprintf("%sWarning:%s ", "\033[0;93m", "\033[0m"),
log.Lmicroseconds|log.Lshortfile)
}
func main() {
envFilePath := flag.String("env", ".env", "Path to the .env file")
flag.Parse()
// if *envFilePath == "" {
// Error.Fatalf("Environment file path is required")
// return
// }
err := clipboard.Init()
if err != nil {
Error.Fatalf("Error initializing clipboard: %v", err)
return
}
env, err := os.ReadFile(*envFilePath)
if err != nil {
Warning.Fatalf("Error reading .env file: %v", err)
// return
}
envvar, err := godotenv.Parse(bytes.NewReader(env))
if err != nil {
Error.Fatalf("Error parsing .env file: %v", err)
return
}
username, ok := envvar["GITEA_USER"]
if !ok {
Error.Fatalf("GITEA_USER environment variable is required")
return
}
password, ok := envvar["GITEA_PASSWORD"]
if !ok {
Error.Fatalf("GITEA_PASSWORD environment variable is required")
return
}
url, ok := envvar["GITEA_URL"]
if !ok {
Error.Fatalf("GITEA_URL environment variable is required")
return
}
if username == "" || password == "" {
Error.Fatalf("GITEA_USER and GITEA_PASSWORD environment variables are required")
return
}
var name, remote string
var private, noinit, forceInit bool
flag.StringVar(&name, "name", "", "Name of the repository")
flag.StringVar(&name, "n", "", "Name of the repository (shorthand)")
flag.BoolVar(&private, "private", false, "Make the repository private")
flag.BoolVar(&private, "p", false, "Make the repository private (shorthand)")
flag.BoolVar(&noinit, "noinit", false, "Do not add remote to the new repo")
flag.BoolVar(&noinit, "ni", false, "Do not add remote to the new repo (shorthand)")
flag.BoolVar(&forceInit, "f", false, "Force assignment of the remote (deletes existing origin)")
flag.StringVar(&remote, "remote", "origin", "Name of the remote to create for the new repository")
flag.StringVar(&remote, "r", "origin", "Name of the remote to create for the new repository (shorthand)")
flag.Parse()
if len(flag.Args()) > 0 {
name = flag.Args()[0]
}
if name == "" {
Error.Fatalf("Repository name is required")
return
}
client, err := gitea.NewClient(url)
if err != nil {
Error.Fatalf("Error creating client: %v", err)
return
}
client.SetBasicAuth("dave", "D7u@NHh^9d33ue!xVAEu")
repo, _, err := client.GetRepo("dave", name)
if err == nil {
log.Printf("Repository already exists at:\n%s", repo.CloneURL)
clipboard.Write(clipboard.FmtText, []byte(repo.CloneURL))
} else {
repo, _, err = client.CreateRepo(gitea.CreateRepoOption{
Name: name,
Private: private,
DefaultBranch: "master",
})
if err != nil {
Error.Fatalf("Error creating repository: %v", err)
return
}
log.Printf("Repository created at:\n%s", repo.CloneURL)
clipboard.Write(clipboard.FmtText, []byte(repo.CloneURL))
}
if !noinit {
cwd, err := os.Getwd()
if err != nil {
Error.Fatalf("Error getting current working directory: %v", err)
return
}
cwd = path.Clean(cwd)
var localRepo *git.Repository
_, err = os.Stat(path.Join(cwd, ".git"))
if err == nil {
localRepo, err = git.PlainOpen(cwd)
if err != nil {
Error.Fatalf("Error opening git repository: %v", err)
return
}
} else {
localRepo, err = git.PlainInit(cwd, false)
if err != nil {
Error.Fatalf("Error initializing git repository: %v", err)
return
}
}
_, err = localRepo.Remote(remote)
if err == nil {
if forceInit {
err = localRepo.DeleteRemote(remote)
if err != nil {
Error.Fatalf("Error deleting remote %s from local repository: %v", remote, err)
return
}
} else {
Error.Fatalf("Remote %s already exists in local repository", remote)
return
}
}
_, err = localRepo.CreateRemote(&config.RemoteConfig{
Name: remote,
URLs: []string{repo.CloneURL},
})
if err != nil {
Error.Fatalf("Error adding remote %s to local repository: %v", remote, err)
return
}
log.Printf("Remote added to local repository")
}
}