hiboot

module
v0.8.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 30, 2018 License: Apache-2.0

README

Hiboot - web/cli application framework

hiboot

Build Status

About

Hiboot is a cloud native web and cli application framework written in Go.

Hiboot is not trying to reinvent everything, it integrates the popular libraries but make them simpler, easier to use. It borrowed some of the Spring features like dependency injection, aspect oriented programming, and auto configuration. You can integrate any other libraries easily by auto configuration with dependency injection support.

If you are a Java developer, you can start coding in Go without learning curve.

Overview

  • Web MVC (Model-View-Controller).
  • Auto Configuration, pre-create instance with properties configs for dependency injection.
  • Dependency injection with struct tag name `inject:""` or Constructor func.

Features

  • Apps

    • cli - command line application
    • web - web application
  • Starters

    • actuator - health check
    • locale - locale starter
    • logging - customized logging settings
    • jwt - jwt starter
    • grpc - grpc application starter
  • Tags

    • inject - inject generic instance into object
    • default - inject default value into struct object
    • value - inject string value or references / variables into struct string field
    • cmd - inject command into parent command for cli application
    • flag - inject flag / options into command object
  • Utils

    • cmap - concurrent map
    • copier - copy between struct
    • crypto - aes, base64, md5, and rsa encryption / decryption
    • gotest - go test util
    • idgen - twitter snowflake id generator
    • io - file io util
    • mapstruct - convert map to struct
    • replacer - replacing stuct field value with references or environment variables
    • sort - sort slice elements
    • str - string util enhancement util
    • validator - struct field validation

and more features on the wey ...

Getting started

This section will show you how to create and run a simplest hiboot application. Let’s get started!

Getting started with Hiboot web application
Get the source code
go get -u github.com/hidevopsio/hiboot

cd $GOPATH/src/github.com/hidevopsio/hiboot/examples/web/helloworld/


Sample code

Below is the simplest web application in Go.

// Line 1: main package
package main

// Line 2: import web starter from hiboot
import "github.com/hidevopsio/hiboot/pkg/app/web"

// Line 3-5: RESTful Controller, derived from web.Controller. The context mapping of this controller is '/' by default
type Controller struct {
	web.Controller
}

// Line 6-8: Get method, the context mapping of this method is '/' by default
// the Method name Get means that the http request method is GET
func (c *Controller) Get() string {
	// response data
	return "Hello world"
}

// Line 9-11: main function
func main() {
	// create new web application and run it
	web.NewApplication(&Controller{}).Run()
}
Run web application
dep ensure

go run main.go
Testing the API by curl
curl http://localhost:8080/
Hello, world
Getting started with Hiboot cli application

Writing Hiboot cli application is as simple as web application, you can take the advantage of dependency injection introduced by Hiboot.

e.g. flag tag dependency injection


// declare main package
package main

// import cli starter and fmt
import "github.com/hidevopsio/hiboot/pkg/app/cli"
import "fmt"

// define the command
type HelloCommand struct {
	// embedding cli.BaseCommand in each command
	cli.BaseCommand
	// inject (bind) flag to field 'To', so that it can be used on Run method, please note that the data type must be pointer
	To *string `flag:"name=to,shorthand=t,value=world,usage=e.g. --to=world or -t world"`
}

// Init constructor
func (c *HelloCommand) Init() {
	c.Use = "hello"
	c.Short = "hello command"
	c.Long = "run hello command for getting started"
}

// Run run the command
func (c *HelloCommand) Run(args []string) error {
	fmt.Printf("Hello, %v\n", *c.To)
	return nil
}

// main function
func main() {
	// create new cli application and run it
	cli.NewApplication(new(HelloCommand)).Run()
}

Run cli application
dep ensure

go run main.go
Hello, world
Build the cli application and run
go build

Let's get help

./hello --help
run hello command for getting started

Usage:
  hello [flags]

Flags:
  -h, --help        help for hello
  -t, --to string   e.g. --to=world or -t world (default "world")

Greeting to Hiboot

./hello --to Hiboot
Hello, Hiboot
Dependency injection in Go

Dependency injection is a concept valid for any programming language. The general concept behind dependency injection is called Inversion of Control. According to this concept a struct should not configure its dependencies statically but should be configured from the outside.

Dependency Injection design pattern allows us to remove the hard-coded dependencies and make our application loosely coupled, extendable and maintainable.

A Go struct has a dependency on another struct, if it uses an instance of this struct. We call this a struct dependency. For example, a struct which accesses a user controller has a dependency on user service struct.

Ideally Go struct should be as independent as possible from other Go struct. This increases the possibility of reusing these struct and to be able to test them independently from other struct.

The following example shows a struct which has no hard dependencies.

package main

import (
    "github.com/hidevopsio/hiboot/pkg/app/web"
    "github.com/hidevopsio/hiboot/pkg/model"
    "github.com/hidevopsio/hiboot/pkg/starter/jwt"
    "time"
)

// This example shows that jwtToken is injected through method Init,
// once you imported "github.com/hidevopsio/hiboot/pkg/starter/jwt",
// jwtToken jwt.Token will be injectable.
func main() {}

// PATH: /login
type loginController struct {
    web.Controller

    jwtToken jwt.Token
}

type userRequest struct {
    // embedded field model.RequestBody mark that userRequest is request body
    model.RequestBody
    Username string `json:"username" validate:"required"`
    Password string `json:"password" validate:"required"`
}

func init() {
    // Register Rest Controller through constructor newLoginController
    web.RestController(newLoginController)
}

// Init inject jwtToken through the argument jwtToken jwt.Token on constructor
func newLoginController(jwtToken jwt.Token) *loginController {
    return &loginController{
        jwtToken: jwtToken,
    }
}

// Post /
// The first word of method is the http method POST, the rest is the context mapping
func (c *loginController) Post(request *userRequest) (response model.Response, err error) {
    jwtToken, _ := c.jwtToken.Generate(jwt.Map{
        "username": request.Username,
        "password": request.Password,
    }, 30, time.Minute)

    response = new(model.BaseResponse)
    response.SetData(jwtToken)

    return
}

Development Guide

Git workflow

Below, we outline one of the more common Git workflows that core developers use. Other Git workflows are also valid.

Fork the main repository
Clone your fork

The commands below require that you have $GOPATH set ($GOPATH docs). We highly recommend you put Istio's code into your GOPATH. Note: the commands below will not work if there is more than one directory in your $GOPATH.

export GITHUB_USER=your-github-username
mkdir -p $GOPATH/src/github.com/hidevopsio
cd $GOPATH/src/github.com/hidevopsio
git clone https://github.com/$GITHUB_USER/hiboot
cd hiboot
git remote add upstream 'https://github.com/hidevopsio/hiboot'
git config --global --add http.followRedirects 1
Create a branch and make changes
git checkout -b my-feature
# Then make your code changes
Keeping your fork in sync
git fetch upstream
git rebase upstream/master

Note: If you have write access to the main repositories (e.g. github.com/hidevopsio/hiboot), you should modify your Git configuration so that you can't accidentally push to upstream:

Directories

Path Synopsis
examples
cli
Package cli provides hiboot command line application examples
Package cli provides hiboot command line application examples
grpc
Package grpc provides hiboot web application service examples that communicate with gRpc protocol
Package grpc provides hiboot web application service examples that communicate with gRpc protocol
web
Package web provides hiboot web application examples
Package web provides hiboot web application examples
web/helloworld
Package helloworld provides the quick start web application example
Package helloworld provides the quick start web application example
pkg
app
Package app provides abstract layer for cli/web application Package app provides hiboot app application interface
Package app provides abstract layer for cli/web application Package app provides hiboot app application interface
app/cli
Package cli provides quick start framework for command line application.
Package cli provides quick start framework for command line application.
app/fake
Package fake provides fake.ApplicationContext for unit testing
Package fake provides fake.ApplicationContext for unit testing
app/web
Package web provides quick start framework for web application.
Package web provides quick start framework for web application.
factory
Package factory provides hiboot factory interface Package factory provides InstantiateFactory and ConfigurableFactory interface
Package factory provides hiboot factory interface Package factory provides InstantiateFactory and ConfigurableFactory interface
factory/autoconfigure
Package autoconfigure implement ConfigurableFactory
Package autoconfigure implement ConfigurableFactory
factory/instantiate
Package instantiate implement InstantiateFactory
Package instantiate implement InstantiateFactory
inject
Package inject implements dependency injection.
Package inject implements dependency injection.
log
Package log provides logging with level debug, info, warn, error, fatal.
Package log provides logging with level debug, info, warn, error, fatal.
model
Package model provides common request and response models.
Package model provides common request and response models.
starter
Package starter provides quick starters for hiboot cli/web application Auto-configured Starter Hiboot auto-configuration attempts to automatically configure your Hiboot application based on the pkg dependencies that you have added.
Package starter provides quick starters for hiboot cli/web application Auto-configured Starter Hiboot auto-configuration attempts to automatically configure your Hiboot application based on the pkg dependencies that you have added.
system
Package system provides system builder which response for properties dependency injection.
Package system provides system builder which response for properties dependency injection.
utils
Package utils provides useful utilities
Package utils provides useful utilities

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL