cli/pkg/runtime/runtime.go
Snider 623f05ffc1 refactor: Remove pkg/help (#25)
The help package has been moved to its own repository at Snider/help. This commit removes the local copy of the package from this repository and updates the dependencies.

Co-authored-by: google-labs-jules[bot] <161369871+google-labs-jules[bot]@users.noreply.github.com>
2025-11-13 14:28:41 +00:00

118 lines
3.4 KiB
Go

package runtime
import (
"context"
"fmt"
"github.com/Snider/Core/pkg/config"
"github.com/Snider/Core/pkg/core"
"github.com/Snider/Core/pkg/crypt"
"github.com/Snider/Core/pkg/display"
"github.com/Snider/Core/pkg/i18n"
"github.com/Snider/Core/pkg/workspace"
"github.com/wailsapp/wails/v3/pkg/application"
)
// Runtime is the container that holds all instantiated services.
// Its fields are the concrete types, allowing Wails to bind them directly.
type Runtime struct {
app *application.App
Core *core.Core
Config *config.Service
Display *display.Service
Crypt *crypt.Service
I18n *i18n.Service
Workspace *workspace.Service
}
// ServiceFactory defines a function that creates a service instance.
type ServiceFactory func() (any, error)
// NewWithFactories creates a new Runtime instance using the provided service factories.
func NewWithFactories(app *application.App, factories map[string]ServiceFactory) (*Runtime, error) {
services := make(map[string]any)
coreOpts := []core.Option{
core.WithWails(app),
}
for _, name := range []string{"config", "display", "crypt", "i18n", "workspace"} {
factory, ok := factories[name]
if !ok {
return nil, fmt.Errorf("service %s factory not provided", name)
}
svc, err := factory()
if err != nil {
return nil, fmt.Errorf("failed to create service %s: %w", name, err)
}
services[name] = svc
svcCopy := svc
coreOpts = append(coreOpts, core.WithName(name, func(c *core.Core) (any, error) { return svcCopy, nil }))
}
coreInstance, err := core.New(coreOpts...)
if err != nil {
return nil, err
}
// --- Type Assertions ---
configSvc, ok := services["config"].(*config.Service)
if !ok {
return nil, fmt.Errorf("config service has unexpected type")
}
displaySvc, ok := services["display"].(*display.Service)
if !ok {
return nil, fmt.Errorf("display service has unexpected type")
}
cryptSvc, ok := services["crypt"].(*crypt.Service)
if !ok {
return nil, fmt.Errorf("crypt service has unexpected type")
}
i18nSvc, ok := services["i18n"].(*i18n.Service)
if !ok {
return nil, fmt.Errorf("i18n service has unexpected type")
}
workspaceSvc, ok := services["workspace"].(*workspace.Service)
if !ok {
return nil, fmt.Errorf("workspace service has unexpected type")
}
rt := &Runtime{
app: app,
Core: coreInstance,
Config: configSvc,
Display: displaySvc,
Crypt: cryptSvc,
I18n: i18nSvc,
Workspace: workspaceSvc,
}
return rt, nil
}
// New creates and wires together all application services.
func New(app *application.App) (*Runtime, error) {
return NewWithFactories(app, map[string]ServiceFactory{
"config": func() (any, error) { return config.New() },
"display": func() (any, error) { return display.New() },
"crypt": func() (any, error) { return crypt.New() },
"i18n": func() (any, error) { return i18n.New() },
"workspace": func() (any, error) { return workspace.New() },
})
}
// ServiceName returns the name of the service. This is used by Wails to identify the service.
func (r *Runtime) ServiceName() string {
return "Core"
}
// ServiceStartup is called by Wails at application startup.
func (r *Runtime) ServiceStartup(ctx context.Context, options application.ServiceOptions) {
r.Core.ServiceStartup(ctx, options)
}
// ServiceShutdown is called by Wails at application shutdown.
func (r *Runtime) ServiceShutdown(ctx context.Context) {
if r.Core != nil {
r.Core.ServiceShutdown(ctx)
}
}