dg cli configuration
Dagster Components is currently in Release Candidate status. APIs are stable, with broader integration coverage and full feature parity in active development and coming soon. Check it out and let us know what you think in the #dg-components channel in the Dagster Community Slack!
dg can be configured from both configuration files and the command line.
There are three kinds of settings:
- Application-level settings configure the dgapplication as a whole. They can be set in configuration files or on the command line, where they are listed as "global options" in thedg --helptext.
- Project-level settings configure a dgproject. They can only be set in the configuration file for a project.
- Workspace-level settings configure a dgworkspace. They can only be set in the configuration file for a workspace.
The application-level settings used in any given invocation of dg are the
result of merging settings from one or more configuration files and the command
line. The order of precedence is:
user config file < project/workspace config file < command line
Note that project and workspace config files are combined above. This is because, when projects are inside a workspace, application-level settings are sourced from the workspace configuration file and disallowed in the constituent project configuration files. In other words, application-level settings are only allowed in project configuration files if the project is not inside a workspace.
Configuration files
There are three kinds of dg configuration files: user, project, and workspace.
- User configuration files are optional and contain only application-level settings. They are located in a platform-specific location, ~/.config/dg.toml(Unix) or%APPDATA%/dg/dg.toml(Windows).
- Project configuration files are required to mark a directory as a dgproject. They are located in the root of adgproject and contain project-specific settings. They may also contain application-level settings if the project is not inside a workspace.
- Workspace configuration files are required to mark a directory as a dgworkspace. They are located in the root of adgworkspace and contain workspace-specific settings. They may also contain application-level settings. When projects are inside a workspace, the application-level settings of the workspace apply to all contained projects as well.
When dg is launched, it will attempt to discover all three configuration files by looking up the directory hierarchy from the CWD (and in the dedicated location for user configuration files). Many commands require a project or workspace to be in scope. If the corresponding configuration file is not found when launching such a command, dg will raise an error.
User configuration file
A user configuration file can be placed at ~/.config/dg.toml (Unix) or
%APPDATA%/dg/dg.toml (Windows).
Below is an example of a user configuration file. The cli section contains
application-level settings and is the only permitted section. The settings
listed in the below sample are comprehensive:
[cli]
# (bool, optional) Specifies whether to use verbose output.
# 
# Defaults to `false`.
verbose = false
# (list[str], optional) Specifies a list of warning IDs to suppress. Full list of warning IDs can be
# found here: https://github.com/dagster-io/dagster/blob/master/python_modules/libraries/dagster-dg-core/dagster_dg_core/utils/warnings.py
suppress_warnings = [
    "cli_config_in_workspace_project",
    "deprecated_user_config_location",
    "deprecated_python_environment",
    "deprecated_dagster_dg_library_entry_point",
    "missing_dg_plugin_module_in_manifest",
    "project_and_activated_venv_mismatch",
]
# Telemetry-related settings.
[cli.telemetry]
# (bool, optional) Specifies whether to enable telemetry.
# 
# Defaults to `true`.
enabled = true
# The `cli.plus` section is a replacement for `.dagster_cloud_cli.yaml`. The
# settings here are required to run `dg plus` commands.
[cli.plus]
# (string, optional) Your Dagster Plus organization, to run dg plus commands against.
#
# Defaults to None.
organization = "hooli"
# (string, optional) The default deployment to run commands against, if another
# deployment is not explicitly specified
#
# Defaults to None.
default_deployment = "prod"
# (optional, str) A Dagster Plus user token to authenticate to your organization
#
# Defaults to None.
user_token = "user:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
Project configuration file
A project configuration file is located in the root of a dg project. It may
either be a pyproject.toml file or a dg.toml file. If it is a
pyproject.toml, then all settings are nested under the tool.dg key. If it
is a dg.toml file, then settings should be placed at the top level. Usually
pyproject.toml is used for project configuration.
Below is an example of the dg-scoped part of a pyproject.toml (note all settings are part of tool.dg.* tables) for a project named my-project. The tool.dg.project section is a comprehensive list of supported settings:
[tool.dg]
# ("project", required) Marks this as a Dagster project.
directory_type = "project"
[tool.dg.project]
# (string, required) Specifies the root module of the project.
root_module = "my_project" # this is required
# (string, optional) Specifies the project submodule where new components and
# definitions are scaffolded.
#
# Defaults to `<root_module>.defs`.
defs_module = "my_project.defs"
# (string, optional) Specifies the project submodule containing the top-level `Definitions`
# object that is targeted when loading the project as a code location.
#
# Defaults to `<root_module>.definitions`.
code_location_target_module = "my_project.definitions"
# (string, optional) Specifies the name used for the code location when the project is
# loaded as a code location.
#
# Defaults to the project name (which is usually the # hyphenated variant of
# the root module name).
code_location_name = "my-project"
# (list[string], optional) List of module names or name-matching patterns to include in the dg
# registry. Defaults to `<root_module>.components`. Patterns can include `*` to match entire
# segments of the module name. * does NOT match partial segments. Example:
#
# - foo.*.bar matches foo.baz.bar and foo.qux.bar
# - foo.*bar is invalid because * does not constitute an entire segment
#
# When a new component is scaffolded with `dg scaffold component <module>.MyComponent`, this setting
# will be created if it does not already exist and the module will be added to the list.
# 
# Defaults to [].
registry_modules = [
  "my_project.alternate_components.*",
]
[tool.dg.cli]
# Application-level settings can be set here. See "User configuration file"
# section for a comprehensive list of available settings.
# If the project is inside a workspace, then this section is disallowed
# (`tool.dg.cli` should # be set in the workspace config instead).
Workspace configuration file
A workspace configuration file is located in the root of a dg workspace. It
may either be a pyproject.toml file or a dg.toml file. If it is a pyproject.toml,
then all settings are nested under the tool.dg key. If it is a dg.toml file,
then all settings are top-level keys. Usually dg.toml is used for workspace
configuration.
Below is an example of a dg.toml file for a workspace. The
workspace section is a comprehensive list of supported settings:
# ("workspace", required) Marks this as a Dagster workspace.
directory_type = "workspace"
[workspace]
# (array, required) Any projects in the workspace need to be listed as items in the
# `tool.dg.workspace.projects` array of tables.
#
# By default this array is empty.
[[workspace.projects]]
# (string, required) The path to the project relative to the workspace root.
path = "projects/project-1"
[[workspace.projects]]
# (string, required) The path to the project relative to the workspace root.
path = "projects/project-2"
[cli]
# Application-level settings can be set here. See "User configuration file"
# section for a comprehensive list of available settings.