Command Line Interface¶
felis¶
Felis command line tools
felis [OPTIONS] COMMAND [ARGS]...
Options
- --version¶
Show the version and exit.
- --log-level <log_level>¶
Felis log level
- Options:
CRITICAL | FATAL | ERROR | WARNING | INFO | DEBUG
- --log-file <log_file>¶
Felis log file path
- --id-generation¶
Generate IDs for all objects that do not have them
Environment variables
- FELIS_LOGLEVEL
Provide a default for
--log-level
- FELIS_LOGFILE
Provide a default for
--log-file
create¶
Create database objects from the Felis file
felis create [OPTIONS] FILE
Options
- --engine-url <engine_url>¶
SQLAlchemy Engine URL
- --schema-name <schema_name>¶
Alternate schema name to override Felis file
- --initialize¶
Create the schema in the database if it does not exist (error if already exists)
- --drop¶
Drop schema if it already exists in the database (implies –initialize)
- --echo¶
Echo database commands as they are executed
- --dry-run¶
Dry run only to print out commands instead of executing
- -o, --output-file <output_file>¶
Write SQL commands to a file instead of executing
- --ignore-constraints¶
Ignore constraints when creating tables
Arguments
- FILE¶
Required argument
Environment variables
- FELIS_ENGINE_URL
Provide a default for
--engine-url
diff¶
Compare two schemas or a schema and a database for changes
Examples:
felis diff schema1.yaml schema2.yaml
felis diff -c alembic schema1.yaml schema2.yaml
felis diff –engine-url sqlite:///test.db schema.yaml
felis diff [OPTIONS] [FILES]...
Options
- --engine-url <engine_url>¶
SQLAlchemy Engine URL
- -c, --comparator <comparator>¶
Comparator to use for schema comparison
- Options:
alembic | deepdiff
- -E, --error-on-change¶
Exit with error code if schemas are different
Arguments
- FILES¶
Optional argument(s)
Environment variables
- FELIS_ENGINE_URL
Provide a default for
--engine-url
init-tap¶
Initialize TAP_SCHEMA objects in the database
felis init-tap [OPTIONS] ENGINE_URL
Options
- --tap-schema-name <tap_schema_name>¶
Alternate database schema name for ‘TAP_SCHEMA’
- --tap-schemas-table <tap_schemas_table>¶
Alternate table name for ‘schemas’
- --tap-tables-table <tap_tables_table>¶
Alternate table name for ‘tables’
- --tap-columns-table <tap_columns_table>¶
Alternate table name for ‘columns’
- --tap-keys-table <tap_keys_table>¶
Alternate table name for ‘keys’
- --tap-key-columns-table <tap_key_columns_table>¶
Alternate table name for ‘key_columns’
Arguments
- ENGINE_URL¶
Required argument
load-tap¶
Load metadata from a Felis file into a TAP_SCHEMA database
felis load-tap [OPTIONS] FILE
Options
- --engine-url <engine_url>¶
SQLAlchemy Engine URL
- --schema-name <schema_name>¶
Alternate Schema Name for Felis file
- --catalog-name <catalog_name>¶
Catalog Name for Schema
- --dry-run¶
Dry Run Only. Prints out the DDL that would be executed
- --tap-schema-name <tap_schema_name>¶
Alternate schema name for ‘TAP_SCHEMA’
- --tap-tables-postfix <tap_tables_postfix>¶
Postfix for TAP_SCHEMA table names
- --tap-schemas-table <tap_schemas_table>¶
Alternate table name for ‘schemas’
- --tap-tables-table <tap_tables_table>¶
Alternate table name for ‘tables’
- --tap-columns-table <tap_columns_table>¶
Alternate table name for ‘columns’
- --tap-keys-table <tap_keys_table>¶
Alternate table name for ‘keys’
- --tap-key-columns-table <tap_key_columns_table>¶
Alternate table name for ‘key_columns’
- --tap-schema-index <tap_schema_index>¶
TAP_SCHEMA index of the schema in this environment
Arguments
- FILE¶
Required argument
Environment variables
- FELIS_ENGINE_URL
Provide a default for
--engine-url
load-tap-schema¶
Load metadata from a Felis file into a TAP_SCHEMA database
felis load-tap-schema [OPTIONS] FILE
Options
- --engine-url <engine_url>¶
SQLAlchemy Engine URL
- --tap-schema-name <tap_schema_name>¶
Name of the TAP_SCHEMA schema in the database
- --tap-tables-postfix <tap_tables_postfix>¶
Postfix which is applied to standard TAP_SCHEMA table names
- --tap-schema-index <tap_schema_index>¶
TAP_SCHEMA index of the schema in this environment
- --dry-run¶
Execute dry run only. Does not insert any data.
- --echo¶
Print out the generated insert statements to stdout
- --output-file <output_file>¶
Write SQL commands to a file
Arguments
- FILE¶
Required argument
Environment variables
- FELIS_ENGINE_URL
Provide a default for
--engine-url
validate¶
Validate one or more Felis YAML files
felis validate [OPTIONS] [FILES]...
Options
- --check-description¶
Check that all objects have a description
- --check-redundant-datatypes¶
Check for redundant datatype overrides
- --check-tap-table-indexes¶
Check that every table has a unique TAP table index
- --check-tap-principal¶
Check that at least one column per table is flagged as TAP principal
Arguments
- FILES¶
Optional argument(s)