Configuration Deprecations in v0.5
We introduced a number of configuration deprecations in Consul-Terraform-Sync (CTS) v0.5. Many of these deprecations are part of an effort to streamline CTS task configuration and reduce the inconsistencies. As CTS support for more use-cases increased, inconsistencies arose and required a lot of documentation to explain.
This documentation outlines the deprecations and examples on how to upgrade your configuration for v0.5. The deprecated configurations will not be removed until v0.8 and later. We plan to also release a tool to automate upgrading your configurations to make the upgrade quicker and smoother.
The deprecations address two major inconsistencies. First is the use of the terminology “source” in various configuration blocks and fields. The second is the exception to configuring a task condition or a task module input by using the services
field and its related service
block.
The word “source” is used in the name of a number of task configurations. “Source” in the configuration name commonly refers to the Terraform module though it is not immediately clear and requires additional documentation to explain.
We deprecated all configuration with the term “source” and replaced it with “module” in the task configuration:
Removal date:
- source: future major release after v0.8
- : v0.8
- source_includes_var: v0.8
The documentation below will refer to the deprecated configurations by their new name.
Address services
field and service
block
The services
field and its associated service
block are frequently an exception to task configuration use-cases and add complexity and restrictions.
The services
field is the only task condition that is not configured through the condition
block. It is also the only additional module input that is not configured through a module_input
block. This leads to a lot of inconsistent relationships with other condition
and module_input
blocks.
We deprecated the services
field and its associated service
filter to remove these exceptions and complicated relationship with other condition
and module_input
blocks:
Deprecated Config | Replacement Config | Description |
---|---|---|
services field | condition “services” or module_input “services” block | The services to provide module input and occasionally act as the task condition |
service block | fields moved into the condition “services” and module_input “services” block | The configuration block to provide additional filtering on the services in the services field |
The services
field and its associated service
block will be removed in a future major release after v0.8.
Further Details on Deprecations
The source
field in the task configuration is deprecated and can be directly renamed to module
.
Example:
Deprecate source field
Deprecate source field
Deprecated
- Deprecated
- New
task {
name = "services_task"
services = ["api", "web"]
source = "path/to/module"
}
task {
name = "services_task"
services = ["api", "web"]
module = "path/to/module"
}
task {
name = "services_task"
services = ["api", "web"]
module = "path/to/module"
}
Deprecate source_input
block
The source_input
block in the task configuration is deprecated and can be directly renamed to module_input
.
Example:
Deprecate source_input block
Deprecated
- Deprecated
- New
task {
name = "scheduled_task"
module = "path/to/module"
condition "schedule" {
cron = "* * * * Mon"
}
source_input "consul-kv" {
path = "my_key"
}
}
task {
name = "scheduled_task"
module = "path/to/module"
condition "schedule" {
cron = "* * * * Mon"
}
source_input "consul-kv" {
path = "my_key"
}
}
task {
name = "scheduled_task"
module = "path/to/module"
condition "schedule" {
cron = "* * * * Mon"
}
module_input "consul-kv" {
path = "my_key"
}
}
task {
name = "scheduled_task"
module = "path/to/module"
condition "schedule" {
cron = "* * * * Mon"
}
module_input "consul-kv" {
path = "my_key"
}
}
The block’s source_includes_var
field is deprecated for all types of conditions and can be directly renamed to use_as_module_input
.
Example:
Deprecate source_includes_var field
Deprecate source_includes_var field
Deprecated
- Deprecated
- New
task {
name = "catalog_services_task"
module = "path/to/module"
condition "catalog-services" {
regexp = "api"
source_includes_var = true
}
}
task {
name = "catalog_services_task"
condition "catalog-services" {
regexp = "api"
use_as_module_input = true
}
}
task {
name = "catalog_services_task"
module = "path/to/module"
condition "catalog-services" {
regexp = "api"
use_as_module_input = true
}
}
Deprecate services
field
The services
field can play different roles in a task depending on other task configurations:
- When no
condition
block is configured, then theservices
field is the task’s condition and module input - When there is a
condition
block configured, then the `services field is only module input for the task
The services
field can be replaced depending on the role it has for the task.
Deprecate services
field as a condition
When the services
field behaves as a condition, it can be replaced with a condition "services"
block with the names
field set to the list of the services.
Example:
Deprecate services field as a condition
Deprecate services field as a condition
Deprecated
- Deprecated
- New
task {
name = "services_condition_task"
module = "path/to/module"
services = ["api", "web"]
}
task {
name = "services_condition_task"
module = "path/to/module"
services = ["api", "web"]
}
task {
name = "services_condition_task"
module = "path/to/module"
condition "services" {
names = ["api", "web"]
}
}
task {
name = "services_condition_task"
module = "path/to/module"
condition "services" {
names = ["api", "web"]
}
}
Deprecate services
field as module input only
Example:
Deprecate services field as a module input
Deprecate services field as a module input
Deprecated
- Deprecated
- New
task {
name = "services_module_input_task"
module = "path/to/module"
condition "consul-kv" {
path = "my_key"
source_includes_var = true
}
services = ["api", "web"]
}
task {
name = "services_module_input_task"
module = "path/to/module"
condition "consul-kv" {
path = "my_key"
source_includes_var = true
}
services = ["api", "web"]
}
task {
name = "services_module_input_task"
module = "path/to/module"
condition "consul-kv" {
path = "my_key"
use_as_module_input = true
}
module_input "services" {
names = ["api", "web"]
}
}
Note: use_as_module_input
was updated in v0.5 so that it will default to true
when unconfigured. In the new configuration, the line to set use_as_module_input = true
is no longer necessary
The service
block is a configuration block outside of the task block. The fields of the service
block provides additional filtering to any task that has that service set in the field.
Once the services
field is upgraded to a condition
or module_input
block, as described in the section above, the deprecated service
block’s fields can be moved to the new condition
or module_input
block.
Example:
Deprecate service block
Deprecate service block
Deprecated
- Deprecated
- New
task {
name = "services_filter_task"
module = "path/to/module"
condition "services" {
names = ["api"]
}
}
service {
datacenter = "dc2"
namespace = "ns"
}
task {
name = "services_filter_task"
module = "path/to/module"
condition "services" {
names = ["api"]
}
}
service {
name = "api"
datacenter = "dc2"
namespace = "ns"
}
task {
name = "services_filter_task"
module = "path/to/module"
condition "services" {
names = ["api"]
datacenter = "dc2"
namespace = "ns"
}
}
task {
name = "services_filter_task"
module = "path/to/module"
condition "services" {
names = ["api"]
datacenter = "dc2"
namespace = "ns"
}
}
There is an edge-case that requires a more complicated deprecation upgrade. Some tasks may have multiple services in the services
field and a service
block configured for each of those services. When the fields are different across the service
blocks, it is necessary to split the task and create new, separate tasks for each service.
Example:
Deprecate service block edge-case
Deprecate service block edge-case
Deprecated
- Deprecated
- New
task {
name = "services_task"
module = "path/to/module"
services = ["api", "web"]
}
service {
name = "api"
datacenter = "api_dc"
}
service {
name = "web"
datacenter = "web_dc"
}
task {
name = "services_task"
module = "path/to/module"
services = ["api", "web"]
}
service {
name = "api"
datacenter = "api_dc"
}
service {
name = "web"
datacenter = "web_dc"
}
task {
name = "api_services_task"
module = "path/to/module"
condition "services" {
names = ["api"]
datacenter = "api_dc"
}
}
task {
name = "web_services_task"
module = "path/to/module"
condition "services" {
names = ["web"]
datacenter = "web_dc"
}