package main import ( _ "embed" "flag" "fmt" "io" "log" "os" "strings" "code.gitea.io/sdk/gitea" "github.com/joho/godotenv" "golang.design/x/clipboard" ) var Error *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, logFile) log.SetOutput(logger) Error = log.New(io.MultiWriter(logFile, os.Stderr, os.Stdout), fmt.Sprintf("%sERROR:%s ", "\033[0;101m", "\033[0m"), log.Lmicroseconds|log.Lshortfile) } //go:embed .env var env string func main() { err := clipboard.Init() if err != nil { Error.Fatalf("Error initializing clipboard: %v", err) os.Exit(1) } envvar, err := godotenv.Parse(strings.NewReader(env)) if err != nil { Error.Fatalf("Error parsing .env file: %v", err) os.Exit(1) } username, ok := envvar["GITEA_USER"] if !ok { Error.Fatalf("GITEA_USER environment variable is required") os.Exit(1) } password, ok := envvar["GITEA_PASSWORD"] if !ok { Error.Fatalf("GITEA_PASSWORD environment variable is required") os.Exit(1) } if username == "" || password == "" { Error.Fatalf("GITEA_USER and GITEA_PASSWORD environment variables are required") os.Exit(1) } var name string var private 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.Parse() if len(flag.Args()) > 0 { name = flag.Args()[0] } if name == "" { Error.Fatalf("Repository name is required") os.Exit(1) } client, err := gitea.NewClient("https://git.site.quack-lab.dev/") if err != nil { Error.Fatalf("Error creating client: %v", err) os.Exit(1) } client.SetBasicAuth("dave", "D7u@NHh^9d33ue!xVAEu") repo, _, err := client.CreateRepo(gitea.CreateRepoOption{ Name: name, Private: private, DefaultBranch: "master", }) if err != nil { Error.Fatalf("Error creating repository: %v", err) os.Exit(1) } log.Printf("Repository created at:\n%s", repo.CloneURL) clipboard.Write(clipboard.FmtText, []byte(repo.CloneURL)) }