2015-01-05 00:18:41 -08:00
|
|
|
package authboss
|
|
|
|
|
|
|
|
var modules = make(map[string]Modularizer)
|
|
|
|
|
2015-03-15 08:31:48 -07:00
|
|
|
// ModuleAttributes is the list of attributes required by all the loaded modules.
|
|
|
|
// Authboss implementers can use this at runtime to determine what data is necessary
|
|
|
|
// to store.
|
|
|
|
var ModuleAttributes = make(AttributeMeta)
|
2015-01-15 02:56:13 -08:00
|
|
|
|
2015-01-10 22:52:39 -08:00
|
|
|
// Modularizer should be implemented by all the authboss modules.
|
2015-01-05 00:18:41 -08:00
|
|
|
type Modularizer interface {
|
2015-02-15 20:07:36 -08:00
|
|
|
Initialize() error
|
2015-01-05 00:18:41 -08:00
|
|
|
Routes() RouteTable
|
|
|
|
Storage() StorageOptions
|
|
|
|
}
|
|
|
|
|
|
|
|
// RegisterModule with the core providing all the necessary information to
|
|
|
|
// integrate into authboss.
|
|
|
|
func RegisterModule(name string, m Modularizer) {
|
|
|
|
modules[name] = m
|
2015-01-15 02:56:13 -08:00
|
|
|
|
|
|
|
for k, v := range m.Storage() {
|
2015-03-15 08:31:48 -07:00
|
|
|
ModuleAttributes[k] = v
|
2015-01-15 02:56:13 -08:00
|
|
|
}
|
2015-01-05 00:18:41 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// LoadedModules returns a list of modules that are currently loaded.
|
|
|
|
func LoadedModules() []string {
|
|
|
|
mods := make([]string, len(modules))
|
|
|
|
i := 0
|
2015-03-16 14:42:45 -07:00
|
|
|
for k := range modules {
|
2015-01-05 00:18:41 -08:00
|
|
|
mods[i] = k
|
|
|
|
i++
|
|
|
|
}
|
|
|
|
|
|
|
|
return mods
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsLoaded checks if a specific module is loaded.
|
|
|
|
func IsLoaded(mod string) bool {
|
|
|
|
_, ok := modules[mod]
|
|
|
|
return ok
|
|
|
|
}
|