Skip to content

akimabs/belajar-go-rest-api

 
 

Repository files navigation

Belajar Go REST API

Belajar REST API dengan bahasa pemrograman Go.

Daftar Isi

Fitur

Projek ini sudah siap dijalankan dan dapat dimodifikasi sesuai kebutuhan masing-masing. Adapun kemampuan projek ini:

  1. Dapat menjadi backend dari REST API.
  2. Dapat menjadi service dalam rangkaian microservices.
  3. Dapat menyediakan dokumentasi API melalui Swagger.
  4. Support berbagai koneksi database, seperti MySQL, PostgreSQL, SQLite, dan SQL Server.
  5. Support migrasi database dalam bentuk file SQL.
  6. Support dependency injection.

Konsep Arsitektural

Struktur proyek ini mengikuti konsep-konsep arsitektural seperti:

  • DRY (Don't Repeat Yourself)
  • SOLID Principle
  • Clean Architecture

Stack Teknologi

Nama Kegunaan
Go Bahasa Pemrograman
Fiber Web Framework
PostgreSQL Database Management System
Gorm Object-Relational Mapper
Jwt Token untuk Otentikasi

Utilitas Pihak Ketiga

Nama Kegunaan
Validator Validasi data
Migrate Migrasi database
Swag Otomatis generate dokumentasi REST API (swagger)
GNU/Make Build tool

Menjalankan Projek

Persiapan

Agar projek dapat dijalankan, diperlukan beberapa hal untuk dipersiapkan, antara lain:

  1. Instalasi Fiber CLI.
go get -u github.com/gofiber/cli/fiber
  1. Instalasi Swaggo.
go get -u github.com/swaggo/swag/cmd/swag
  1. Instalasi Migrate. Ikuti panduan di sini.

  2. Menjalankan migration dengan menyesuaikan akses database.

migrate -path db/migrations -database "postgres://localhost/test_db?sslmode=disable" up

Mode Development

  1. Clone projek ke komputer lokal, dengan perintah:
git clone https://github.com/hadihammurabi/belajar-go-rest-api
  1. Menjalankan projek dengan mode development (pengembangan) dengan perintah:
make dev

Mode Production

  1. Clone projek ke komputer lokal, dengan perintah:
git clone https://github.com/hadihammurabi/belajar-go-rest-api
  1. Menjalankan projek siap guna dengan perintah:
make && ./main

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 96.9%
  • Dockerfile 1.3%
  • Makefile 1.3%
  • Shell 0.5%