Command-line tool to generate GO services, applications and libraries with reusable logic.
Please consider supporting this project by making a donation via PayPal
- category Tool
- author Nicola Asuni info@tecnick.com
- copyright 2014-2017 Nicola Asuni - Tecnick.com LTD
- license MIT (see LICENSE)
- link https://github.com/tecnickcom/gogen
This is a command-line tool to quickly generate GO services, applications and libraries with a common set of features and reusable logic.
Each GO project built with this tool adheres to the set of conventions detailed in the following articles:
- Software Naming
- Software Structure
- Software Versioning
- Software Configuration
- Software Logging Format
- Software Metrics
- Simple API JSON Response Format
- Software Automation
- Build Software with Docker
Each generated project is immediately functional and can be fully tested using the make qa
command.
To understand the logic of the generated applications please start with the main.go
file and follow the code.
This project includes a Makefile that allows you to test and build the project in a Linux-compatible system with simple commands.
All the artifacts and reports produced using this Makefile are stored in the target folder.
To see all available options:
make help
make new TYPE=app CONFIG=myproject.cfg
-
TYPE is the project type:
- lib : library
- app : command-line application
- srv : HTTP API service
-
CONFIG is the configuration file containing the project settings.
To create a new configuration please clone the default.cfg file and change the values.
All projects are creted inside the target directory and should be moved to the correct path inside the $GOPATH/src.
- Web HTTP RESTful JSON API;
- Standard command line options;
- Multiple configuration options, including remote configuration via Consul or Etcd;
- Logging;
- StatsD client to collect usage metrics;
- Unit tests;
- Makefile;
- Docker build;
- RPM, DEB and Docker packaging.
- Standard command line options;
- Multiple configuration options, including remote configuration via Consul or Etcd;
- Logging;
- Unit tests;
- Makefile;
- Docker build;
- RPM, DEB and Docker packaging.
- Unit tests;
- Makefile;
- Docker build;