opensaps/context/context.go

111 lines
3.5 KiB
Go
Raw Normal View History

// OpenSAPS - Open Slack API server for everyone.
//
// Copyright (c) 2017, Stanislav N. aka pztrn.
// All rights reserved.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
package context
import (
2017-10-31 22:50:14 +05:00
// stdlib
"os"
"strings"
// local
configurationinterface "go.dev.pztrn.name/opensaps/config/interface"
parserinterface "go.dev.pztrn.name/opensaps/parsers/interface"
pusherinterface "go.dev.pztrn.name/opensaps/pushers/interface"
slackapiserverinterface "go.dev.pztrn.name/opensaps/slack/apiserverinterface"
slackmessage "go.dev.pztrn.name/opensaps/slack/message"
2017-10-31 22:50:14 +05:00
// other
"github.com/pztrn/mogrus"
"go.dev.pztrn.name/flagger"
)
type Context struct {
2017-10-31 22:50:14 +05:00
Config configurationinterface.ConfigurationInterface
Flagger *flagger.Flagger
Log *mogrus.LoggerHandler
Parsers map[string]parserinterface.ParserInterface
Pushers map[string]pusherinterface.PusherInterface
SlackAPIServer slackapiserverinterface.SlackAPIServerInterface
}
func (c *Context) Initialize() {
2017-10-31 22:50:14 +05:00
c.Parsers = make(map[string]parserinterface.ParserInterface)
c.Pushers = make(map[string]pusherinterface.PusherInterface)
2017-10-31 22:50:14 +05:00
l := mogrus.New()
l.Initialize()
c.Log = l.CreateLogger("opensaps")
c.Log.CreateOutput("stdout", os.Stdout, true, "debug")
c.Flagger = flagger.New("opensaps", flagger.LoggerInterface(c.Log))
2017-10-31 22:50:14 +05:00
c.Flagger.Initialize()
}
// Registers configuration interface.
func (c *Context) RegisterConfigurationInterface(ci configurationinterface.ConfigurationInterface) {
2017-10-31 22:50:14 +05:00
c.Config = ci
c.Config.Initialize()
}
// Registers parser interface.
func (c *Context) RegisterParserInterface(name string, iface parserinterface.ParserInterface) {
2017-10-31 22:50:14 +05:00
c.Parsers[name] = iface
c.Parsers[name].Initialize()
}
// Registers Pusher interface.
func (c *Context) RegisterPusherInterface(name string, iface pusherinterface.PusherInterface) {
2017-10-31 22:50:14 +05:00
c.Pushers[name] = iface
c.Pushers[name].Initialize()
}
// Registers Slack API HTTP server control structure.
// Russians will have pretty good luff on variable name.
func (c *Context) RegisterSlackAPIServerInterface(sasi slackapiserverinterface.SlackAPIServerInterface) {
2017-10-31 22:50:14 +05:00
c.SlackAPIServer = sasi
c.SlackAPIServer.Initialize()
}
func (c *Context) SendToParser(name string, message slackmessage.SlackMessage) map[string]interface{} {
2017-10-31 22:50:14 +05:00
parser, found := c.Parsers[strings.ToLower(name)]
if !found {
c.Log.Errorf("Parser '%s' not found, will use default one!", name)
return c.Parsers["default"].ParseMessage(message)
}
2017-10-31 22:50:14 +05:00
return parser.ParseMessage(message)
}
func (c *Context) SendToPusher(protocol string, connection string, data slackmessage.SlackMessage) {
2017-10-31 22:50:14 +05:00
pusher, ok := c.Pushers[protocol]
if !ok {
c.Log.Errorf("Pusher not found (or initialized) for protocol '%s'!", protocol)
}
2017-10-31 22:50:14 +05:00
pusher.Push(connection, data)
}
// Shutdown everything.
func (c *Context) Shutdown() {
2017-10-31 22:50:14 +05:00
c.SlackAPIServer.Shutdown()
2017-10-31 22:50:14 +05:00
for _, pusher := range c.Pushers {
pusher.Shutdown()
}
}