mirror of
https://github.com/valitydev/osquery-1.git
synced 2024-11-08 02:18:53 +00:00
89 lines
2.2 KiB
C++
89 lines
2.2 KiB
C++
/*
|
|
* Copyright (c) 2014, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
*/
|
|
|
|
#include <boost/thread.hpp>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
#include <osquery/config.h>
|
|
#include <osquery/config/plugin.h>
|
|
#include <osquery/core.h>
|
|
#include <osquery/database.h>
|
|
#include <osquery/events.h>
|
|
#include <osquery/logger/plugin.h>
|
|
#include <osquery/scheduler.h>
|
|
|
|
#ifndef __APPLE__
|
|
namespace osquery {
|
|
DEFINE_osquery_flag(bool, daemonize, false, "Run as daemon (osqueryd only).");
|
|
}
|
|
#endif
|
|
|
|
int main(int argc, char* argv[]) {
|
|
osquery::initOsquery(argc, argv, osquery::OSQUERY_TOOL_DAEMON);
|
|
|
|
#ifndef __APPLE__
|
|
// OSX uses launchd to daemonize.
|
|
if (osquery::FLAGS_daemonize) {
|
|
if (daemon(0, 0) == -1) {
|
|
::exit(EXIT_FAILURE);
|
|
}
|
|
}
|
|
#endif
|
|
|
|
auto pid_status = osquery::createPidFile();
|
|
if (!pid_status.ok()) {
|
|
LOG(ERROR) << "Could not start osqueryd: " << pid_status.toString();
|
|
::exit(EXIT_FAILURE);
|
|
}
|
|
|
|
try {
|
|
osquery::DBHandle::getInstance();
|
|
} catch (std::exception& e) {
|
|
LOG(ERROR) << "osqueryd failed to start: " << e.what();
|
|
::exit(EXIT_FAILURE);
|
|
}
|
|
|
|
LOG(INFO) << "Listing all plugins";
|
|
|
|
LOG(INFO) << "Logger plugins:";
|
|
for (const auto& it : REGISTERED_LOGGER_PLUGINS) {
|
|
LOG(INFO) << " - " << it.first;
|
|
}
|
|
|
|
LOG(INFO) << "Config plugins:";
|
|
for (const auto& it : REGISTERED_CONFIG_PLUGINS) {
|
|
LOG(INFO) << " - " << it.first;
|
|
}
|
|
|
|
LOG(INFO) << "Event Publishers:";
|
|
for (const auto& it : REGISTERED_EVENTPUBLISHERS) {
|
|
LOG(INFO) << " - " << it.first;
|
|
}
|
|
|
|
LOG(INFO) << "Event Subscribers:";
|
|
for (const auto& it : REGISTERED_EVENTSUBSCRIBERS) {
|
|
LOG(INFO) << " - " << it.first;
|
|
}
|
|
|
|
// Start a thread for each appropriate event type
|
|
osquery::registries::faucet(REGISTERED_EVENTPUBLISHERS,
|
|
REGISTERED_EVENTSUBSCRIBERS);
|
|
osquery::EventFactory::delay();
|
|
|
|
boost::thread scheduler_thread(osquery::initializeScheduler);
|
|
scheduler_thread.join();
|
|
|
|
// End any event type run loops.
|
|
osquery::EventFactory::end();
|
|
|
|
return 0;
|
|
}
|