Route53 - Update impl cov to show change_resource_record_sets (#4401)
This commit is contained in:
		
							parent
							
								
									5f6ca27bb8
								
							
						
					
					
						commit
						36e66d32b9
					
				| @ -3473,11 +3473,11 @@ | |||||||
| 
 | 
 | ||||||
| ## route53 | ## route53 | ||||||
| <details> | <details> | ||||||
| <summary>10% implemented</summary> | <summary>17% implemented</summary> | ||||||
| 
 | 
 | ||||||
| - [ ] activate_key_signing_key | - [ ] activate_key_signing_key | ||||||
| - [ ] associate_vpc_with_hosted_zone | - [ ] associate_vpc_with_hosted_zone | ||||||
| - [ ] change_resource_record_sets | - [X] change_resource_record_sets | ||||||
| - [X] change_tags_for_resource | - [X] change_tags_for_resource | ||||||
| - [X] create_health_check | - [X] create_health_check | ||||||
| - [X] create_hosted_zone | - [X] create_hosted_zone | ||||||
| @ -3519,9 +3519,9 @@ | |||||||
| - [ ] get_traffic_policy_instance | - [ ] get_traffic_policy_instance | ||||||
| - [ ] get_traffic_policy_instance_count | - [ ] get_traffic_policy_instance_count | ||||||
| - [ ] list_geo_locations | - [ ] list_geo_locations | ||||||
| - [ ] list_health_checks | - [X] list_health_checks | ||||||
| - [ ] list_hosted_zones | - [X] list_hosted_zones | ||||||
| - [ ] list_hosted_zones_by_name | - [X] list_hosted_zones_by_name | ||||||
| - [ ] list_hosted_zones_by_vpc | - [ ] list_hosted_zones_by_vpc | ||||||
| - [ ] list_query_logging_configs | - [ ] list_query_logging_configs | ||||||
| - [ ] list_resource_record_sets | - [ ] list_resource_record_sets | ||||||
|  | |||||||
| @ -407,14 +407,76 @@ class Route53Backend(BaseBackend): | |||||||
|             return self.resource_tags[resource_id] |             return self.resource_tags[resource_id] | ||||||
|         return {} |         return {} | ||||||
| 
 | 
 | ||||||
|     def get_all_hosted_zones(self): |     def change_resource_record_sets(self, the_zone, change_list): | ||||||
|  |         for value in change_list: | ||||||
|  |             action = value["Action"] | ||||||
|  |             record_set = value["ResourceRecordSet"] | ||||||
|  | 
 | ||||||
|  |             cleaned_record_name = record_set["Name"].strip(".") | ||||||
|  |             cleaned_hosted_zone_name = the_zone.name.strip(".") | ||||||
|  | 
 | ||||||
|  |             if not cleaned_record_name.endswith(cleaned_hosted_zone_name): | ||||||
|  |                 error_msg = """ | ||||||
|  |                 An error occurred (InvalidChangeBatch) when calling the ChangeResourceRecordSets operation: | ||||||
|  |                 RRSet with DNS name %s is not permitted in zone %s | ||||||
|  |                 """ % ( | ||||||
|  |                     record_set["Name"], | ||||||
|  |                     the_zone.name, | ||||||
|  |                 ) | ||||||
|  |                 return error_msg | ||||||
|  | 
 | ||||||
|  |             if not record_set["Name"].endswith("."): | ||||||
|  |                 record_set["Name"] += "." | ||||||
|  | 
 | ||||||
|  |             if action in ("CREATE", "UPSERT"): | ||||||
|  |                 if "ResourceRecords" in record_set: | ||||||
|  |                     resource_records = list(record_set["ResourceRecords"].values())[0] | ||||||
|  |                     if not isinstance(resource_records, list): | ||||||
|  |                         # Depending on how many records there are, this may | ||||||
|  |                         # or may not be a list | ||||||
|  |                         resource_records = [resource_records] | ||||||
|  |                     record_set["ResourceRecords"] = [ | ||||||
|  |                         x["Value"] for x in resource_records | ||||||
|  |                     ] | ||||||
|  |                 if action == "CREATE": | ||||||
|  |                     the_zone.add_rrset(record_set) | ||||||
|  |                 else: | ||||||
|  |                     the_zone.upsert_rrset(record_set) | ||||||
|  |             elif action == "DELETE": | ||||||
|  |                 if "SetIdentifier" in record_set: | ||||||
|  |                     the_zone.delete_rrset_by_id(record_set["SetIdentifier"]) | ||||||
|  |                 else: | ||||||
|  |                     the_zone.delete_rrset(record_set) | ||||||
|  |         return None | ||||||
|  | 
 | ||||||
|  |     def list_hosted_zones(self): | ||||||
|         return self.zones.values() |         return self.zones.values() | ||||||
| 
 | 
 | ||||||
|  |     def list_hosted_zones_by_name(self, dnsname): | ||||||
|  |         if dnsname: | ||||||
|  |             dnsname = dnsname[0] | ||||||
|  |             if dnsname[-1] != ".": | ||||||
|  |                 dnsname += "." | ||||||
|  |             zones = [zone for zone in self.list_hosted_zones() if zone.name == dnsname] | ||||||
|  |         else: | ||||||
|  |             # sort by names, but with domain components reversed | ||||||
|  |             # see http://boto3.readthedocs.io/en/latest/reference/services/route53.html#Route53.Client.list_hosted_zones_by_name | ||||||
|  | 
 | ||||||
|  |             def sort_key(zone): | ||||||
|  |                 domains = zone.name.split(".") | ||||||
|  |                 if domains[-1] == "": | ||||||
|  |                     domains = domains[-1:] + domains[:-1] | ||||||
|  |                 return ".".join(reversed(domains)) | ||||||
|  | 
 | ||||||
|  |             zones = self.list_hosted_zones() | ||||||
|  |             zones = sorted(zones, key=sort_key) | ||||||
|  |         return dnsname, zones | ||||||
|  | 
 | ||||||
|     def get_hosted_zone(self, id_): |     def get_hosted_zone(self, id_): | ||||||
|         return self.zones.get(id_.replace("/hostedzone/", "")) |         return self.zones.get(id_.replace("/hostedzone/", "")) | ||||||
| 
 | 
 | ||||||
|     def get_hosted_zone_by_name(self, name): |     def get_hosted_zone_by_name(self, name): | ||||||
|         for zone in self.get_all_hosted_zones(): |         for zone in self.list_hosted_zones(): | ||||||
|             if zone.name == name: |             if zone.name == name: | ||||||
|                 return zone |                 return zone | ||||||
| 
 | 
 | ||||||
| @ -427,7 +489,7 @@ class Route53Backend(BaseBackend): | |||||||
|         self.health_checks[health_check_id] = health_check |         self.health_checks[health_check_id] = health_check | ||||||
|         return health_check |         return health_check | ||||||
| 
 | 
 | ||||||
|     def get_health_checks(self): |     def list_health_checks(self): | ||||||
|         return self.health_checks.values() |         return self.health_checks.values() | ||||||
| 
 | 
 | ||||||
|     def delete_health_check(self, health_check_id): |     def delete_health_check(self, health_check_id): | ||||||
|  | |||||||
| @ -44,7 +44,7 @@ class Route53(BaseResponse): | |||||||
|             return 201, headers, template.render(zone=new_zone) |             return 201, headers, template.render(zone=new_zone) | ||||||
| 
 | 
 | ||||||
|         elif request.method == "GET": |         elif request.method == "GET": | ||||||
|             all_zones = route53_backend.get_all_hosted_zones() |             all_zones = route53_backend.list_hosted_zones() | ||||||
|             template = Template(LIST_HOSTED_ZONES_RESPONSE) |             template = Template(LIST_HOSTED_ZONES_RESPONSE) | ||||||
|             return 200, headers, template.render(zones=all_zones) |             return 200, headers, template.render(zones=all_zones) | ||||||
| 
 | 
 | ||||||
| @ -54,27 +54,7 @@ class Route53(BaseResponse): | |||||||
|         query_params = parse_qs(parsed_url.query) |         query_params = parse_qs(parsed_url.query) | ||||||
|         dnsname = query_params.get("dnsname") |         dnsname = query_params.get("dnsname") | ||||||
| 
 | 
 | ||||||
|         if dnsname: |         dnsname, zones = route53_backend.list_hosted_zones_by_name(dnsname) | ||||||
|             dnsname = dnsname[0] |  | ||||||
|             if dnsname[-1] != ".": |  | ||||||
|                 dnsname += "." |  | ||||||
|             zones = [ |  | ||||||
|                 zone |  | ||||||
|                 for zone in route53_backend.get_all_hosted_zones() |  | ||||||
|                 if zone.name == dnsname |  | ||||||
|             ] |  | ||||||
|         else: |  | ||||||
|             # sort by names, but with domain components reversed |  | ||||||
|             # see http://boto3.readthedocs.io/en/latest/reference/services/route53.html#Route53.Client.list_hosted_zones_by_name |  | ||||||
| 
 |  | ||||||
|             def sort_key(zone): |  | ||||||
|                 domains = zone.name.split(".") |  | ||||||
|                 if domains[-1] == "": |  | ||||||
|                     domains = domains[-1:] + domains[:-1] |  | ||||||
|                 return ".".join(reversed(domains)) |  | ||||||
| 
 |  | ||||||
|             zones = route53_backend.get_all_hosted_zones() |  | ||||||
|             zones = sorted(zones, key=sort_key) |  | ||||||
| 
 | 
 | ||||||
|         template = Template(LIST_HOSTED_ZONES_BY_NAME_RESPONSE) |         template = Template(LIST_HOSTED_ZONES_BY_NAME_RESPONSE) | ||||||
|         return 200, headers, template.render(zones=zones, dnsname=dnsname) |         return 200, headers, template.render(zones=zones, dnsname=dnsname) | ||||||
| @ -119,48 +99,12 @@ class Route53(BaseResponse): | |||||||
|                     ]["Change"] |                     ]["Change"] | ||||||
|                 ] |                 ] | ||||||
| 
 | 
 | ||||||
|             for value in change_list: |             error_msg = route53_backend.change_resource_record_sets( | ||||||
|                 action = value["Action"] |                 the_zone, change_list | ||||||
|                 record_set = value["ResourceRecordSet"] |  | ||||||
| 
 |  | ||||||
|                 cleaned_record_name = record_set["Name"].strip(".") |  | ||||||
|                 cleaned_hosted_zone_name = the_zone.name.strip(".") |  | ||||||
| 
 |  | ||||||
|                 if not cleaned_record_name.endswith(cleaned_hosted_zone_name): |  | ||||||
|                     error_msg = """ |  | ||||||
|                     An error occurred (InvalidChangeBatch) when calling the ChangeResourceRecordSets operation: |  | ||||||
|                     RRSet with DNS name %s is not permitted in zone %s |  | ||||||
|                     """ % ( |  | ||||||
|                         record_set["Name"], |  | ||||||
|                         the_zone.name, |  | ||||||
|             ) |             ) | ||||||
|  |             if error_msg: | ||||||
|                 return 400, headers, error_msg |                 return 400, headers, error_msg | ||||||
| 
 | 
 | ||||||
|                 if not record_set["Name"].endswith("."): |  | ||||||
|                     record_set["Name"] += "." |  | ||||||
| 
 |  | ||||||
|                 if action in ("CREATE", "UPSERT"): |  | ||||||
|                     if "ResourceRecords" in record_set: |  | ||||||
|                         resource_records = list(record_set["ResourceRecords"].values())[ |  | ||||||
|                             0 |  | ||||||
|                         ] |  | ||||||
|                         if not isinstance(resource_records, list): |  | ||||||
|                             # Depending on how many records there are, this may |  | ||||||
|                             # or may not be a list |  | ||||||
|                             resource_records = [resource_records] |  | ||||||
|                         record_set["ResourceRecords"] = [ |  | ||||||
|                             x["Value"] for x in resource_records |  | ||||||
|                         ] |  | ||||||
|                     if action == "CREATE": |  | ||||||
|                         the_zone.add_rrset(record_set) |  | ||||||
|                     else: |  | ||||||
|                         the_zone.upsert_rrset(record_set) |  | ||||||
|                 elif action == "DELETE": |  | ||||||
|                     if "SetIdentifier" in record_set: |  | ||||||
|                         the_zone.delete_rrset_by_id(record_set["SetIdentifier"]) |  | ||||||
|                     else: |  | ||||||
|                         the_zone.delete_rrset(record_set) |  | ||||||
| 
 |  | ||||||
|             return 200, headers, CHANGE_RRSET_RESPONSE |             return 200, headers, CHANGE_RRSET_RESPONSE | ||||||
| 
 | 
 | ||||||
|         elif method == "GET": |         elif method == "GET": | ||||||
| @ -212,7 +156,7 @@ class Route53(BaseResponse): | |||||||
|             return 200, headers, DELETE_HEALTH_CHECK_RESPONSE |             return 200, headers, DELETE_HEALTH_CHECK_RESPONSE | ||||||
|         elif method == "GET": |         elif method == "GET": | ||||||
|             template = Template(LIST_HEALTH_CHECKS_RESPONSE) |             template = Template(LIST_HEALTH_CHECKS_RESPONSE) | ||||||
|             health_checks = route53_backend.get_health_checks() |             health_checks = route53_backend.list_health_checks() | ||||||
|             return 200, headers, template.render(health_checks=health_checks) |             return 200, headers, template.render(health_checks=health_checks) | ||||||
| 
 | 
 | ||||||
|     def not_implemented_response(self, request, full_url, headers): |     def not_implemented_response(self, request, full_url, headers): | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user