Command-Line Help for Surveilr
Command Overview:
- surveilr- Subcommands: - Options:
- surveilr admin- Subcommands:
- surveilr admin init- Options:
- surveilr admin merge- Options:
- surveilr admin cli-help-md
- surveilr admin test- Subcommands:
- surveilr admin test classifiers- Options:
- surveilr admin credentials- Subcommands:
- surveilr admin credentials microsoft-365- Options:
- surveilr capturable-exec- Subcommands:
- surveilr capturable-exec ls- Options:
- surveilr capturable-exec test- Subcommands:
- surveilr capturable-exec test file- Options:
- surveilr capturable-exec test task- Options:
- surveilr ingest- Subcommands:
- surveilr ingest files- Options:
- surveilr ingest tasks- Options:
- surveilr ingest imap- Subcommands: - Options:
- surveilr ingest imap microsoft-365- Options:
- surveilr notebooks- Subcommands: - Options:
- surveilr notebooks cat- Options:
- surveilr notebooks ls- Options:
- surveilr sqlpage- Options:
- surveilr udi- Subcommands:
- surveilr udi pgp- Subcommands: - Options:
- surveilr udi pgp osquery- Subcommands:
- surveilr udi pgp osquery local- Options:
- surveilr udi pgp osquery remote- Options:
- surveilr udi admin
- surveilr transform- Subcommands: - Options:
- surveilr transform html- Options:
- surveilr transform markdown
surveilr
Usage: surveilr [OPTIONS] <COMMAND>
Subcommands:
- admin— Admin / maintenance utilities
- capturable-exec— Capturable Executables (CE) maintenance tools
- ingest— Ingest content from device file system and other sources
- notebooks— Notebooks maintenance utilities
- sqlpage— Configuration to start the SQLPage webserver
- udi— Universal Data Infrastructure
- transform— Resource transformation utilities for data stored in the RSSD
Options:
- 
--device-name <DEVICE_NAME>— How to identify this deviceDefault value: mf-elitemini-hx90-01
- 
-d,--debug— Turn debugging information on (repeat for higher levels)
- 
--log-mode <LOG_MODE>— Output logs in json formatPossible values: full,json,compact
- 
--log-file <LOG_FILE>— File for logs to be written to
surveilr admin
Admin / maintenance utilities
Usage: surveilr admin <COMMAND>
Subcommands:
- init— initialize an empty database with bootstrap.sql
- merge— merge multiple surveillance state databases into a single one
- cli-help-md— generate CLI help markdown
- test— generate CLI help markdown
- credentials— emit credentials
surveilr admin init
initialize an empty database with bootstrap.sql
Usage: surveilr admin init [OPTIONS]
Options:
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite databaseDefault value: resource-surveillance.sqlite.db
- 
-I,--state-db-init-sql <STATE_DB_INIT_SQL>— one or more globs to match as SQL files and batch execute them in alpha order
- 
-r,--remove-existing-first— remove the existing database firstPossible values: true,false
- 
--with-device— add the current device in the empty database’s device tablePossible values: true,false
surveilr admin merge
merge multiple surveillance state databases into a single one
Usage: surveilr admin merge [OPTIONS]
Options:
- 
-c,--candidates <CANDIDATES>— one or more DB name globs to match and mergeDefault value: *.db
- 
-i,--ignore-candidates <IGNORE_CANDIDATES>— one or more DB name globs to ignore if they match
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite database with merged contentDefault value: resource-surveillance-aggregated.sqlite.db
- 
-I,--state-db-init-sql <STATE_DB_INIT_SQL>— one or more globs to match as SQL files and batch execute them in alpha order
- 
-r,--remove-existing-first— remove the existing database firstPossible values: true,false
- 
--sql-only— only generate SQL and emit to STDOUT (no actual merge)Possible values: true,false
surveilr admin cli-help-md
generate CLI help markdown
Usage: surveilr admin cli-help-md
surveilr admin test
generate CLI help markdown
Usage: surveilr admin test <COMMAND>
Subcommands:
- classifiers— test capturable executables files
surveilr admin test classifiers
test capturable executables files
Usage: surveilr admin test classifiers [OPTIONS]
Options:
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite databaseDefault value: resource-surveillance.sqlite.db
- 
-I,--state-db-init-sql <STATE_DB_INIT_SQL>— one or more globs to match as SQL files and batch execute them in alpha order
- 
--builtins— only show the builtins, not from the databasePossible values: true,false
surveilr admin credentials
emit credentials
Usage: surveilr admin credentials <COMMAND>
Subcommands:
- microsoft-365— microsoft 365 credentials
surveilr admin credentials microsoft-365
microsoft 365 credentials
Usage: surveilr admin credentials microsoft-365 [OPTIONS] --client-id <CLIENT_ID> --client-secret <CLIENT_SECRET>
Options:
- 
-i,--client-id <CLIENT_ID>— Client ID of the application from MSFT Azure App Directory
- 
-s,--client-secret <CLIENT_SECRET>— Client Secret of the application from MSFT Azure App Directory
- 
-r,--redirect-uri <REDIRECT_URI>— Redirect URL. Base redirect URL path. It gets concatenated with the server address to form the full redirect url, when using theauth_codemode for token generation
- 
--env— Emit values to stdoutPossible values: true,false
- 
--export— Emit values to stdout with the “export” syntax right in front to enable direct sourcingPossible values: true,false
surveilr capturable-exec
Capturable Executables (CE) maintenance tools
Usage: surveilr capturable-exec <COMMAND>
Subcommands:
- ls— list potential capturable executables
- test— test capturable executables files
surveilr capturable-exec ls
list potential capturable executables
Usage: surveilr capturable-exec ls [OPTIONS]
Options:
- 
-r,--root-fs-path <ROOT_FS_PATH>— one or more root paths to ingestDefault value: .
- 
--markdown— emit the results as markdown, not a simple tablePossible values: true,false
surveilr capturable-exec test
test capturable executables files
Usage: surveilr capturable-exec test <COMMAND>
Subcommands:
- file— test capturable executables files
- task— Execute a task string as if it was run by- ingest tasksand show the output
surveilr capturable-exec test file
test capturable executables files
Usage: surveilr capturable-exec test file --fs-path <FS_PATH>
Options:
- -f,- --fs-path <FS_PATH>
surveilr capturable-exec test task
Execute a task string as if it was run by ingest tasks and show the output
Usage: surveilr capturable-exec test task [OPTIONS]
Options:
- 
-s,--stdin— send commands in via STDIN the same as withingest tasksand just emit the outputPossible values: true,false
- 
-t,--task <TASK>— one or more commands that would work as a Deno Task line
- 
--cwd <CWD>— use this as the current working directory (CWD)
surveilr ingest
Ingest content from device file system and other sources
Usage: surveilr ingest <COMMAND>
Subcommands:
- files— Ingest content from device file system and other sources
- tasks— Notebooks maintenance utilities
- imap— Ingest content from email boxes
surveilr ingest files
Ingest content from device file system and other sources
Usage: surveilr ingest files [OPTIONS]
Options:
- 
--dry-run— don’t run the ingestion, just report statisticsPossible values: true,false
- 
-b,--behavior <BEHAVIOR>— the behavior name inbehaviortable
- 
-r,--root-fs-path <ROOT_FS_PATH>— one or more root paths to ingestDefault value: .
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite databaseDefault value: resource-surveillance.sqlite.db
- 
-I,--state-db-init-sql <STATE_DB_INIT_SQL>— one or more globs to match as SQL files and batch execute them in alpha order
- 
--include-state-db-in-ingestion— include the surveil database in the ingestion candidatesPossible values: true,false
- 
--stats— show stats as an ASCII table after completionPossible values: true,false
- 
--stats-json— show stats in JSON after completionPossible values: true,false
- 
--save-behavior <SAVE_BEHAVIOR>— save the options as a new behavior
surveilr ingest tasks
Notebooks maintenance utilities
Usage: surveilr ingest tasks [OPTIONS]
Options:
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite databaseDefault value: resource-surveillance.sqlite.db
- 
-I,--state-db-init-sql <STATE_DB_INIT_SQL>— one or more globs to match as SQL files and batch execute them in alpha order
- 
--stdin— read tasks from STDINPossible values: true,false
- 
--stats— show session stats after completionPossible values: true,false
- 
--stats-json— show session stats as JSON after completionPossible values: true,false
surveilr ingest imap
Ingest content from email boxes
Usage: surveilr ingest imap [OPTIONS] [COMMAND]
Subcommands:
- microsoft-365— Microsoft 365 Credentials
Options:
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite databaseDefault value: resource-surveillance.sqlite.db
- 
-I,--state-db-init-sql <STATE_DB_INIT_SQL>— one or more globs to match as SQL files and batch execute them in alpha order
- 
-u,--username <USERNAME>— email address
- 
-p,--password <PASSWORD>— password to the email. mainly an app password. See the documentation on how to create an app password
- 
-a,--server-addr <SERVER_ADDR>— IMAP server address. e.g imap.gmail.com or outlook.office365.com
- 
--port <PORT>— IMAP server portDefault value: 993
- 
-f,--folder <FOLDER>— Mailboxes to read from. i.e folders. Takes a regular expression matching the folder names. The default is a ”*” which means all foldersDefault value: *
- 
-s,--status <STATUS>— Status of the messages to be ingestedDefault value: unreadPossible values: all,unread,read,starred
- 
-b,--batch-size <BATCH_SIZE>— Maximum number of messages to be ingestedDefault value: 1000
- 
-e,--extract-attachments— Extract AttachmentsDefault value: truePossible values: true,false
surveilr ingest imap microsoft-365
Microsoft 365 Credentials
Usage: surveilr ingest imap microsoft-365 [OPTIONS] --client-id <CLIENT_ID> --client-secret <CLIENT_SECRET> --mode <MODE>
Options:
- 
-i,--client-id <CLIENT_ID>— Client ID of the application from MSFT Azure App Directory
- 
-s,--client-secret <CLIENT_SECRET>— Client Secret of the application from MSFT Azure App Directory
- 
-m,--mode <MODE>— The mode to generate an access_token. Default is ‘DeviceCode’Possible values: auth-code,device-code
- 
-a,--addr <ADDR>— Address to start the authentication server on, when using theauth_codemode for token generationDefault value: http://127.0.0.1:8000
- 
-r,--redirect-uri <REDIRECT_URI>— Redirect URL. Base redirect URL path. It gets concatenated with the server address to form the full redirect url, when using theauth_codemode for token generationDefault value: /redirect
- 
-p,--port <PORT>— Port to bind the server toDefault value: 8000
surveilr notebooks
Notebooks maintenance utilities
Usage: surveilr notebooks [OPTIONS] <COMMAND>
Subcommands:
- cat— Notebooks’ cells emit utilities
- ls— list all notebooks
Options:
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite databaseDefault value: resource-surveillance.sqlite.db
- 
-I,--state-db-init-sql <STATE_DB_INIT_SQL>— one or more globs to match as SQL files and batch execute them in alpha order
surveilr notebooks cat
Notebooks’ cells emit utilities
Usage: surveilr notebooks cat [OPTIONS]
Options:
- 
-n,--notebook <NOTEBOOK>— search for these notebooks (include % for LIKE otherwise =)
- 
-c,--cell <CELL>— search for these cells (include % for LIKE otherwise =)
- 
-s,--seps— add separators before each cellPossible values: true,false
surveilr notebooks ls
list all notebooks
Usage: surveilr notebooks ls [OPTIONS]
Options:
- 
-m,--migratable— list all SQL cells that will be handled by execute_migrationsPossible values: true,false
surveilr sqlpage
Configuration to start the SQLPage webserver
Usage: surveilr sqlpage [OPTIONS] --port <PORT>
Options:
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite databaseDefault value: resource-surveillance.sqlite.db
- 
-u,--url-base-path <URL_BASE_PATH>— Base URL for SQLPage to start from. Defaults to “/index.sql”Default value: /
- 
-p,--port <PORT>— Port to bind sqplage webserver to
- 
-o,--otel <OTEL>— Port that any OTEL compatible service is running on
- 
-m,--metrics <METRICS>— Metrics port. Used for scraping metrics with tools like OpenObserve or Prometheus
surveilr udi
Universal Data Infrastructure
Usage: surveilr udi <COMMAND>
Subcommands:
- pgp— UDI PostgreSQL Proxy for remote SQL starts up a server which pretends to be PostgreSQL but proxies its SQL to other CLI services with SQL-like interface (called SQL Suppliers)
- admin—
surveilr udi pgp
UDI PostgreSQL Proxy for remote SQL starts up a server which pretends to be PostgreSQL but proxies its SQL to other CLI services with SQL-like interface (called SQL Suppliers)
Usage: surveilr udi pgp [OPTIONS] [COMMAND]
Subcommands:
- osquery— query a machine
Options:
- 
-a,--addr <ADDR>— IP address to bind udi-pgp toDefault value: 127.0.0.1:5432
- 
-u,--username <USERNAME>— Username for authentication
- 
-p,--password <PASSWORD>— Password for authentication
- 
-i,--supplier-id <SUPPLIER_ID>— Identification for the supplier which will be passed to the client. e.g surveilr udi pgp -u john -p doe -i test-supplier osquery local The psql comand will be: psql -h 127.0.0.1 -p 5432 -d “test-supplier” -c “select * from system_info”
- 
-c,--config <CONFIG>— Config file for UDI-PGP. Either a .ncl file or JSON file
- 
-d,--admin-state-fs-path <ADMIN_STATE_FS_PATH>— Admin SQLite Database path for state managementDefault value: resource-surveillance-admin.sqlite.db
surveilr udi pgp osquery
query a machine
Usage: surveilr udi pgp osquery <COMMAND>
Subcommands:
- local— execute osquery on the local machine
- remote— execute osquery on remote hosts
surveilr udi pgp osquery local
execute osquery on the local machine
Usage: surveilr udi pgp osquery local [OPTIONS]
Options:
- -a,- --atc-file-path <ATC_FILE_PATH>— ATC Configuration File path
surveilr udi pgp osquery remote
execute osquery on remote hosts
Usage: surveilr udi pgp osquery remote [OPTIONS]
Options:
- -s,- --ssh-targets <SSH_TARGETS>— SSH details of hosts to execute osquery on including and identifier. e,g. “user@127.0.0.1:22,john”/“user@host.com:1234,doe”
surveilr udi admin
Usage: surveilr udi admin
surveilr transform
Resource transformation utilities for data stored in the RSSD
Usage: surveilr transform [OPTIONS] <COMMAND>
Subcommands:
- html— Transform HTML content
- markdown— Transform markdown content
Options:
- 
-d,--state-db-fs-path <STATE_DB_FS_PATH>— target SQLite databaseDefault value: resource-surveillance.sqlite.db
- 
-r,--reset-transforms— Indicates if all current transforms should be deleted before running the transformDefault value: falsePossible values: true,false
surveilr transform html
Transform HTML content
Usage: surveilr transform html [OPTIONS]
Options:
- -c,- --css-select <CSS_SELECT>— List of CSS selectors with names and values. e.g. -css-select=“name_of_select_query:div > p” i.e, select all p tags in a div tag
surveilr transform markdown
Transform markdown content
Usage: surveilr transform markdown
This document was generated automatically by
clap-markdown.