Command-Line Help for spacetime
This document contains the help content for the spacetime command-line program.
Command Overview:
spacetime↴spacetime publish↴spacetime delete↴spacetime logs↴spacetime call↴spacetime describe↴spacetime dev↴spacetime sql↴spacetime rename↴spacetime generate↴spacetime list↴spacetime login↴spacetime login show↴spacetime logout↴spacetime init↴spacetime build↴spacetime server↴spacetime server list↴spacetime server set-default↴spacetime server add↴spacetime server remove↴spacetime server fingerprint↴spacetime server ping↴spacetime server edit↴spacetime server clear↴spacetime subscribe↴spacetime start↴spacetime version↴
spacetime
Usage: spacetime [OPTIONS] <COMMAND>
Subcommands:
publish— Create and update a SpacetimeDB databasedelete— Deletes a SpacetimeDB databaselogs— Prints logs from a SpacetimeDB databasecall— Invokes a function (reducer or procedure) in a database. WARNING: This command is UNSTABLE and subject to breaking changes.describe— Describe the structure of a database or entities within it. WARNING: This command is UNSTABLE and subject to breaking changes.dev— Start development mode with auto-regenerate client module bindings, auto-rebuild, and auto-publish on file changes.sql— Runs a SQL query on the database. WARNING: This command is UNSTABLE and subject to breaking changes.rename— Rename a databasegenerate— Generate client files for a spacetime module.list— Lists the databases attached to an identity. WARNING: This command is UNSTABLE and subject to breaking changes.login— Manage your login to the SpacetimeDB CLIlogout—init— Initializes a new spacetime project.build— Builds a spacetime module.server— Manage the connection to the SpacetimeDB server. WARNING: This command is UNSTABLE and subject to breaking changes.subscribe— Subscribe to SQL queries on the database. WARNING: This command is UNSTABLE and subject to breaking changes.start— Start a local SpacetimeDB instanceversion— Manage installed spacetime versions
Options:
--root-dir <ROOT_DIR>— The root directory to store all spacetime files in.--config-path <CONFIG_PATH>— The path to the cli.toml config file
spacetime publish
Create and update a SpacetimeDB database
Usage: spacetime publish [OPTIONS] [name|identity]
Run spacetime help publish for more detailed information.
Arguments:
-
<NAME|IDENTITY>— A valid domain or identity for this database.Database names must match the regex
/^[a-z0-9]+(-[a-z0-9]+)*$/, i.e. only lowercase ASCII letters and numbers, separated by dashes.
Options:
-
-c,--delete-data <CLEAR-DATABASE>— When publishing to an existing database identity, first DESTROY all data associated with the module. With 'on-conflict': only when breaking schema changes occur.Possible values:
always,on-conflict,never -
--build-options <BUILD_OPTIONS>— Options to pass to the build command, for example --build-options='--lint-dir='Default value: ``
-
-p,--module-path <MODULE_PATH>— The system path (absolute or relative) to the module project. Defaults to spacetimedb/ subdirectory, then current directory. -
-b,--bin-path <WASM_FILE>— The system path (absolute or relative) to the compiled wasm binary we should publish, instead of building the project. -
-j,--js-path <JS_FILE>— UNSTABLE: The system path (absolute or relative) to the javascript file we should publish, instead of building the project. -
--break-clients— Allow breaking changes when publishing to an existing database identity. This will force publish even if it will break existing clients, but will NOT force publish if it would cause deletion of any data in the database. See --yes and --delete-data for details. -
--anonymous— Perform this action with an anonymous identity -
--parent <PARENT>— A valid domain or identity of an existing database that should be the parent of this database.If a parent is given, the new database inherits the team permissions from the parent. A parent can only be set when a database is created, not when it is updated.
-
--organization <ORGANIZATION>— The name or identity of an existing organization this database should be created under.If an organization is given, the organization member's permissions apply to the new database. An organization can only be set when a database is created, not when it is updated.
-
-s,--server <SERVER>— The nickname, domain name or URL of the server to host the database. -
-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com). -
--no-config— Ignore spacetime.json configuration -
--env <ENV>— Environment name for config file layering (e.g., dev, staging)
spacetime delete
Deletes a SpacetimeDB database
Usage: spacetime delete [OPTIONS] [database]
Run spacetime help delete for more detailed information.
Arguments:
<DATABASE>— The name or identity of the database to delete
Options:
-s,--server <SERVER>— The nickname, host name or URL of the server hosting the database-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).--no-config— Ignore spacetime.json configuration
spacetime logs
Prints logs from a SpacetimeDB database
Usage: spacetime logs [OPTIONS] [database]
Run spacetime help logs for more detailed information.
Arguments:
<DATABASE>— The name or identity of the database to print logs from
Options:
-
-s,--server <SERVER>— The nickname, host name or URL of the server hosting the database -
-n,--num-lines <NUM_LINES>— The number of lines to print from the start of the log of this database. If no num lines is provided, all lines will be returned. -
-f,--follow— A flag that causes logs to not stop when end of the log file is reached, but rather to wait for additional data to be appended to the input. -
--format <FORMAT>— Output format for the logsDefault value:
textPossible values:
text,json -
-l,--level <LEVEL>— Filter logs by severity level. Only messages at the specified level or higher will be shown. Levels from least to most severe: trace, debug, info, warn, error, panic.Possible values:
trace,debug,info,warn,error,panic -
--level-exact— When combined with --level, show only logs at exactly the specified level instead of that level and above. -
-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com). -
--no-config— Ignore spacetime.json configuration
spacetime call
Invokes a function (reducer or procedure) in a database. WARNING: This command is UNSTABLE and subject to breaking changes.
Usage: spacetime call [OPTIONS] [call_parts]...
Run spacetime help call for more detailed information.
Arguments:
<CALL_PARTS>— Call arguments: [DATABASE] <FUNCTION_NAME> [ARGUMENTS...]
Options:
-s,--server <SERVER>— The nickname, host name or URL of the server hosting the database--anonymous— Perform this action with an anonymous identity-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).--no-config— Ignore spacetime.json configuration
spacetime describe
Describe the structure of a database or entities within it. WARNING: This command is UNSTABLE and subject to breaking changes.
Usage: spacetime describe [OPTIONS] --json [describe_parts]...
Run spacetime help describe for more detailed information.
Arguments:
<DESCRIBE_PARTS>— Describe arguments: [DATABASE] [ENTITY_TYPE ENTITY_NAME]
Options:
--json— Output the schema in JSON format. Currently required; in the future, omitting this will give human-readable output.--anonymous— Perform this action with an anonymous identity-s,--server <SERVER>— The nickname, host name or URL of the server hosting the database-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).--no-config— Ignore spacetime.json configuration
spacetime dev
Start development mode with auto-regenerate client module bindings, auto-rebuild, and auto-publish on file changes.
Usage: spacetime dev [OPTIONS] [database]
Arguments:
<DATABASE>— The database name/identity to publish to (optional, will prompt if not provided)
Options:
-
--project-path <PROJECT-PATH>— The path to the project directoryDefault value:
. -
--module-bindings-path <MODULE-BINDINGS-PATH>— The path to the module bindings directory relative to the project directory, defaults to<project-path>/src/module_bindingsDefault value:
src/module_bindings -
--module-path <MODULE-PATH>— Path to the SpacetimeDB server module, relative to current directory. Defaults to<project-path>/spacetimedb. -
--client-lang <CLIENT-LANG>— The programming language for the generated client module bindings (e.g., typescript, csharp, python). If not specified, it will be detected from the project.Possible values:
csharp,typescript,rust,unrealcpp -
-s,--server <SERVER>— The nickname, host name or URL of the server to publish to -
-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com). -
-c,--delete-data <CLEAR-DATABASE>— When publishing to an existing database identity, first DESTROY all data associated with the module. With 'on-conflict': only when breaking schema changes occur.Possible values:
always,on-conflict,never -
-t,--template <TEMPLATE>— Template ID or GitHub repository (owner/repo or URL) for project initialization -
--run <COMMAND>— Command to run the client development server (overrides spacetime.json config) -
--server-only— Only run the server (module) without starting the client -
--no-config— Ignore spacetime.json configuration -
--env <ENV>— Environment name for config file layering (e.g., dev, staging). Defaults to 'dev'. -
--skip-publish— Skip the publish step -
--skip-generate— Skip the generate step
spacetime sql
Runs a SQL query on the database. WARNING: This command is UNSTABLE and subject to breaking changes.
Usage: spacetime sql [OPTIONS] [sql_parts]...
Arguments:
<SQL_PARTS>— SQL arguments: [DATABASE] <QUERY>
Options:
-
--interactive— Instead of using a query, run an interactive command prompt forSQLexpressions -
--confirmed <CONFIRMED>— Instruct the server to deliver only updates of confirmed transactionsPossible values:
true,false -
--anonymous— Perform this action with an anonymous identity -
-s,--server <SERVER>— The nickname, host name or URL of the server hosting the database -
-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com). -
--no-config— Ignore spacetime.json configuration
spacetime rename
Rename a database
Usage: spacetime rename [OPTIONS] --to <new-name> <database-identity>
Run spacetime rename --help for more detailed information.
Arguments:
<DATABASE-IDENTITY>— The database identity to rename
Options:
--to <NEW-NAME>— The new name you would like to assign-s,--server <SERVER>— The nickname, host name or URL of the server on which to set the name-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).
spacetime generate
Generate client files for a spacetime module.
Usage: spacetime generate [DATABASE] --lang <LANG> --out-dir <DIR> [--module-path <DIR> | --bin-path <PATH> | --unreal-module-name <MODULE_NAME> | --uproject-dir <DIR> | --include-private]
Run spacetime help generate for more detailed information.
Arguments:
<DATABASE>— Database name or glob pattern to filter which databases to generate for
Options:
-
-b,--bin-path <WASM_FILE>— The system path (absolute or relative) to the compiled wasm binary we should inspect -
-j,--js-path <JS_FILE>— The system path (absolute or relative) to the bundled javascript file we should inspect -
-p,--module-path <MODULE_PATH>— The system path (absolute or relative) to the module project. Defaults to spacetimedb/ subdirectory, then current directory. -
-o,--out-dir <OUT_DIR>— The system path (absolute or relative) to the generate output directory -
--uproject-dir <UPROJECT_DIR>— Path to the Unreal project directory, replaces --out-dir for Unreal generation (only used with --lang unrealcpp) -
--namespace <NAMESPACE>— The namespace that should be usedDefault value:
SpacetimeDB.Types -
--unreal-module-name <UNREAL_MODULE_NAME>— The module name that should be used for DLL export macros (required for lang unrealcpp) -
-l,--lang <LANG>— The language to generatePossible values:
csharp,typescript,rust,unrealcpp -
--build-options <BUILD_OPTIONS>— Options to pass to the build command, for example --build-options='--lint-dir='Default value: ``
-
--include-private— Include private tables and functions in generated code (types are always included).Default value:
false -
-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com). -
--no-config— Ignore spacetime.json configuration -
--env <ENV>— Environment name for config file layering (e.g., dev, staging)
spacetime list
Lists the databases attached to an identity. WARNING: This command is UNSTABLE and subject to breaking changes.
Usage: spacetime list [OPTIONS]
Options:
-s,--server <SERVER>— The nickname, host name or URL of the server from which to list databases-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).
spacetime login
Manage your login to the SpacetimeDB CLI
Usage: spacetime login [OPTIONS] login \<COMMAND\>
Subcommands:
show— Show the current login info
Options:
-
--auth-host <AUTH-HOST>— Fetch login token from a different hostDefault value:
https://spacetimedb.com -
--server-issued-login <SERVER>— Log in to a SpacetimeDB server directly, without going through a global auth server -
--token <SPACETIMEDB-TOKEN>— Bypass the login flow and use a login token directly -
--no-browser— Do not open a browser window
spacetime login show
Show the current login info
Usage: spacetime login show [OPTIONS]
Options:
--token— Also show the auth token
spacetime logout
Usage: spacetime logout [OPTIONS]
Options:
-
--auth-host <AUTH-HOST>— Log out from a custom auth serverDefault value:
https://spacetimedb.com
spacetime init
Initializes a new spacetime project.
Usage: spacetime init [OPTIONS] [PROJECT_NAME]
Arguments:
<PROJECT_NAME>— Project name
Options:
--project-path <PATH>— Directory where the project will be created (defaults to./<PROJECT_NAME>)--server-only— Initialize server only from the template (no client)--lang <LANG>— Server language: rust, csharp, typescript, cpp (it can only be used when --template is not specified)-t,--template <TEMPLATE>— Template ID or GitHub repository (owner/repo or URL)--local— Use local deployment instead of Maincloud--non-interactive— Run in non-interactive mode
spacetime build
Builds a spacetime module.
Usage: spacetime build [OPTIONS]
Options:
-
-p,--module-path <MODULE_PATH>— The system path (absolute or relative) to the module project. Defaults to spacetimedb/ subdirectory, then current directory. -
--lint-dir <LINT_DIR>— The directory to lint for nonfunctional print statements. If set to the empty string, skips linting.Default value:
src -
-d,--debug— Builds the module using debug instead of release (intended to speed up local iteration, not recommended for CI)
spacetime server
Manage the connection to the SpacetimeDB server. WARNING: This command is UNSTABLE and subject to breaking changes.
Usage: spacetime server server \<COMMAND\>
Subcommands:
list— List stored server configurationsset-default— Set the default server for future operationsadd— Add a new server configurationremove— Remove a saved server configurationfingerprint— Show or update a saved server's fingerprintping— Checks to see if a SpacetimeDB host is onlineedit— Update a saved server's nickname, host name or protocolclear— Deletes all data from all local databases
spacetime server list
List stored server configurations
Usage: spacetime server list
spacetime server set-default
Set the default server for future operations
Usage: spacetime server set-default <server>
Arguments:
<SERVER>— The nickname, host name or URL of the new default server
spacetime server add
Add a new server configuration
Usage: spacetime server add [OPTIONS] --url <url> <name>
Arguments:
<NAME>— Nickname for this server
Options:
--url <URL>— The URL of the server to add-d,--default— Make the new server the default server for future operations--no-fingerprint— Skip fingerprinting the server
spacetime server remove
Remove a saved server configuration
Usage: spacetime server remove [OPTIONS] <server>
Arguments:
<SERVER>— The nickname, host name or URL of the server to remove
Options:
-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).
spacetime server fingerprint
Show or update a saved server's fingerprint
Usage: spacetime server fingerprint [OPTIONS] <server>
Arguments:
<SERVER>— The nickname, host name or URL of the server
Options:
-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).
spacetime server ping
Checks to see if a SpacetimeDB host is online
Usage: spacetime server ping <server>
Arguments:
<SERVER>— The nickname, host name or URL of the server to ping
spacetime server edit
Update a saved server's nickname, host name or protocol
Usage: spacetime server edit [OPTIONS] <server>
Arguments:
<SERVER>— The nickname, host name or URL of the server
Options:
--new-name <NICKNAME>— A new nickname to assign the server configuration--url <URL>— A new URL to assign the server configuration--no-fingerprint— Skip fingerprinting the server-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).
spacetime server clear
Deletes all data from all local databases
Usage: spacetime server clear [OPTIONS]
Options:
--data-dir <DATA_DIR>— The path to the server data directory to clear [default: that of the selected spacetime instance]-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com).
spacetime subscribe
Subscribe to SQL queries on the database. WARNING: This command is UNSTABLE and subject to breaking changes.
Usage: spacetime subscribe [OPTIONS] [subscribe_parts]...
Arguments:
<SUBSCRIBE_PARTS>— Subscribe arguments: [DATABASE] <QUERY> [QUERY...]
Options:
-
-n,--num-updates <NUM-UPDATES>— The number of subscription updates to receive before exiting -
-t,--timeout <TIMEOUT>— The timeout, in seconds, after which to disconnect and stop receiving subscription messages. If-nis specified, it will stop after whichever one comes first. -
--print-initial-update— Print the initial update for the queries. -
--confirmed <CONFIRMED>— Instruct the server to deliver only updates of confirmed transactionsPossible values:
true,false -
--anonymous— Perform this action with an anonymous identity -
-y,--yes— Run non-interactively wherever possible. This will answer "yes" to almost all prompts, but will sometimes answer "no" to preserve non-interactivity (e.g. when prompting whether to log in with spacetimedb.com). -
--no-config— Ignore spacetime.json configuration -
-s,--server <SERVER>— The nickname, host name or URL of the server hosting the database
spacetime start
Start a local SpacetimeDB instance
Run spacetime start --help to see all options.
Usage: spacetime start [OPTIONS] [args]...
Arguments:
<ARGS>— The args to pass tospacetimedb-{edition} start
Options:
-
--edition <EDITION>— The edition of SpacetimeDB to start upDefault value:
standalonePossible values:
standalone,cloud
spacetime version
Manage installed spacetime versions
Run spacetime version --help to see all options.
Usage: spacetime version [ARGS]...
Arguments:
<ARGS>— The args to pass to spacetimedb-update
This document was generated automatically by
clap-markdown.