Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion cloudinit/sources/DataSourceVultr.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,12 @@ def _get_data(self):

# Fetch metadata
self.metadata = self.get_metadata()
self.metadata["instance-id"] = self.metadata["instanceid"]
self.metadata["instance-id"] = self.metadata["instance-v2-id"]
self.metadata["local-hostname"] = self.metadata["hostname"]
region = self.metadata["region"]["regioncode"]
if "countrycode" in self.metadata["region"]:
region = self.metadata["region"]["countrycode"]
self.metadata["region"] = region.lower()
self.userdata_raw = self.metadata["user-data"]

# Generate config and process data
Expand Down
40 changes: 25 additions & 15 deletions cloudinit/sources/helpers/vultr.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,23 +16,33 @@

@lru_cache()
def get_metadata(url, timeout, retries, sec_between, agent):
# Bring up interface
try:
with EphemeralDHCPv4(connectivity_url_data={"url": url}):
# Set metadata route
set_route()

# Fetch the metadata
v1 = read_metadata(url, timeout, retries, sec_between, agent)
except (NoDHCPLeaseError) as exc:
LOG.error("Bailing, DHCP Exception: %s", exc)
raise

return json.loads(v1)
# Bring up interface (and try untill one works)
exception = RuntimeError("Failed to DHCP")

# Seek iface with DHCP
for iface in net.get_interfaces():
# Skip dummy interfaces
if "dummy" in iface[0]:
continue
try:
with EphemeralDHCPv4(
iface=iface[0], connectivity_url_data={"url": url}
):
# Set metadata route
set_route(iface[0])

# Fetch the metadata
v1 = read_metadata(url, timeout, retries, sec_between, agent)
except (NoDHCPLeaseError) as exc:
LOG.error("DHCP Exception: %s", exc)
exception = exc

return json.loads(v1)
raise exception


# Set route for metadata
def set_route():
def set_route(iface):
# Get routes, confirm entry does not exist
routes = netinfo.route_info()

Expand Down Expand Up @@ -67,7 +77,7 @@ def set_route():
"add",
"169.254.169.254/32",
"dev",
net.find_fallback_nic(),
iface,
]
)
elif subp.which("route"):
Expand Down