-
Notifications
You must be signed in to change notification settings - Fork 9.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Default tags for all resources #7926
Comments
In general (with my limited knowledge on the provider specifics) this should be possible. The one tricky part would be any resources that have additions to the basic tag properties. The one I know that does this is the auto scaling group resources which in addition to a key and value also has a required property which determines whether the tags propagate to instances the ASG creates. So that should probably be taken into account when (if?) implementing this. |
@gwkunze sorry for the late reply, am currently on a long vacation, coming back next week and want to have a proper look at this then. I've never handled the terraform core nor written any plugins, but want to give this a try anyways as I'd love to have this feature. Is there anything else that you can think of that one would need to keep in mind when implementing this? I'm very confident that my TF knowledge is way more limited than yours haha :-) Thanks already for this suggestion! |
Alright, so I investigated this a little further and am pretty sure that I won't have the resources to tackle this. I have no prior experience with go, never contributed to this repo before and have not a whole lot of time. |
I'm really interested in this and might be able to put some time into it in the next couple of weeks. I was thinking a little bit on @gwkunze's comment about resources like ASG, and wanted to throw out a couple of potential syntax options.
There don't appear to be any other resources where this happens, so it's hard to generalize a decent syntax. But I lean towards #2 as the cleanest way to deal with the fact that Thoughts? |
In terms of tag propagation, there are other "AWS" resources where this is supported (though not sure how this is done in terraform):
|
@jonscheiding my first instinct is to prefer the first option to keep all that configuration together, but on the other hand, the auto-scaling group is just one exception and even there it has become less necessary as EC2 Launch Templates gives you more than enough to replace the need for the "propagateAtLaunch"-feature and using the regular tag syntax, ie:
if much nicer to read/write than
Even if you give extra properties a reasonable default. So on second though I think I prefer the second or third option. I can also suggest a potential slight alternative to the second option: specifying a list of tag-keys you want propagated, something like:
|
@gwkunze If I'm understanding you correctly, you're proposing we go from
to something like
I think I like that syntax better too, but I would shy away from undertaking a breaking schema change. |
I've been trying to wrap my head around the Terraform and AWS provider code to understand how this would be implemented. It seems like I would have to touch every resource [that supports tags] and probably add a AFAICT there is not any kind of like "provider-level Can anybody who understands this code better than me confirm that? |
@jonscheiding I meant going to that syntax only for the "default tag" functionality on the provider itself, not change the existing structure for auto scaling groups. So the change would be something like add a |
Hi, everyone! 👋 Thank you for your interest in this functionality. This would be awesome to have within the Terraform AWS Provider. I just wanted to drop a quick note in here that the maintainers are on board with thinking about this design and trying to develop this in a way that can be plugged into the existing provider codebase (e.g. per AWS service or resource) with community help if at all feasible. We would likely want to shy away from any large "all or nothing" changes because it will require large amounts of integration testing and hold up other development work within the provider codebase. Something to also consider here is the related, but opposite problem outlined in hashicorp/terraform#20866 where we could also have the ability to ignore a list of tags, per Terraform AWS Provider. From an operator perspective, the combined design would hopefully be fairly simple: # Design sketch - not currently implemented and design may change during development
provider "aws" {
# ... potentially other configuration ...
default_tags = {
Tag1 = "Value1"
Tag2 = "Value2"
# ...
}
ignore_tags = ["Tag3"]
} Then any resource could retrieve that information from the However as alluded to above, the underlying implementation work may potentially require some new functionality not currently available (or easily usable) in the Terraform Provider SDK and Terraform AWS Provider codebase. We're hoping to meet about this in the next week or two and can hopefully present more ideas or next steps on the manner. Ideally we would like to have clear documentation on how this can be implemented, documented, and tested so the work can be distributed for each resource when the design work is done. The |
While I'm not 100% certain about this, the I'm somewhat ambivalent about this change as it moves the terraform syntax further away from the raw API which could make it slightly more complex to learn. But on the other hand, consistency is important and it seems with the introduction of Launch Templates Amazon themselves are making "propagate_at_launch" superfluous. |
Hi, would it possible to use wildcards with Apparently using |
…eate Reference: #7926 In preparation for provider-wide ignore and default tag logic, here we refactor this resource to use the consistent keyvaluetags handling. The previous `setTags()` logic was always performing retries only necessary for resource creation and not following recommended practices to call the `Read` function after `Create`. Output from acceptance testing: ``` --- PASS: TestAccAWSVpc_disappears (16.21s) --- PASS: TestAccAWSVpc_coreMismatchedDiffs (23.55s) --- PASS: TestAccAWSVpc_DisabledDnsSupport (28.46s) --- PASS: TestAccAWSVpc_classiclinkOptionSet (28.64s) --- PASS: TestAccAWSVpc_bothDnsOptionsSet (28.66s) --- PASS: TestAccAWSVpc_classiclinkDnsSupportOptionSet (29.10s) --- PASS: TestAccAWSVpc_basic (29.31s) --- PASS: TestAccAWSVpc_update (40.02s) --- PASS: TestAccAWSVpc_tags (45.37s) --- PASS: TestAccAWSVpc_AssignGeneratedIpv6CidrBlock (62.90s) --- PASS: TestAccAWSVpc_Tenancy (62.94s) ```
Reference: #7926 Output from acceptance testing: ``` --- PASS: TestAccAWSEcrDataSource_ecrImage (13.77s) --- PASS: TestAccAWSEcrRepository_basic (14.42s) --- PASS: TestAccAWSEcrRepository_immutability (14.53s) --- PASS: TestAccAWSEcrDataSource_ecrRepository (16.21s) --- PASS: TestAccAWSEcrRepository_tags (20.90s) ```
…ad after Create Reference: #7926 Similar in nature to: #10315 In preparation for provider-wide ignore and default tag logic, here we refactor this resource to use the consistent `keyvaluetags` handling. The previous `setTags()` logic was always performing retries only necessary for resource creation and the resource itself was not following recommended practices to call the Read function after Create. Ouput from acceptance testing: ``` --- PASS: TestAccAWSSubnet_availabilityZoneId (25.22s) --- PASS: TestAccAWSSubnet_basic (25.66s) --- PASS: TestAccAWSSubnet_enableIpv6 (41.83s) --- PASS: TestAccAWSSubnet_ipv6 (66.62s) ```
Reference: #7926 In preparation for provider-wide ignore and default tag logic, here we refactor this resource to use the consistent `keyvaluetags` handling. Output from acceptance testing: ``` --- PASS: TestAccDataSourceAwsSubnet_basic (28.82s) --- PASS: TestAccDataSourceAwsSubnet_ipv6ByIpv6CidrBlock (46.06s) --- PASS: TestAccDataSourceAwsSubnet_ipv6ByIpv6Filter (46.30s) ```
Reference: #7926 In preparation for provider-wide ignore and default tag logic, here we refactor this resource to use the consistent `keyvaluetags` handling. Output from acceptance testing: ``` --- PASS: TestAccDataSourceAwsVpc_basic (27.54s) --- PASS: TestAccDataSourceAwsVpc_ipv6Associated (27.56s) --- PASS: TestAccDataSourceAwsVpc_multipleCidr (51.12s) ```
Reference: #7926 Creates a new `ignore_tags` provider configuration, that wires into the `AWSClient` struct provided to all provider resources. This can be used to ignore certain tag keys across all resources of the provider, once the resource implements support. Output from acceptance testing: ``` --- PASS: TestAccAWSProvider_IgnoreTags_One (3.70s) --- PASS: TestAccAWSProvider_IgnoreTags_Multiple (3.71s) --- PASS: TestAccAWSProvider_IgnoreTags_None (3.71s) ```
Reference: #7926 Output from acceptance testing: ``` --- PASS: TestAccAWSVpc_ignoreTags (31.81s) --- PASS: TestAccAWSVpc_tags (43.32s) ```
* provider: Support default tags (resources aws_r*) Reference: #7926 * docs/provider: Update tagging documentation (resources aws_r*)
* provider: Support default tags (resources aws_i*) Reference: #7926 * docs/provider: Update tagging documentation (resources aws_i*) * Update aws/resource_aws_iam_policy.go * provider: Add missing default tag Read functionality
* provider: Support default tags (resources aws_c*) Reference: #7926 * resource/aws_cloudwatch_composite_alarm: Add missing meta * docs/provider: Update tagging documentation (resources aws_c*) * resource/aws_cognito_user_pool: Ensure updates include default tags Output from acceptance testing: ``` --- PASS: TestAccAWSCognitoUserPool_basic (32.72s) --- PASS: TestAccAWSCognitoUserPool_disappears (23.07s) --- PASS: TestAccAWSCognitoUserPool_MfaConfiguration_SmsConfiguration (90.95s) --- PASS: TestAccAWSCognitoUserPool_MfaConfiguration_SmsConfigurationAndSoftwareTokenMfaConfiguration (81.96s) --- PASS: TestAccAWSCognitoUserPool_MfaConfiguration_SmsConfigurationToSoftwareTokenMfaConfiguration (52.93s) --- PASS: TestAccAWSCognitoUserPool_MfaConfiguration_SoftwareTokenMfaConfiguration (46.95s) --- PASS: TestAccAWSCognitoUserPool_MfaConfiguration_SoftwareTokenMfaConfigurationToSmsConfiguration (47.99s) --- PASS: TestAccAWSCognitoUserPool_recovery (49.48s) --- PASS: TestAccAWSCognitoUserPool_schemaAttributes (52.07s) --- PASS: TestAccAWSCognitoUserPool_schemaAttributesModified (32.71s) --- PASS: TestAccAWSCognitoUserPool_schemaAttributesRemoved (32.71s) --- PASS: TestAccAWSCognitoUserPool_SmsAuthenticationMessage (45.81s) --- PASS: TestAccAWSCognitoUserPool_SmsConfiguration (80.39s) --- PASS: TestAccAWSCognitoUserPool_SmsConfiguration_ExternalId (75.83s) --- PASS: TestAccAWSCognitoUserPool_SmsConfiguration_SnsCallerArn (73.17s) --- PASS: TestAccAWSCognitoUserPool_SmsVerificationMessage (53.22s) --- PASS: TestAccAWSCognitoUserPool_update (86.20s) --- PASS: TestAccAWSCognitoUserPool_withAdminCreateUserConfiguration (43.93s) --- PASS: TestAccAWSCognitoUserPool_withAdminCreateUserConfigurationAndPasswordPolicy (24.82s) --- PASS: TestAccAWSCognitoUserPool_withAdvancedSecurityMode (69.48s) --- PASS: TestAccAWSCognitoUserPool_withAliasAttributes (52.96s) --- PASS: TestAccAWSCognitoUserPool_withDeviceConfiguration (43.98s) --- PASS: TestAccAWSCognitoUserPool_withEmailConfiguration (28.09s) --- PASS: TestAccAWSCognitoUserPool_withEmailVerificationMessage (44.74s) --- PASS: TestAccAWSCognitoUserPool_withLambdaConfig (79.27s) --- PASS: TestAccAWSCognitoUserPool_withPasswordPolicy (53.72s) --- PASS: TestAccAWSCognitoUserPool_withTags (70.01s) --- PASS: TestAccAWSCognitoUserPool_withUsernameConfiguration (53.49s) --- PASS: TestAccAWSCognitoUserPool_withVerificationMessageTemplate (53.61s) --- SKIP: TestAccAWSCognitoUserPool_withEmailConfigurationSource (0.00s) ``` * provider: Add missing default tags handling
* provider: Support default tags (resources aws_d*) Reference: #7926 * docs/provider: Update tagging documentation (resources aws_d*) * resource/aws_dynamodb_table: Fix rebasing issues
* provider: Support default tags (resources aws_b*) Reference: #7926 * docs/provider: Update tagging documentation (resources aws_b*) * resource/aws_batch_job_definition: Fix rebase issue
* provider: Support default tags (resources aws_s*) Reference: #7926 * resource/aws_serverlessapplication_repository_cloudformation_stack: Add lintignore * Fix rebase issues
This has been released in version 3.38.0 of the Terraform AWS provider. Please see the Terraform documentation on provider versioning or reach out if you need any assistance upgrading. For further feature requests or bug reports with this functionality, please create a new GitHub issue following the template for triage. Thanks! |
I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues. |
Description
When creating service stacks on AWS with Terraform, I like to tag all resources of a project. Right now, this involves a lot of manual work.
I would like to set default tags with the provider, that then automatically get applied to all AWS resources that support it.
There has been an issue over on the main terraform repo (since 2015) which had plenty of 👍 and got closed in favor of creating issues with the respective providers. I couldn't find such an issue though, thus creating this one.
New or Affected Resource(s)
aws_*
Potential Terraform Configuration
References
Community Note
The text was updated successfully, but these errors were encountered: