diff --git a/pyproject.toml b/pyproject.toml index f6edd8eb..1f3028e8 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -3,7 +3,7 @@ [tool.poetry] name = "aws-service-catalog-puppet" -version = "0.243.1" +version = "0.244.0" description = "Making it easier to deploy ServiceCatalog products" classifiers = ["Development Status :: 5 - Production/Stable", "Intended Audience :: Developers", "Programming Language :: Python :: 3", "License :: OSI Approved :: Apache Software License", "Operating System :: OS Independent", "Natural Language :: English"] homepage = "https://service-catalog-tools-workshop.com/" diff --git a/servicecatalog_puppet/commands/task_reference_helpers/generators/spoke_local_portfolios.py b/servicecatalog_puppet/commands/task_reference_helpers/generators/spoke_local_portfolios.py index 3c24b77a..d97cf4db 100644 --- a/servicecatalog_puppet/commands/task_reference_helpers/generators/spoke_local_portfolios.py +++ b/servicecatalog_puppet/commands/task_reference_helpers/generators/spoke_local_portfolios.py @@ -472,6 +472,8 @@ def handle_spoke_local_portfolios( "dependencies_by_reference": [ all_tasks_task_reference, constants.CREATE_POLICIES, + share_and_accept_ref, + ], "account_id": task_to_add.get("account_id"), "region": task_to_add.get("region"), @@ -536,7 +538,7 @@ def handle_spoke_local_portfolios( ], ), task_reference=portfolio_import_or_copy_ref, - product_generation_mathod=product_generation_method, + product_generation_method=product_generation_method, section_name=f"portfolio-{product_generation_method}", portfolio_get_all_products_and_their_versions_ref=spoke_portfolio_all_products_and_versions_ref, portfolio_get_all_products_and_their_versions_for_hub_ref=hub_portfolio_all_products_and_versions_before_ref, diff --git a/servicecatalog_puppet/commands/task_reference_helpers/generators/spoke_local_portfolios_test.py b/servicecatalog_puppet/commands/task_reference_helpers/generators/spoke_local_portfolios_test.py index 632d8089..50471486 100644 --- a/servicecatalog_puppet/commands/task_reference_helpers/generators/spoke_local_portfolios_test.py +++ b/servicecatalog_puppet/commands/task_reference_helpers/generators/spoke_local_portfolios_test.py @@ -20,6 +20,7 @@ def test_for_accounts(self): puppet_account_id = "hub_account_id" account_id = "spoke_account_id" region = "eu-west-0" + ou_name = "ou-do8d-me7f39on" item_name = "depsrefactor" portfolio = "DepsRefactor" @@ -38,7 +39,7 @@ def test_for_accounts(self): "dependencies": [], "account_id": account_id, "organization": "o-sw3edla4pd", - "ou": "ou-do8d-me7f39on", + "ou": ou_name, "region": region, task_reference_constants.MANIFEST_SECTION_NAMES: { "imported-portfolios": True @@ -53,6 +54,7 @@ def test_for_accounts(self): f"SERVICE_CATALOG_LIST_PORTFOLIOS_{region}_OF_{account_id}", f"SERVICE_CATALOG_CREATE_PORTFOLIOS_{region}_OF_{account_id}", ], + "product_generation_method": "import", } all_tasks_task_reference = task_to_add["task_reference"] all_tasks = {all_tasks_task_reference: task_to_add} @@ -154,7 +156,7 @@ def test_for_accounts(self): task_reference_constants.MANIFEST_SECTION_NAMES: { "imported-portfolios": True }, - "ou_to_share_with": "ou-do8d-me7f39on", + "ou_to_share_with": ou_name, "portfolio": portfolio, "portfolio_task_reference": f"portfolio-local-{puppet_account_id}-{region}-{portfolio}", "puppet_account_id": puppet_account_id, @@ -162,10 +164,10 @@ def test_for_accounts(self): "section_name": "portfolio-share-and-accept-aws_organizations", "share_principals": "True", "share_tag_options": "True", - "task_reference": f"portfolio_share_and_accept-ou-do8d-me7f39on-{region}-{portfolio}", + "task_reference": f"portfolio_share_and_accept-{ou_name}-{region}-{portfolio}", }, all_tasks[ - f"portfolio_share_and_accept-ou-do8d-me7f39on-{region}-{portfolio}" + f"portfolio_share_and_accept-{ou_name}-{region}-{portfolio}" ], ) @@ -199,6 +201,7 @@ def test_for_accounts(self): "dependencies_by_reference": [ f"imported-portfolios_{item_name}_{account_id}_{region}", "create-policies", + f"portfolio_share_and_accept-{ou_name}-{region}-{portfolio}", ], "execution": "hub", task_reference_constants.MANIFEST_ACCOUNT_IDS: {account_id: True}, @@ -250,8 +253,10 @@ def test_for_accounts(self): f"imported-portfolios_{item_name}_{account_id}_{region}", f"portfolio-get-all-products-and-their-versions-{account_id}-{region}-{portfolio}", f"portfolio-get-all-products-and-their-versions-before-{puppet_account_id}-{region}-{portfolio}", + f"portfolio-local-{puppet_account_id}-{region}-{portfolio}", ], "execution": "hub", + "hub_portfolio_task_reference": f"portfolio-local-{puppet_account_id}-{region}-{portfolio}", task_reference_constants.MANIFEST_ACCOUNT_IDS: {account_id: True}, task_reference_constants.MANIFEST_ITEM_NAMES: {item_name: True}, task_reference_constants.MANIFEST_SECTION_NAMES: { @@ -261,14 +266,14 @@ def test_for_accounts(self): "portfolio_get_all_products_and_their_versions_for_hub_ref": f"portfolio-get-all-products-and-their-versions-before-{puppet_account_id}-{region}-{portfolio}", "portfolio_get_all_products_and_their_versions_ref": f"portfolio-get-all-products-and-their-versions-{account_id}-{region}-{portfolio}", "portfolio_task_reference": f"imported-portfolios_{item_name}_{account_id}_{region}", - "product_generation_mathod": None, + "product_generation_method": "import", "region": region, - "section_name": "portfolio-None", + "section_name": "portfolio-import", "status": None, - "task_reference": f"portfolio_None-imported-portfolios-{item_name}-{account_id}-{region}-{portfolio}", + "task_reference": f"portfolio_import-imported-portfolios-{item_name}-{account_id}-{region}-{portfolio}", }, all_tasks[ - f"portfolio_None-imported-portfolios-{item_name}-{account_id}-{region}-{portfolio}" + f"portfolio_import-imported-portfolios-{item_name}-{account_id}-{region}-{portfolio}" ], ) @@ -305,7 +310,7 @@ def test_for_accounts(self): "dependencies_by_reference": [ f"imported-portfolios_{item_name}_{account_id}_{region}", f"portfolio-puppet-role-association-{account_id}-{region}-{portfolio}", - f"portfolio_None-imported-portfolios-{item_name}-{account_id}-{region}-{portfolio}", + f"portfolio_import-imported-portfolios-{item_name}-{account_id}-{region}-{portfolio}", ], "execution": "hub", task_reference_constants.MANIFEST_ACCOUNT_IDS: {account_id: True}, diff --git a/servicecatalog_puppet/workflow/portfolio/portfolio_management/copy_into_spoke_local_portfolio_task.py b/servicecatalog_puppet/workflow/portfolio/portfolio_management/copy_into_spoke_local_portfolio_task.py index b8eabe6d..c134f615 100644 --- a/servicecatalog_puppet/workflow/portfolio/portfolio_management/copy_into_spoke_local_portfolio_task.py +++ b/servicecatalog_puppet/workflow/portfolio/portfolio_management/copy_into_spoke_local_portfolio_task.py @@ -142,13 +142,15 @@ def run(self): n_products_to_check = len(products_to_check) products_found = 0 while products_found < n_products_to_check: - response = servicecatalog.search_products_as_admin_single_page( # TODO optimise = swap for paginator - PortfolioId=spoke_portfolio_id, - ) - products_ids = [ - product_view_detail.get("ProductViewSummary").get("ProductId") - for product_view_detail in response.get("ProductViewDetails") - ] + products_ids = list() + paginator = servicecatalog.get_paginator('search_products_as_admin') + for page in paginator.paginate( + PortfolioId=spoke_portfolio_id, + ): + for pvd in page.get("ProductViewDetails", []): + products_ids.append( + pvd.get("ProductViewSummary").get("ProductId") + ) products_found = 0 for product_to_check in products_to_check: if product_to_check in products_ids: diff --git a/servicecatalog_puppet/workflow/portfolio/portfolio_management/import_into_spoke_local_portfolio_task.py b/servicecatalog_puppet/workflow/portfolio/portfolio_management/import_into_spoke_local_portfolio_task.py index 76a95cd9..a4289695 100644 --- a/servicecatalog_puppet/workflow/portfolio/portfolio_management/import_into_spoke_local_portfolio_task.py +++ b/servicecatalog_puppet/workflow/portfolio/portfolio_management/import_into_spoke_local_portfolio_task.py @@ -60,13 +60,16 @@ def run(self): n_products_to_check = len(products_to_check) products_found = 0 while products_found < n_products_to_check: - response = servicecatalog.search_products_as_admin_single_page( # TODO optimise = swap for paginator + products_ids = list() + paginator = servicecatalog.get_paginator('search_products_as_admin') + for page in paginator.paginate( PortfolioId=spoke_portfolio_id, - ) - products_ids = [ - product_view_detail.get("ProductViewSummary").get("ProductId") - for product_view_detail in response.get("ProductViewDetails") - ] + ): + for pvd in page.get("ProductViewDetails", []): + products_ids.append( + pvd.get("ProductViewSummary").get("ProductId") + ) + products_found = 0 for product_to_check in products_to_check: if product_to_check in products_ids: diff --git a/setup.py b/setup.py index 1cd77a85..5f004cf5 100644 --- a/setup.py +++ b/setup.py @@ -73,7 +73,7 @@ setup_kwargs = { 'name': 'aws-service-catalog-puppet', - 'version': '0.243.1', + 'version': '0.244.0', 'description': 'Making it easier to deploy ServiceCatalog products', 'long_description': '# aws-service-catalog-puppet\n\n![logo](./docs/logo.png) \n\n## Badges\n\n[![codecov](https://codecov.io/gh/awslabs/aws-service-catalog-puppet/branch/master/graph/badge.svg?token=e8M7mdsmy0)](https://codecov.io/gh/awslabs/aws-service-catalog-puppet)\n\n\n## What is it?\nThis is a python3 framework that makes it easier to share multi region AWS Service Catalog portfolios and makes it \npossible to provision products into accounts declaratively using a metadata based rules engine.\n\nWith this framework you define your accounts in a YAML file. You give each account a set of tags, a default region and \na set of enabled regions.\n\nOnce you have done this you can define portfolios should be shared with each set of accounts using the tags and you \ncan specify which regions the shares occur in.\n\nIn addition to this, you can also define products that should be provisioned into accounts using the same tag based \napproach. The framework will assume role into the target account and provision the product on your behalf.\n\n\n## Getting started\n\nYou can read the [installation how to](https://service-catalog-tools-workshop.com/30-how-tos/10-installation/30-service-catalog-puppet.html)\nor you can read through the [every day use](https://service-catalog-tools-workshop.com/30-how-tos/50-every-day-use.html)\nguides.\n\nYou can read the [documentation](https://aws-service-catalog-puppet.readthedocs.io/en/latest/) to understand the inner \nworkings. \n\n\n## Going further\n\nThe framework is one of a pair. The other is [aws-service-catalog-factory](https://github.com/awslabs/aws-service-catalog-factory).\nWith Service Catalog Factory you can create pipelines that deploy multi region portfolios very easily. \n\n## License\n\nThis library is licensed under the Apache 2.0 License. \n \n', 'author': 'Eamonn Faherty',