2016-09-29 02:44:05 +00:00
|
|
|
// Package service holds the implementation of the kolide service interface and the HTTP endpoints
|
2016-09-01 04:51:38 +00:00
|
|
|
// for the API
|
2016-09-26 18:48:55 +00:00
|
|
|
package service
|
2016-08-28 03:59:17 +00:00
|
|
|
|
2016-09-01 04:51:38 +00:00
|
|
|
import (
|
2019-08-02 21:08:42 +00:00
|
|
|
"html/template"
|
2017-11-16 16:53:42 +00:00
|
|
|
"net/http"
|
2019-08-02 21:08:42 +00:00
|
|
|
"strings"
|
2021-04-12 23:22:22 +00:00
|
|
|
"sync"
|
2017-11-16 16:53:42 +00:00
|
|
|
"time"
|
2016-09-04 05:13:42 +00:00
|
|
|
|
2016-09-21 03:08:11 +00:00
|
|
|
"github.com/WatchBeam/clock"
|
2020-11-11 17:59:12 +00:00
|
|
|
"github.com/fleetdm/fleet/server/config"
|
|
|
|
"github.com/fleetdm/fleet/server/kolide"
|
|
|
|
"github.com/fleetdm/fleet/server/logging"
|
|
|
|
"github.com/fleetdm/fleet/server/sso"
|
2020-12-16 17:16:55 +00:00
|
|
|
kitlog "github.com/go-kit/kit/log"
|
2019-08-02 21:08:42 +00:00
|
|
|
"github.com/kolide/kit/version"
|
2019-04-08 18:47:15 +00:00
|
|
|
"github.com/pkg/errors"
|
2016-09-01 04:51:38 +00:00
|
|
|
)
|
2016-08-28 03:59:17 +00:00
|
|
|
|
2016-09-01 04:51:38 +00:00
|
|
|
// NewService creates a new service from the config struct
|
2017-05-09 00:43:48 +00:00
|
|
|
func NewService(ds kolide.Datastore, resultStore kolide.QueryResultStore,
|
2019-04-08 18:47:15 +00:00
|
|
|
logger kitlog.Logger, config config.KolideConfig, mailService kolide.MailService,
|
2021-05-20 00:29:38 +00:00
|
|
|
c clock.Clock, sso sso.SessionStore, lq kolide.LiveQueryStore, carveStore kolide.CarveStore,
|
|
|
|
license kolide.LicenseInfo) (kolide.Service, error) {
|
2016-08-28 03:59:17 +00:00
|
|
|
var svc kolide.Service
|
2019-04-08 18:47:15 +00:00
|
|
|
|
|
|
|
osqueryLogger, err := logging.New(config, logger)
|
2017-04-03 21:48:50 +00:00
|
|
|
if err != nil {
|
2019-04-08 18:47:15 +00:00
|
|
|
return nil, errors.Wrap(err, "initializing osquery logging")
|
2017-04-03 21:48:50 +00:00
|
|
|
}
|
2016-09-04 05:13:42 +00:00
|
|
|
|
2021-04-12 23:22:22 +00:00
|
|
|
svc = &service{
|
2019-04-08 18:47:15 +00:00
|
|
|
ds: ds,
|
2020-12-16 17:16:55 +00:00
|
|
|
carveStore: carveStore,
|
2019-04-08 18:47:15 +00:00
|
|
|
resultStore: resultStore,
|
2020-03-23 01:33:04 +00:00
|
|
|
liveQueryStore: lq,
|
2019-04-08 18:47:15 +00:00
|
|
|
logger: logger,
|
|
|
|
config: config,
|
|
|
|
clock: c,
|
|
|
|
osqueryLogWriter: osqueryLogger,
|
|
|
|
mailService: mailService,
|
|
|
|
ssoSessionStore: sso,
|
2021-04-12 23:22:22 +00:00
|
|
|
seenHostSet: newSeenHostSet(),
|
2017-11-16 16:53:42 +00:00
|
|
|
metaDataClient: &http.Client{
|
|
|
|
Timeout: 5 * time.Second,
|
|
|
|
},
|
2021-05-20 00:29:38 +00:00
|
|
|
license: license,
|
2016-08-28 03:59:17 +00:00
|
|
|
}
|
2017-05-09 00:43:48 +00:00
|
|
|
svc = validationMiddleware{svc, ds, sso}
|
2016-08-28 03:59:17 +00:00
|
|
|
return svc, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type service struct {
|
2020-03-23 01:33:04 +00:00
|
|
|
ds kolide.Datastore
|
2020-12-16 17:16:55 +00:00
|
|
|
carveStore kolide.CarveStore
|
2020-03-23 01:33:04 +00:00
|
|
|
resultStore kolide.QueryResultStore
|
|
|
|
liveQueryStore kolide.LiveQueryStore
|
|
|
|
logger kitlog.Logger
|
|
|
|
config config.KolideConfig
|
|
|
|
clock clock.Clock
|
2016-09-01 04:51:38 +00:00
|
|
|
|
2019-04-08 18:47:15 +00:00
|
|
|
osqueryLogWriter *logging.OsqueryLogger
|
2016-09-15 14:52:17 +00:00
|
|
|
|
2017-05-09 00:43:48 +00:00
|
|
|
mailService kolide.MailService
|
|
|
|
ssoSessionStore sso.SessionStore
|
2017-11-16 16:53:42 +00:00
|
|
|
metaDataClient *http.Client
|
2021-04-12 23:22:22 +00:00
|
|
|
|
|
|
|
seenHostSet *seenHostSet
|
2021-05-20 00:29:38 +00:00
|
|
|
|
|
|
|
license kolide.LicenseInfo
|
2016-09-01 04:51:38 +00:00
|
|
|
}
|
2016-12-20 21:54:30 +00:00
|
|
|
|
|
|
|
func (s service) SendEmail(mail kolide.Email) error {
|
|
|
|
return s.mailService.SendEmail(mail)
|
|
|
|
}
|
2017-01-04 21:16:17 +00:00
|
|
|
|
|
|
|
func (s service) Clock() clock.Clock {
|
|
|
|
return s.clock
|
|
|
|
}
|
2017-05-09 00:43:48 +00:00
|
|
|
|
|
|
|
type validationMiddleware struct {
|
|
|
|
kolide.Service
|
|
|
|
ds kolide.Datastore
|
|
|
|
ssoSessionStore sso.SessionStore
|
|
|
|
}
|
2019-08-02 21:08:42 +00:00
|
|
|
|
|
|
|
// getAssetURL gets the URL prefix used for retrieving assets from Github. This
|
|
|
|
// function will determine the appropriate version to use, and create a URL
|
|
|
|
// prefix for retrieving assets from that tag.
|
|
|
|
func getAssetURL() template.URL {
|
|
|
|
v := version.Version().Version
|
|
|
|
tag := strings.Split(v, "-")[0]
|
|
|
|
if tag == "unknown" {
|
|
|
|
tag = "master"
|
|
|
|
}
|
|
|
|
|
2020-11-11 17:59:12 +00:00
|
|
|
return template.URL("https://github.com/fleetdm/fleet/blob/" + tag)
|
2019-08-02 21:08:42 +00:00
|
|
|
}
|
2021-04-12 23:22:22 +00:00
|
|
|
|
|
|
|
// seenHostSet implements synchronized storage for the set of seen hosts.
|
|
|
|
type seenHostSet struct {
|
|
|
|
mutex sync.Mutex
|
|
|
|
hostIDs map[uint]bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func newSeenHostSet() *seenHostSet {
|
|
|
|
return &seenHostSet{
|
|
|
|
mutex: sync.Mutex{},
|
|
|
|
hostIDs: make(map[uint]bool),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// addHostID adds the host identified by ID to the set
|
|
|
|
func (m *seenHostSet) addHostID(id uint) {
|
|
|
|
m.mutex.Lock()
|
|
|
|
defer m.mutex.Unlock()
|
|
|
|
m.hostIDs[id] = true
|
|
|
|
}
|
|
|
|
|
|
|
|
// getAndClearHostIDs gets the list of unique host IDs from the set and empties
|
|
|
|
// the set.
|
|
|
|
func (m *seenHostSet) getAndClearHostIDs() []uint {
|
|
|
|
m.mutex.Lock()
|
|
|
|
defer m.mutex.Unlock()
|
|
|
|
var ids []uint
|
2021-05-17 17:29:50 +00:00
|
|
|
for id := range m.hostIDs {
|
2021-04-12 23:22:22 +00:00
|
|
|
ids = append(ids, id)
|
|
|
|
}
|
|
|
|
m.hostIDs = make(map[uint]bool)
|
|
|
|
return ids
|
|
|
|
}
|