-
Notifications
You must be signed in to change notification settings - Fork 4
/
init.go
68 lines (60 loc) · 1.72 KB
/
init.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
package controller
import (
"context"
"strings"
"sync"
"github.com/pkg/errors"
"github.com/samber/lo"
"projectforge.dev/projectforge/app"
"projectforge.dev/projectforge/app/controller/cutil"
"projectforge.dev/projectforge/app/project"
"projectforge.dev/projectforge/app/util"
)
var allowedRoutes = []string{"/about", "/admin", "/testbed", "/welcome"}
func initApp(_ context.Context, _ *app.State, _ util.Logger) error {
return nil
}
func initAppRequest(as *app.State, ps *cutil.PageState) error {
if err := initProjects(ps.Context, as, ps.Logger); err != nil {
return errors.Wrap(err, "unable to initialize projects")
}
root := as.Services.Projects.Default()
if root.Info == nil {
allowed := lo.ContainsBy(allowedRoutes, func(r string) bool {
return strings.HasSuffix(ps.URI.Path, r)
})
if !allowed {
ps.ForceRedirect = "/welcome"
}
}
return nil
}
var initProjectsMu = sync.Mutex{}
func initProjects(ctx context.Context, as *app.State, logger util.Logger) error {
initProjectsMu.Lock()
defer initProjectsMu.Unlock()
prjs, err := as.Services.Projects.Refresh(logger)
if err != nil {
return errors.Wrap(err, "can't load projects")
}
for _, prj := range prjs {
var mods project.ModuleDefs
if prj.Info != nil {
mods = prj.Info.ModuleDefs
}
var keys []string
for _, mod := range mods {
k, err := as.Services.Modules.Register(ctx, prj.Path, mod.Key, mod.Path, mod.URL, logger)
if err != nil {
return errors.Wrapf(err, "unable to register module definition for module [%s]", mod.Key)
}
keys = append(keys, k...)
}
if len(keys) > 0 {
if len(keys) != 1 && keys[0] != "*" {
logger.Debugf("Loaded modules for [%s]: %s", prj.Key, strings.Join(keys, ", "))
}
}
}
return nil
}