Chaki is an application builder framework designed to simplify the development process in Go by abstracting processes such as tracing, logging, Kafka integration, and Swagger documentation. It reduces the amount of boilerplate code, enhancing developer experience and productivity. Chaki handles complex tasks for you, allowing you to focus more on the core functionalities of your application.
Using Chaki, you can:
A simple usage example is provided below. For more detailed examples, please refer to the examples directory.
func main() {
// create instance
app := chaki.New()
// add modules
app.Use(
foomodule.Module(),
)
// provide constructors
app.Provide(
NewFooRepository,
NewFooService,
NewBarClient,
NewFooController,
NewFooCreatedConsumer,
// or you can just provide an already created instance
chaki.Valuer(barRepositoryInstance),
)
// start application
if err := app.Start(); err != nil {
logger.Fatal(err)
}
}
Chaki is fundamentally based on the uber-go/fx
dependency injection system and includes additional features such as a module system. This framework, built on a simple foundation, derives much of its power from its modules.
app.Use
.*gorm.Gorm
or sarama.SyncProducer
, in any constructor you want.