osctrl-admin

osctrl-admin is the Admin service for osctrl.

Execute ./osctrl-admin help to show the main help of the program:

$ ./osctrl-admin help
NAME:
   osctrl-admin - Admin service for osctrl, a fast and efficient osquery management

USAGE:
   osctrl-admin [global options] [command [command options]]

DESCRIPTION:
   Admin service for osctrl, a fast and efficient osquery management

COMMANDS:
   help
   config-validate, config-verify  Validate YAML configuration file
   config-generate                 Generate an example configuration file using the current flag values

GLOBAL OPTIONS:
   --config, -c                                                     Provide service configuration via YAML file [$SERVICE_CONFIG]
   --config-file FILE, -C FILE                                      Load service configuration from FILE (default: "./config/admin.yml") [$SERVICE_CONFIG_FILE]
   --listener string, -l string                                     Listener for the service (default: "127.0.0.1") [$SERVICE_LISTENER]
   --port int, -p int                                               TCP port for the service (default: 9000) [$SERVICE_PORT]
   --host string, -H string                                         Exposed hostname the service uses (default: "osctrl.net") [$SERVICE_HOST]
   --auth string, -A string                                         Authentication mechanism for the service (default: "none") [$SERVICE_AUTH]
   --log-level string                                               Log level for the service (default: "info") [$SERVICE_LOG_LEVEL]
   --log-format string                                              Log format for the service (default: "json") [$SERVICE_LOG_FORMAT]
   --audit-log, --audit                                             Enable audit log for the service. Logs all sensitive actions [$AUDIT_LOG]
   --logger string, -L string                                       Logger mechanism to handle status/result logs from nodes (default: "db") [$SERVICE_LOGGER]
   --logger-db-same                                                 Use the same DB configuration for the logger [$LOGGER_DB_SAME]
   --always-log, -a, --always                                       Always log status and on-demand query logs from nodes in database [$ALWAYS_LOG]
   --redis-connection-string string                                 Redis connection string, must include schema (<redis|rediss|unix>://<user>:<pass>@<host>:<port>/<db>?<options> [$REDIS_CONNECTION_STRING]
   --redis-host string                                              Redis host to be connected to (default: "127.0.0.1") [$REDIS_HOST]
   --redis-port int                                                 Redis port to be connected to (default: 6379) [$REDIS_PORT]
   --redis-pass string                                              Password to be used for redis [$REDIS_PASS]
   --redis-db int                                                   Redis database to be selected after connecting (default: 0) [$REDIS_DB]
   --redis-conn-retry int                                           Time in seconds to retry the connection to the cache, if set to 0 the service will stop if the connection fails (default: 10) [$REDIS_CONN_RETRY]
   --db-type string                                                 Type of backend to be used (default: "postgres") [$DB_TYPE]
   --db-host string                                                 Backend host to be connected to (default: "127.0.0.1") [$DB_HOST]
   --db-port int                                                    Backend port to be connected to (default: 5432) [$DB_PORT]
   --db-name string                                                 Database name to be used in the backend (default: "osctrl") [$DB_NAME]
   --db-user string                                                 Username to be used for the backend (default: "postgres") [$DB_USER]
   --db-pass string                                                 Password to be used for the backend (default: "postgres") [$DB_PASS]
   --db-sslmode string                                              SSL native support to encrypt the connection to the backend (default: "disable") [$DB_SSLMODE]
   --db-max-idle-conns int                                          Maximum number of connections in the idle connection pool (default: 20) [$DB_MAX_IDLE_CONNS]
   --db-max-open-conns int                                          Maximum number of open connections to the database (default: 100) [$DB_MAX_OPEN_CONNS]
   --db-conn-max-lifetime int                                       Maximum amount of time a connection may be reused (default: 30) [$DB_CONN_MAX_LIFETIME]
   --db-conn-retry int                                              Time in seconds to retry the connection to the database, if set to 0 the service will stop if the connection fails (default: 10) [$DB_CONN_RETRY]
   --db-filepath string                                             File path to the SQLite database, only used when type is sqlite (default: "./osctrl.db") [$DB_SQLITE_FILEPATH]
   --tls, -t                                                        Enable TLS termination. It requires certificate and key [$TLS_SERVER]
   --cert FILE, -T FILE                                             TLS termination certificate from FILE (default: "./config/tls.crt") [$TLS_CERTIFICATE]
   --key FILE, -K FILE                                              TLS termination private key from FILE (default: "./config/tls.key") [$TLS_KEY]
   --enable-osctrld                                                 Enable osctrld endpoints and functionality. [$OSCTRLD]
   --carver-type string                                             Carver to be used to receive files extracted from nodes (default: "db") [$CARVER_TYPE]
   --carver-s3-bucket string                                        S3 bucket to be used as configuration for carves [$CARVER_S3_BUCKET]
   --carver-s3-region string                                        S3 region to be used as configuration for carves [$CARVER_S3_REGION]
   --carve-s3-key-id string                                         S3 access key id to be used as configuration for carves [$CARVER_S3_KEY_ID]
   --carve-s3-secret string                                         S3 access key secret to be used as configuration for carves [$CARVER_S3_SECRET]
   --carver-local-dir string                                        Local directory to store carved files (default: "./carved_files/") [$CARVER_LOCAL_DIR]
   --log-s3-bucket string                                           S3 bucket to be used as configuration for logging [$LOG_S3_BUCKET]
   --log-s3-region string                                           S3 region to be used as configuration for logging [$LOG_S3_REGION]
   --log-s3-key-id string                                           S3 access key id to be used as configuration for logging [$LOG_S3_KEY_ID]
   --log-s3-secret string                                           S3 access key secret to be used as configuration for logging [$LOG_S3_SECRET]
   --jwt-secret string                                              Password to be used for the backend [$JWT_SECRET]
   --jwt-expire int                                                 Maximum amount of hours for the tokens to expire (default: 3) [$JWT_EXPIRE]
   --osquery-version string                                         Version of osquery to be used (default: "5.20.0") [$OSQUERY_VERSION]
   --osquery-tables-file string                                     File with the osquery tables to be used (default: "./data/5.20.0.json") [$OSQUERY_TABLES]
   --osquery-logger                                                 Enable remote tls logger for osquery [$OSQUERY_LOGGER]
   --osquery-config                                                 Enable remote tls config for osquery [$OSQUERY_CONFIG]
   --osquery-query                                                  Enable remote tls queries for osquery [$OSQUERY_QUERY]
   --osquery-carve                                                  Enable remote tls carver for osquery [$OSQUERY_CARVE]
   --session-key string                                             Session key to generate cookies from it [$SESSION_KEY]
   --static string, -s string                                       Directory with all the static files needed for the osctrl-admin UI (default: "./static") [$STATIC_FILES]
   --static-offline, -S                                             Use offline static files (js and css). Default is online files. [$STATIC_ONLINE]
   --templates string                                               Directory with all the templates needed for the osctrl-admin UI (default: "./tmpl_admin") [$TEMPLATES_DIR]
   --background-image string, --bg-img string, --background string  Background image file for all the pages in the osctrl-admin UI (default: "./static/img/circuit.svg") [$BACKGROUND_IMAGE]
   --branding-image string, --brand-img string, --branding string   Branding image file for the osctrl-admin UI. Use an image with 450x130 pixels for best results. (default: "./static/img/brand.png") [$BRANDING_IMAGE]
   --enable-http-debug                                              Enable HTTP Debug mode to dump full HTTP incoming request [$HTTP_DEBUG]
   --http-debug-file string                                         File to dump the HTTP requests when HTTP Debug mode is enabled (default: "./debug-http-admin.log") [$HTTP_DEBUG_FILE]
   --http-debug-show-body                                           Show body of the HTTP requests when HTTP Debug mode is enabled [$HTTP_DEBUG_SHOW_BODY]
   --version, -v                                                    Print version information
   --help, -h                                                       show help