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-mdsurveilr 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 adminsurveilr transform- Subcommands: - Options:surveilr transform html- Options:surveilr transform markdown
surveilr
Usage: surveilr [OPTIONS] <COMMAND>
Subcommands:
admin— Admin / maintenance utilitiescapturable-exec— Capturable Executables (CE) maintenance toolsingest— Ingest content from device file system and other sourcesnotebooks— Notebooks maintenance utilitiessqlpage— Configuration to start the SQLPage webserverudi— Universal Data Infrastructuretransform— 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.sqlmerge— merge multiple surveillance state databases into a single onecli-help-md— generate CLI help markdowntest— generate CLI help markdowncredentials— 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 executablestest— 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 filestask— Execute a task string as if it was run byingest 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 sourcestasks— Notebooks maintenance utilitiesimap— 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 utilitiesls— 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 machineremote— 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 contentmarkdown— 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.