Skip to content

Golang boilerplate to kickstart a new project

Notifications You must be signed in to change notification settings

feildrixliemdra/go-boilerplate

Repository files navigation

Go Boilerplate

A boilerplate for building Go applications quickly and effectively. This template provides a structured foundation with essential libraries, configurations, and setup to speed up your development process in Go.

Features

  • Modular Project Structure: Organized code to maintain readability and scalability.
  • Environment Management: .env configuration for managing environment variables.
  • Dependency Management: Uses Go Modules for easy dependency tracking.
  • Docker Support: Dockerized setup for easier deployment and consistency across environments.
  • Testing: Basic setup for unit testing.

Getting Started

Prerequisites

  • Go (version 1.16 or higher)
  • Docker (optional for containerization)
  • Make

Installation

  1. Clone the repo
     git clone https://github.com/feildrixliemdra/go-boilerplate.git
     cd go-boilerplate
  2. Install dependencies
    go mod tidy
  3. Set up environment variables:
     make env 
     or
     cp config/config.yaml.example config/config.yaml  #fill in necessary values. #fill in necessary values.
  4. Change git remote url to avoid accidental pushes to base project
    git remote set-url origin your_github_username/repo_name
    git remote -v # confirm the changes
  5. Run the application:
    go run main.go
    Or Using Docker
    docker-compose up --build
    Access the application at http://localhost:<your_port>.

Project Structure

.
├── cmd                # Main applications of the project
├── pkg                # Library code that's ok to use by external applications
├── internal           # Private application code (cannot be imported by other projects)
│   ├── config         # Application configuration and settings
│   ├── controllers    # Handle HTTP requests and responses, business logic for APIs
│   ├── models         # Data models representing entities, structs, and database schema
│   ├── repository     # Data access layer for managing database operations
│   ├── services       # Core business logic and reusable services for the application
│   ├── utils          # Utility functions and helper methods
│   └── middleware     # Custom middleware functions for handling requests and responses
├── configs            # Configuration files
├── scripts            # Scripts for various tasks
├── .env.example       # Environment variables example file
├── Dockerfile         # Docker configuration
├── docker-compose.yml # Docker Compose configuration
├── Makefile           # Automation commands
└── README.md

  • internal/config

    Contains configuration files and setup functions for initializing configurations. It typically reads from environment variables and .env files to set up values for application settings, database connections, and API configurations.

  • internal/controllers

    Contains handlers responsible for managing incoming HTTP requests and sending responses. Each controller usually corresponds to an endpoint or resource, delegating business logic to the appropriate services and handling the HTTP logic, such as parsing requests and formatting responses.

  • internal/services

    Contains the core business logic of the application, defining reusable services and application flows. Services here interact with repositories to retrieve or update data, applying business rules and validations before returning results.

  • internal/models

    Defines the data structures used across the application, representing entities like User, Product, or Order. These models often map directly to database tables and include struct tags to help with serialization, database ORM, or validation.

  • internal/repository

    Acts as the Data Access Layer (DAL), managing database operations like querying, creating, updating, and deleting records. This layer encapsulates all direct interactions with the database, often leveraging interfaces to support dependency injection for testing.

  • internal/utils

    Utility functions and helper methods that may not belong in any specific module. These could include functions for string manipulation, date formatting, error handling, or logging that are used throughout the application.

  • internal/config

    Contains configuration files and setup functions for initializing configurations. It typically reads from environment variables and .env files to set up values for application settings, database connections, and API configurations.

  • internal/middleware

    Defines custom middleware functions for intercepting and processing requests/responses, such as authentication, authorization, logging, error handling, and rate limiting. Middleware can enhance request handling by adding cross-cutting functionality across endpoints.

Running Tests

To run tests:

go test ./...

Roadmap

  • Setup base folder structure
  • Setup REST handler
  • Setup Request Payload Validator
  • Setup i8n response
  • Setup gRPC handler

Contact

Feildrix Liemdra - [email protected]

About

Golang boilerplate to kickstart a new project

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published