-
Notifications
You must be signed in to change notification settings - Fork 4.2k
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
change-resource-record-sets uses only record name and type as unique key but requires full details when deleting #8241
Comments
Hi @sdrabblescripta, thanks for reaching out. Could you clarify the inconsistency here? Right now, it looks like both |
Hi @RyanFitzSimmonsAK thanks for responding, but that's exactly my issue. The error from UPSERTing a record (changing the target and other params) is:
implying only the name and type are used for the key, however since both delete and the update side of an upsert fail unless the existing parameters are provided kinda puts the lie to that statement. Plus, if i can't actually update a record (change target e.g.) what's the point of an UPSERT? it should really just be an INSERT. |
Using the sample code that you provided, I was able to change the target alias of a latency-based record. What is the routing policy of your alias record? Also, could you provide debug logs? You can get debug logs by adding |
The | a non-latency RRSet with the same name and type already exists. (or this, from a DELETE op): | Tried to delete resource record set [name='foo.bar.com.', type='A'] but it was not found ? |
No, I don't think so. The documentation for ChangeResourceRecordSets even specifies "To delete a resource record set, you must specify all the same values that you specified when you created it." Those statements are suggesting that you're trying to create a latency record with the same name and type as an existing non-latency record. I'd double check that the record you are trying to modify is actually a latency record, and that all the other details are correct. Do you have any other records with the same name? |
Thanks again. Maybe I'm just too dumb to understand but if I have to provide all details when deleting how can an upsert work? What exactly is being updated if the key is "all fields" ? As far as the update I'm attempting goes, there's exactly one record matching (name, type). If I change the type as part of the upsert, there will be no records matching and so this should be considered an insert, no? |
Name + type is sufficient to identify a unique record, but you still need to provide other details because they would be required in the event the record does not exist and needs to be created. For example, if you wanted to just update the
That is correct, as name + type identifies a unique record. Just make sure you're providing the correct parameters for whatever type of record you want to create. |
| Name + type is sufficient to identify a unique record Except when deleting, when I have to provide all details of the existing record. This is my issue. The behaviour is definitely not "name + type identifies a unique record" when deleting. If it were, I wouldn't have to provide the entire current record, which requires a separate request to retrieve that same record just to delete it. | if you wanted to just update the TTL of a simple routing record, you still need to provide ResourceRecords because it's needed for creating a record. But in the event the record doesn't need to be created, you seem to be saying "(name + type) + TTL" is enough to update the existing record.. but this is not the case either. TL;DR: there is no situation I have found where I can provide just the name + type for deleting, or the name + type + modified fields for upserting an existing (name + type) record. |
Name + type does identify a unique record, because Route53 does not allow you to have multiple records of the same name and type. However, the API is designed such that deleting a record requires more than that minimum amount of information. Considering that it is specifically called out in the documentation, I'd suspect it's a very purposeful decision. In the event that the record needs to be updated (not created), it still needs both |
Thanks for your response. Given that there's already a CREATE command - where I would expect to pass ALL details of the new record - there seems to be no use for an UPSERT since it expects the same values, meaning a change is always treated as a create until the last possible moment. I found a different path to achieve my goals (DELETE + CREATE) however so this is not such a big issue for me at this time. As to: | Considering that it is specifically called out in the documentation, I'd suspect it's a very purposeful decision Purposeful or not, the behaviour is inconsistent with declaring a unique key as the fields (name + type). Requiring ALL details be provided to delete an existing record is akin to saying (in python, or any other similar language) deleting a key from a dict requires the value be passed as well, which is.. uncommon to say the least. The doc states "name + key identifies a record uniquely" and then does not clearly indicate that the API flies in the face of this by requiring additional fields to uniquely identify a record for deletion; I believe that should be called out much more strongly. That said, I think we're reached the point where there is no further value to be gained from continuing this discussion. While I think the docs could be clearer (or the API actually changed to make sense :) ) I truly value your input and am grateful for your perspective. |
|
Describe the bug
I attempt to UPSERT a record to change where it points:
AWS complains:
Fair enough, it uses name + type to identify the record... except:
Having to look up the existing values just to stuff them into the DELETE change is a waste of time and other resources. Either (name+type) refers to a unique record, or it doesn't, and in the latter case I should therefore not have to provide the other specific record details when deleting. In the former case, an UPSERT should cause the unique record to be updated, as per the docs:
| UPSERT : If a resource set doesn’t exist, Route 53 creates it. If a resource set exists Route 53 updates it with the values in the request.
Expected Behavior
I expect one of the following:
Current Behavior
See above.
Reproduction Steps
See above.
Possible Solution
Allow me to UPSERT a record using name+type as the key.
Additional Information/Context
No response
CLI version used
aws-cli/2.13.26 Python/3.11.6 Linux/5.15.49-linuxkit exe/aarch64.debian.11 prompt/off
Environment details (OS name and version, etc.)
Linux f6a3cbd6774c 5.15.49-linuxkit #1 SMP PREEMPT Tue Sep 13 07:51:32 UTC 2022 aarch64 GNU/Linux
The text was updated successfully, but these errors were encountered: