in servicecatalog_puppet/workflow/portfolio/portfolio_management/import_into_spoke_local_portfolio_task.py [0:0]
def run(self):
with self.input().get("create_spoke_local_portfolio").open("r") as f:
spoke_portfolio = json.loads(f.read())
portfolio_id = spoke_portfolio.get("Id")
with self.input().get("hub_portfolio").open("r") as f:
hub_portfolio = json.loads(f.read())
hub_portfolio_id = hub_portfolio.get("portfolio_id")
product_name_to_id_dict = {}
hub_product_to_import_list = []
with self.input().get("products_and_provisioning_artifacts").open("r") as f:
products_and_provisioning_artifacts = json.loads(f.read())
for product_view_summary in products_and_provisioning_artifacts:
hub_product_name = product_view_summary.get("Name")
hub_product_id = product_view_summary.get("ProductId")
product_name_to_id_dict[hub_product_name] = hub_product_id
hub_product_to_import_list.append(hub_product_id)
self.info(f"Starting product import with targets {hub_product_to_import_list}")
with self.spoke_regional_client("servicecatalog") as spoke_service_catalog:
while True:
self.info(f"Generating product list for portfolio {portfolio_id}")
response = spoke_service_catalog.search_products_as_admin_single_page(
PortfolioId=portfolio_id,
)
spoke_portfolio_products = [
product_view_detail.get("ProductViewSummary").get("ProductId")
for product_view_detail in response.get("ProductViewDetails")
]
target_products = [
product_id
for product_id in hub_product_to_import_list
if product_id not in spoke_portfolio_products
]
if not target_products:
self.info(
f"No more products for import to portfolio {portfolio_id}"
)
break
self.info(
f"Products {target_products} not yet imported to portfolio {portfolio_id}"
)
for product_id in target_products:
self.info(f"Associating {product_id}")
spoke_service_catalog.associate_product_with_portfolio(
ProductId=product_id,
PortfolioId=portfolio_id,
SourcePortfolioId=hub_portfolio_id,
)
# associate_product_with_portfolio is not a synchronous request
# so wait a short time, then try again with any products not yet appeared
time.sleep(2)
with self.output().open("w") as f:
f.write(
json.dumps(
{
"portfolio": spoke_portfolio,
"products": product_name_to_id_dict,
},
indent=4,
default=str,
)
)