-
-
Notifications
You must be signed in to change notification settings - Fork 72
/
Copy pathcomponent.go
83 lines (70 loc) · 2.21 KB
/
component.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package goyave
import (
"gorm.io/gorm"
"goyave.dev/goyave/v5/config"
"goyave.dev/goyave/v5/lang"
"goyave.dev/goyave/v5/slog"
)
// Composable defines all the functions every component of the presentation
// layer (HTTP/REST) of your application must implement. These functions are
// accessors to the essential server resources.
// A component can be parent of several sub-components.
type Composable interface {
Init(server *Server)
Server() *Server
DB() *gorm.DB
Config() *config.Config
Lang() *lang.Languages
Logger() *slog.Logger
Service(name string) Service
LookupService(name string) (Service, bool)
}
// Registrer qualifies a controller that registers its routes itself.
// It is required for controllers to implement this interface if you want
// to use `router.Controller()`.
type Registrer interface {
Composable
RegisterRoutes(router *Router)
}
// Component base implementation of `Composable` to easily make a
// custom component using structure composition.
type Component struct {
server *Server
}
var _ Composable = (*Component)(nil)
// Init the component using the given server.
func (c *Component) Init(server *Server) {
c.server = server
}
// Server returns the parent server.
func (c *Component) Server() *Server {
return c.server
}
// Service returns the service identified by the given name.
// Panics if no service could be found with the given name.
func (c *Component) Service(name string) Service {
return c.server.Service(name)
}
// LookupService search for a service by its name. If the service
// identified by the given name exists, it is returned with the `true` boolean.
// Otherwise returns `nil` and `false`.
func (c *Component) LookupService(name string) (Service, bool) {
return c.server.LookupService(name)
}
// Logger returns the server's logger.
func (c *Component) Logger() *slog.Logger {
return c.server.Logger
}
// DB returns the root database instance. Panics if no
// database connection is set up.
func (c *Component) DB() *gorm.DB {
return c.server.DB()
}
// Config returns the server's config.
func (c *Component) Config() *config.Config {
return c.server.Config()
}
// Lang returns the languages loaded by the server.
func (c *Component) Lang() *lang.Languages {
return c.server.Lang
}