Alpha flags
Alpha flags are experimental features that are in an early testing phase and is likely to change or be removed without prior notice. Do not use the product or functionality in production systems.
The Cognite Toolkit uses alpha flags to enable experimental functionality that we often plan to support in the next minor release.
By default, alpha flags aren't enabled. To enable them, you must update the cdf.toml file. For example, to enable the module-repeat alpha flag,
add the following to your cdf.toml file:
[alpha_flags]
module-repeat = true
Cognite Toolkit versioning and releases
The Cognite Toolkit uses semantic versioning to manage versions as major, minor, and patch (for example, 0.3.17).
- 
A major version increases with breaking changes in the CLI or the format of modules and configuration files. Installing a new major toolkit version may require updating your configuration files or modules. 
- 
Minor versions increase with new features and patch versions with bug fixes. 
As long as the major version is 0, breaking changes may happen between minor versions.
The Cognite Toolkit follows a release cycle of alpha, beta, and stable releases, shown by 'a' and 'b' in the version number.
- Alpha releases (for example, 0.3.0a1) test new features, may contain breaking changes, and aren't recommended for production.
- Beta releases (0.3.0b1) focus on stability and bug fixes and are suitable for non-production testing.
- Stable releases (0.3.0) are production-ready.
Introducing new functionality in stable versions can lead to new bugs. Alpha flags allow you to selectively enable new functionality, minimizing the risk of introducing new bugs. The state of alpha flags vary, with some planned for future releases and others being experimental, requiring further testing.
Alpha flag: module-repeat
Status: experimental
[alpha_flags]
module-repeat = true
This flag enables you to deploy the same module multiple times, for example, if you have multiple locations that should all have the same module deployed.
To deploy the same module multiple times, you must define a list of variables in the config.[env].yaml file. For
example, if you have a module my_module with a data set resource:
./modules/
    └── my_module/
        └── data_sets/
            └── location.DataSet.yaml
./config.dev.yaml
The location.DataSet.yaml file looks like this:
- externalId: ds_{{ location }}_assets
  name: Dataset for assets on {{ location }}
  description: This is the dataset for all assets on {{ location }}
In the config.dev.yaml file, define a list under the my_module key:
environment: ...
variables:
  modules:
    to_repeat:
      - location: oslo
      - location: new_york
This creates two data sets, one for Oslo and one for New York.
In the build directory, you'll get these two files:
- externalId: ds_oslo_assets
  name: Dataset for assets on oslo
  description: This is the dataset for all assets on oslo
- externalId: ds_new_york_assets
  name: Dataset for assets on new_york
  description: This is the dataset for all assets on new_york
Alpha flag: import-cmd
Status: experimental
[alpha_flags]
import-cmd = true
This flag enables the cdf import command. The only subcommand available is transformation-cli. The command
converts the transformation-cli manifest files to the Cognite API (Toolkit) format. Use this, for example, if you have
transformations managed by the transformation-cli and want to convert them to the Cognite Toolkit format.
Alpha flag: infield
Status: Planned for 0.6.0
Available from: 0.5.10
[alpha_flags]
infield = true
This flag enables the infield configuration resource. See cdf.toml
for more information about the infield configuration resource.
Alpha flag: populate
Status: Will be removed in 0.7.0 - replaced by cdf upload.
Available from: 0.4.7
[alpha_flags]
populate = true
This flag enables the cdf populate command. This command lets you populate a view from a CSV or Parquet file.
For more information, enable the flag and run cdf populate --help to see the available options.
Alpha flag: exit-on-warning
Status: planned for 0.6.0
Available from: 0.5.31
[alpha_flags]
exit-on-warning = true
This flag enables the --exit-non-zero-on-warning option in the cdf build command. This will raise an error if
the build has any warnings. The intended use case is when running the Cognite Toolkit in a CI/CD pipeline.
Alpha flag: migrate
Status: experimental
Available from: 0.5.45
[alpha_flags]
migrate = true
This flag enables the cdf migrate command. This command migrates asset-centric resources to data modeling. This
is currently an experimental feature and isn't recommended for production use.
Alpha flag: dump-data
Status: Will be removed in 0.7.0 - replaced by cdf download.
Available from: 0.4.7
[alpha_flags]
dump-data = true
This flag splits the cdf dump command into cdf dump config and cdf dump data. The cdf dump data command lets you
dump Assets, TimeSeries, Events, and Files to CSV or Parquet files. For more information, enable the flag and run
cdf dump data --help to see the available options.
Alpha flag: dump-extended
Status: planned for 0.7.0
Available from: 0.5.41
[alpha_flags]
dump-extended = true
Extends the cdf dump command with support for dumping LocationFilter, Instance Space, SearchConfig,
DataSets, Agents, Functions and ExtractionPiplines resource, as well as Streamlit applications.
Alpha flag: profile
Status: experimental
Available from: 0.5.27
[alpha_flags]
profile = true
This flag enables the cdf profile command. This command allows you to profile CDF resources and their dependencies.
Use the cdf profile --help command to see the available options. Note that this command is currently in development and
will change in future releases.
Alpha flag: agents
Status: planned for 0.7.0
Available from: 0.5.7
Recommended version: 0.5.85 or later. This version includes fixes for the agents resource.
[alpha_flags]
agents = true
This flag enables the agent configuration resource. This resource allows you to define agents in your CDF project.
Alpha flag: search-config
Status: planned for 0.7.0
Available from: 0.6.26
[alpha_flags]
search-config = true
This flag enables the SearchConfig resource, which allows you to define configurations for the search application.
The YAML Reference Library has more information about the SearchConfig resource.
Alpha flag: purge-instances
Status: planned for 0.7.0
Available from: 0.6.28
[alpha_flags]
purge-instances = true
This flag enables the command cdf purge instances which allows you to purge instance from your CDF project.
The command includes unlinking which means that timeseries and files that have been migrated to instances,
can be unlinked from the instances before deletion. This will preserve the timeseries and files in CDF,
but remove the instance association. The command also includes dry-run which shows what instances would be
purged without actually performing the purge.
Alpha flags: upload and download
Status: planned for 0.7.0
Available from: 0.6.7 and 0.6.9
[alpha_flags]
upload = true
download = true
These flags enable the cdf upload and cdf download commands. These two commands allow you to upload
and download data from CDF. Initially only RAW tables are supported, but more resources will be addded
(assets, timeseries, events, file metadata, sequences, instances) in future releases. Use the --help flag
to see the available options.