Product Promotion
0x5a.live
for different kinds of informations and explorations.
GitHub - Fs02/wire: Strict Runtime Dependency Injection for Golang
Strict Runtime Dependency Injection for Golang. Contribute to Fs02/wire development by creating an account on GitHub.
Visit SiteGitHub - Fs02/wire: Strict Runtime Dependency Injection for Golang
Strict Runtime Dependency Injection for Golang. Contribute to Fs02/wire development by creating an account on GitHub.
Powered by 0x5a.live ๐
wire
Wire is runtime depedency injection/wiring for golang. It's designed to be strict to avoid your go application running without proper dependency injected.
Features:
- Strictly validates dependency and prevents missing or ambiguous dependency.
- Check againts possible forgotten
wire
tag. - Easily connect and resolve object anywhere.
- Annotates ambiguous interface type using connection name or implementation name.
Install
go get github.com/Fs02/wire
Example
package wire_test
import (
"fmt"
"github.com/Fs02/wire"
)
type Listener struct{}
func (listener Listener) Next() string {
return "system"
}
type Printer interface {
Exec(string) error
}
type SystemPrint struct {
App string `wire:""`
}
func (systemPrint SystemPrint) Exec(msg string) error {
fmt.Println("[" + systemPrint.App + "] System: " + msg)
return nil
}
type UserPrint struct {
App string `wire:""`
Target string
}
func (userPrint UserPrint) Exec(msg string) error {
fmt.Println("[" + userPrint.App + "]" + userPrint.Target + ": " + msg)
return nil
}
type Service struct {
// Each of `wire`` tag below indicate fields to be wired with apporpriate component.
// value inside `wire` tag indicate the name of the component and optionally it's type.
// `wire` with empty value will be wired with default value (named using empty string).
// Ambiguous field can be resolved by adding it's type, name or both (separated using comma) to the `wire` tag.
// Don't worry if you forgot to add wire tag to an interface or a pointer, wire will warn you if any nil field are found.
// To ignore wiring on specific field, you can use add `wire:"-"`.
Listener Listener `wire:""`
SystemPrint Printer `wire:",SystemPrint"`
FooUserPrint Printer `wire:"foo"`
BooUserPrint Printer `wire:"boo,UserPrint"`
}
func (service Service) Update() error {
switch service.Listener.Next() {
case "system":
return service.SystemPrint.Exec("hello from system")
case "user-foo":
return service.FooUserPrint.Exec("hello from foo")
case "user-boo":
return service.BooUserPrint.Exec("hello from boo")
default:
return nil
}
}
func init() {
// add components to be wired by the library.
// wire all components only once and as early as possible.
wire.Connect("CoolApp")
wire.Connect(Listener{}) // we don't need to pass by reference here, since it doesn't require any wiring.
wire.Connect(&SystemPrint{}) // we need to pass by reference it to allow wiring, wire will panic if we pass by value.
wire.Connect(&UserPrint{Target: "foo"}, "foo") // wire a UserPrint named by "foo".
wire.Connect(&UserPrint{Target: "boo"}, "boo") // wire a UserPrint named by "boo", wire will panic if there's duplicate components detected.
wire.Connect(&Service{})
// Apply wiring
wire.Apply()
}
func Example() {
// Resolve a service component to be used later.
var service Service
wire.Resolve(&service)
service.Update()
// Output: [CoolApp] System: hello from system
}
License
Released under the MIT License
GoLang Resources
are all listed below.
GitHub - GuilhermeCaruso/anko: :crystal_ball: Simple application watcher
resource
~/github.com
resource
GitHub - jidicula/go-fuzz-action: GitHub Action for Go 1.18 fuzz testing
resource
~/github.com
resource
GitHub - tucnak/climax: Climax is an alternative CLI with the human face
resource
~/github.com
resource
GitHub - lawrencewoodman/roveralls: A Go recursive coverage testing tool
resource
~/github.com
resource
GitHub - nakagami/firebirdsql: Firebird RDBMS sql driver for Go (golang)
resource
~/github.com
resource
GitHub - liweiyi88/onedump: Effortlessly database dump with one command.
resource
~/github.com
resource
GitHub - beefsack/go-astar: Go implementation of the A* search algorithm
resource
~/github.com
resource
GitHub - lxn/walk: A Windows GUI toolkit for the Go Programming Language
resource
~/github.com
resource
GitHub - mongodb/mongo-go-driver: The Official Golang driver for MongoDB
resource
~/github.com
resource
GitHub - bykof/gostradamus: Gostradamus: Better DateTimes for Go ๐ฐ๏ธ
resource
~/github.com
resource
GitHub - mozillazg/go-unidecode: ASCII transliterations of Unicode text.
resource
~/github.com
resource
GitHub - bolknote/go-gd: Go bingings for GD (http://www.boutell.com/gd/)
resource
~/github.com
resource
GitHub - mosajjal/dnsmonster: Passive DNS Capture and Monitoring Toolkit
resource
~/github.com
resource
GitHub - haxpax/gosms: :mailbox_closed: Your own local SMS gateway in Go
resource
~/github.com
resource
GitHub - wajox/gobase: This is a simple skeleton for golang applications
resource
~/github.com
resource
GitHub - VividCortex/gohistogram: Streaming approximate histograms in Go
resource
~/github.com
resource
GitHub - malaschitz/randomForest: Random Forest implementation in golang
resource
~/github.com
resource
GitHub - google/gopacket: Provides packet processing capabilities for Go
resource
~/github.com
resource
GitHub - khezen/evoli: Genetic Algorithm and Particle Swarm Optimization
resource
~/github.com
resource
GitHub - didip/tollbooth: Simple middleware to rate-limit HTTP requests.
resource
~/github.com
resource
GitHub - mustafaakin/gongular: A different approach to Go web frameworks
resource
~/github.com
resource
GitHub - songgao/colorgo: Colorize (highlight) `go build` command output
resource
~/github.com
resource
Made with โค๏ธ
to provide different kinds of informations and resources.