Skip to content

Latest commit

 

History

History
228 lines (171 loc) · 5.03 KB

README.md

File metadata and controls

228 lines (171 loc) · 5.03 KB

go-commons

go-commons is a versatile collection of utility packages that simplify common tasks related to Cli,Git and GitHub.

For examples check the examples directory.

Features

CLI Commands

Easily create CLI commands with Cobra to perform common tasks.

GitHub API Integration

Easily interact with GitHub using the go-github library. Key features include:

  • Listing user organizations and repositories.
  • Checking rate limits.
  • Managing authentication via tokens or SSH keys.

Git Operations

Streamline Git-related tasks with go-git, including:

  • Cloning repositories.
  • Updating local repositories.
  • Supporting both HTTPS and SSH protocols for authentication.

Utility Functions

  • Directory management: Check for existence and create directories if necessary.
  • Environment variable handling: Fetch variables with default fallback options.

Installation

To add go-commons to your project, run:

go get -u github.com/cloudnative-zoo/go-commons

Usage

CLI Command Example

package main

import (
   "fmt"
   "github.com/spf13/cobra"
   "github.com/cloudnative-zoo/go-commons/cli"
)

func main() {
   rootCmd := cli.NewCommand(cli.CommandConfig{
      Use:   "app",
      Short: "A sample CLI app",
      Long:  "This is a sample CLI app demonstrating the usage of the NewCommand function",
      Run: func(cmd *cobra.Command, args []string) {
         fmt.Println("App executed!")
      },
      Flags: []cli.FlagConfig{
         {
            Name:         "name",
            Short:        "n",
            DefaultValue: "World",
            Usage:        "Specify the name",
            Required:     false,
         },
         {
            Name:         "verbose",
            Short:        "v",
            DefaultValue: false,
            Usage:        "Enable verbose mode",
            Required:     false,
         },
      },
   })

   if err := rootCmd.Execute(); err != nil {
      fmt.Println(err)
   }
}

GitHub API Service Example

package main

import (
    "context"
    "log/slog"

    "github.com/cloudnative-zoo/go-commons/github"
)

func main() {
    ctx := context.Background()

    githubService, err := github.New(
        github.WithToken("your_github_token"),
    )
    if err != nil {
        slog.With("error", err).Error("Failed to initialize GitHub service")
        return
    }

    orgs, err := githubService.ListOrganizations(ctx)
    if err != nil {
        slog.With("error", err).Error("Failed to list organizations")
        return
    }

    slog.With("organizations", orgs).Info("Retrieved organizations")
}

Git Service Example

package main

import (
    "context"
    "log/slog"

    "github.com/cloudnative-zoo/go-commons/git"
)

func main() {
    ctx := context.Background()

    gitService, err := git.New(
        git.WithSSHKeyPath("/path/to/ssh/key", ""),
        git.WithRepoPath("/path/to/local/repo"),
        git.WithURL("[email protected]:user/repo.git"),
    )
    if err != nil {
        slog.With("error", err).Error("Failed to initialize Git service")
        return
    }

    err = gitService.CloneOrPull(ctx)
    if err != nil {
        slog.With("error", err).Error("Failed to clone or pull repository")
        return
    }

    slog.Info("Repository synchronized successfully")
}

Development

Prerequisites

Configuration

Taskfile

A Taskfile.yaml is included to streamline common development tasks:

  • Pre-commit checks
  • Updating Go modules
  • Formatting code
  • Running go vet
  • Running golangci-lint

Pre-commit Hooks

The .pre-commit-config.yaml file configures hooks for:

  • Sensitive data detection: gitleaks
  • Formatting tools: End-of-file fixer, trailing whitespace remover, JSON formatter
  • Linting tools: golangci-lint, gofmt, goimports
  • Spelling and syntax checks

Contributing

We welcome contributions! Follow these steps:

  1. Fork the repository.
  2. Create a new branch:
    git checkout -b feature-branch
  3. Make your changes.
  4. Commit your changes:
    git commit -am 'Add new feature'
  5. Push to the branch:
    git push origin feature-branch
  6. Open a pull request.

License

This project is licensed under the MIT License. See the LICENSE file for details.


Acknowledgements

We are grateful for the following libraries and tools that power this project:


Contact

For questions, suggestions, or feedback, please open an issue on the GitHub repository.


Authors