Skip to content

Commit

Permalink
fix: map data correctly
Browse files Browse the repository at this point in the history
  • Loading branch information
Apollorion committed Jun 4, 2024
1 parent 4e9458d commit fb91466
Showing 1 changed file with 38 additions and 24 deletions.
62 changes: 38 additions & 24 deletions spacemk/exporters/terraform.py
Original file line number Diff line number Diff line change
Expand Up @@ -432,18 +432,7 @@ def reset_variable_set_relationships(var_set_id: str, variable_set_relationship_
)[0]

logging.info(f"Updating {var_set_id} to attach to the workspace {new_workspace.get('id')}")

var_set_reset = False
# remove Var Set from Workspaces
if variable_set_relationship_backup.get("relationships.workspaces.data") is not None:
self._extract_data_from_api(
method="DELETE",
path=f"/varsets/{var_set_id}/relationships/workspaces",
request_data={
"data": variable_set_relationship_backup.get("relationships.workspaces.data")
}
)

# Add Var Set to only the new workspace and set it as priority
self._extract_data_from_api(
method="PATCH",
Expand Down Expand Up @@ -1266,6 +1255,7 @@ def find_variable_set(data: dict, variable_set_id: str) -> dict:
if (
"relationships.projects.data" in variable_set
and variable_set.get("relationships.projects.data") is not None
and len(variable_set.get("relationships.projects.data")) > 0
):
for project in variable_set.get("relationships.projects.data"):
logging.info(
Expand All @@ -1274,9 +1264,14 @@ def find_variable_set(data: dict, variable_set_id: str) -> dict:
)
data.append(
{
"_migration_id": self._generate_migration_id(variable.get("id")),
"_relationships": {
"space": project.get("id"),
"context": f"{project.get('id')}_{variable_set.get('id')}",
"space": {
"_migration_id": self._generate_migration_id(project.get("id"))
},
"context": {
"_migration_id": self._generate_migration_id(f"{project.get('id')}_{variable_set.get('id')}"),
},
},
"_source_id": f"{project.get('id')}_{variable.get('id')}",
"description": variable.get("attributes.description"),
Expand All @@ -1291,9 +1286,14 @@ def find_variable_set(data: dict, variable_set_id: str) -> dict:
else:
data.append(
{
"_migration_id": self._generate_migration_id(variable.get("id")),
"_relationships": {
"space": variable_set.get("relationships.organization.data.id"),
"context": variable.get("relationships.varset.data.id"),
"space": {
"_migration_id": self._generate_migration_id(variable_set.get("relationships.organization.data.id"))
},
"context": {
"_migration_id": self._generate_migration_id(variable.get("relationships.varset.data.id"))
},
},
"_source_id": variable.get("id"),
"description": variable.get("attributes.description"),
Expand All @@ -1318,14 +1318,17 @@ def _map_contexts_data(self, src_data: dict) -> dict:
if variable_set.get("attributes.global"):
data.append(
{
"_migration_id": self._generate_migration_id(variable_set.get("id")),
"_relationships": {
"space": variable_set.get("relationships.organization.data.id"),
"space": {
"_migration_id": self._generate_migration_id(variable_set.get("relationships.organization.data.id"))
},
"stacks": [], # The list is empty because it will be auto-attached to all stacks
},
"_source_id": variable_set.get("id"),
"description": variable_set.get("attributes.description"),
"labels": ["autoattach:*"],
"name": variable_set.get("attributes.name"),
"name": variable_set.get("attributes.name")
}
)
else:
Expand All @@ -1335,13 +1338,17 @@ def _map_contexts_data(self, src_data: dict) -> dict:
if (
"relationships.projects.data" in variable_set
and variable_set.get("relationships.projects.data") is not None
and len(variable_set.get("relationships.projects.data")) > 0
):
for project in variable_set.get("relationships.projects.data"):
logging.info(f"Append context copy '{project.get('id')}' / '{variable_set.get('id')}'")
data.append(
{
"_migration_id": self._generate_migration_id(variable_set.get("id")),
"_relationships": {
"space": project.get("id"),
"space": {
"_migration_id": self._generate_migration_id(project.get("id"))
},
"stacks": [], # The list is empty because it will be auto-attached to all stacks
},
"_source_id": f"{project.get('id')}_{variable_set.get('id')}",
Expand All @@ -1351,18 +1358,25 @@ def _map_contexts_data(self, src_data: dict) -> dict:
}
)

if (
# If the variable set is attached to the project, we dont need to also attach it to the workspace
# as it will already be attached to the workspace via the project relationship.
elif (
"relationships.workspaces.data" in variable_set
and variable_set.get("relationships.workspaces.data") is not None
and len(variable_set.get("relationships.workspaces.data")) > 0
):
stacks = []
for workspace in variable_set.get("relationships.workspaces.data"):
stacks.append({"_migration_id": self._generate_migration_id(workspace.get("id"))})

data.append(
{
"_migration_id": self._generate_migration_id(variable_set.get("id")),
"_relationships": {
"space": variable_set.get("relationships.organization.data.id"),
"stacks": [
workspace.get("id")
for workspace in variable_set.get("relationships.workspaces.data")
],
"space": {
"_migration_id": self._generate_migration_id(variable_set.get("relationships.organization.data.id"))
},
"stacks": stacks,
},
"_source_id": variable_set.get("id"),
"description": variable_set.get("attributes.description"),
Expand Down

0 comments on commit fb91466

Please sign in to comment.