package main import ( "flag" "fmt" "io" "log" "os" "code.gitea.io/sdk/gitea" "github.com/joho/godotenv" ) 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) } func main() { godotenv.Load() username := os.Getenv("GITEA_USER") password := os.Getenv("GITEA_PASSWORD") 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) }