From 28a6e1d0aea5b1a0121234db690e1b39a5722106 Mon Sep 17 00:00:00 2001 From: Sven Walter Date: Fri, 15 Nov 2024 08:58:42 +0100 Subject: [PATCH] add migration M0007 for adding dependency injection --- migrations.md | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/migrations.md b/migrations.md index b2c1e04..9db1f1e 100644 --- a/migrations.md +++ b/migrations.md @@ -3,6 +3,43 @@ This file contains a list of tasks that are either required or at least strongly recommended to align projects using this SDK. +## M0007 2024-11-08 Switch to Dependency Injection + +### Reasoning + +Our previous approach to have a single `Server` struct and to put all logic there gets messy pretty fast. Worse than +that it is hard to refactor this to separate this into multiple structs or packages. Dependency injection will help us +to separate those things in the very beginning of a project without manual wiring of dependencies. + +### Hints + +* The primary server.Run function should be replaced with a standalone `RunServer(ctx context.Context, c *dig.Container) error` +* The `cmdutil.Runner` should setup environment specific dependencies (eg Redis vs Miniredis) while `RunServer` should + setup the independent ones (eg services, workers and handlers). + +### Examples + +The `RunServer` function could look like this: + +```go +func RunServer(ctx context.Context, c *dig.Container) error { + return errors.Join( + // define services and repos + c.Provide(...), + + // define HTTP handlers + webutil.ProvideHandler(c, handlers.New...), + + // define workers + runutil.ProvideWorker(c, workers.New...), + + // start all workers + runutil.RunProvidedWorkers(ctx, c), + ) +} +``` + + ## M0006 2024-09-20 Use webutil.NewServer ### Reasoning