katello 4.4.2.2 → 4.5.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +5 -1
- data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +98 -0
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +39 -3
- data/app/controllers/katello/api/v2/content_exports_controller.rb +19 -0
- data/app/controllers/katello/api/v2/content_imports_controller.rb +13 -16
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +0 -12
- data/app/controllers/katello/api/v2/content_views_controller.rb +13 -0
- data/app/controllers/katello/api/v2/environments_controller.rb +1 -1
- data/app/controllers/katello/api/v2/host_module_streams_controller.rb +8 -2
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +25 -3
- data/app/controllers/katello/api/v2/organizations_controller.rb +4 -2
- data/app/controllers/katello/api/v2/repositories_bulk_actions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repositories_controller.rb +9 -3
- data/app/controllers/katello/api/v2/repository_sets_controller.rb +40 -7
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +2 -2
- data/app/controllers/katello/concerns/api/v2/hosts_controller_extensions.rb +1 -1
- data/app/helpers/katello/concerns/smart_proxy_helper_extensions.rb +4 -0
- data/app/helpers/katello/hosts_and_hostgroups_helper.rb +21 -3
- data/app/lib/actions/katello/alternate_content_source/create.rb +24 -0
- data/app/lib/actions/katello/alternate_content_source/destroy.rb +27 -0
- data/app/lib/actions/katello/alternate_content_source/update.rb +41 -0
- data/app/lib/actions/katello/cdn_configuration/update.rb +2 -2
- data/app/lib/actions/katello/content_view/destroy.rb +2 -1
- data/app/lib/actions/katello/content_view/incremental_updates.rb +7 -3
- data/app/lib/actions/katello/content_view/publish.rb +7 -9
- data/app/lib/actions/katello/content_view_version/auto_create_products.rb +4 -4
- data/app/lib/actions/katello/content_view_version/auto_create_redhat_repositories.rb +6 -4
- data/app/lib/actions/katello/content_view_version/auto_create_repositories.rb +6 -4
- data/app/lib/actions/katello/content_view_version/import.rb +25 -22
- data/app/lib/actions/katello/content_view_version/import_library.rb +0 -1
- data/app/lib/actions/katello/content_view_version/import_repository.rb +21 -0
- data/app/lib/actions/katello/content_view_version/incremental_update.rb +85 -93
- data/app/lib/actions/katello/content_view_version/reset_content_view_repositories_from_metadata.rb +2 -2
- data/app/lib/actions/katello/product/content_create.rb +10 -8
- data/app/lib/actions/katello/repository/destroy.rb +36 -12
- data/app/lib/actions/katello/repository_set/disable_repository.rb +8 -3
- data/app/lib/actions/pulp3/alternate_content_source/create.rb +20 -0
- data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +20 -0
- data/app/lib/actions/pulp3/alternate_content_source/delete.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/update.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +17 -0
- data/app/lib/actions/pulp3/content_view_version/{import.rb → create_import.rb} +5 -5
- data/app/lib/actions/pulp3/content_view_version/create_importer.rb +4 -3
- data/app/lib/actions/pulp3/content_view_version/destroy_importer.rb +12 -1
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +18 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +23 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +18 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +1 -1
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_repository.rb +51 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +5 -2
- data/app/lib/actions/pulp3/repository/refresh_distribution.rb +4 -1
- data/app/lib/actions/pulp3/repository/save_distribution_references.rb +2 -0
- data/app/lib/katello/api/v2/error_handling.rb +1 -0
- data/app/lib/katello/resources/cdn/katello_cdn.rb +3 -1
- data/app/lib/katello/util/errata.rb +2 -3
- data/app/lib/katello/validators/alternate_content_source_path_validator.rb +29 -0
- data/app/lib/katello/validators/content_default_http_proxy_setting_validator.rb +12 -0
- data/app/lib/katello/validators/content_view_environment_validator.rb +10 -5
- data/app/models/katello/alternate_content_source.rb +66 -0
- data/app/models/katello/authorization/alternate_content_source.rb +33 -0
- data/app/models/katello/authorization/repository.rb +3 -3
- data/app/models/katello/candlepin/repository_mapper.rb +13 -6
- data/app/models/katello/cdn_configuration.rb +15 -15
- data/app/models/katello/concerns/content_facet_host_extensions.rb +25 -0
- data/app/models/katello/concerns/host_managed_extensions.rb +7 -5
- data/app/models/katello/concerns/http_proxy_extensions.rb +14 -0
- data/app/models/katello/concerns/organization_extensions.rb +4 -2
- data/app/models/katello/concerns/setting_extensions.rb +14 -0
- data/app/models/katello/concerns/smart_proxy_extensions.rb +2 -1
- data/app/models/katello/content.rb +1 -0
- data/app/models/katello/content_credential.rb +6 -0
- data/app/models/katello/content_override.rb +7 -3
- data/app/models/katello/content_view.rb +33 -2
- data/app/models/katello/content_view_erratum_filter.rb +26 -12
- data/app/models/katello/content_view_filter.rb +4 -0
- data/app/models/katello/content_view_version.rb +12 -0
- data/app/models/katello/content_view_version_export_history.rb +3 -1
- data/app/models/katello/erratum.rb +9 -5
- data/app/models/katello/events/delete_latest_content_view_version.rb +40 -0
- data/app/models/katello/host/content_facet.rb +14 -0
- data/app/models/katello/host_available_module_stream.rb +12 -0
- data/app/models/katello/product_content.rb +1 -0
- data/app/models/katello/purpose_sla_status.rb +1 -1
- data/app/models/katello/purpose_status.rb +2 -2
- data/app/models/katello/repository.rb +7 -4
- data/app/models/katello/root_repository.rb +1 -1
- data/app/models/katello/smart_proxy_alternate_content_source.rb +8 -0
- data/app/models/katello/sync_plan.rb +1 -1
- data/app/presenters/katello/product_content_presenter.rb +15 -0
- data/app/services/katello/applicable_host_queue.rb +1 -1
- data/app/services/katello/content_unit_indexer.rb +2 -1
- data/app/services/katello/product_content_finder.rb +12 -2
- data/app/services/katello/pulp3/alternate_content_source.rb +117 -0
- data/app/services/katello/pulp3/api/file.rb +8 -0
- data/app/services/katello/pulp3/api/yum.rb +8 -0
- data/app/services/katello/pulp3/content_view_version/export.rb +27 -5
- data/app/services/katello/pulp3/content_view_version/import.rb +97 -71
- data/app/services/katello/pulp3/content_view_version/import_export_common.rb +4 -4
- data/app/services/katello/pulp3/content_view_version/import_gpg_keys.rb +13 -11
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +67 -72
- data/app/services/katello/pulp3/content_view_version/importable_products.rb +40 -24
- data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +88 -39
- data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +2 -2
- data/app/services/katello/pulp3/content_view_version/metadata_map.rb +117 -0
- data/app/services/katello/pulp3/pulp_content_unit.rb +6 -1
- data/app/services/katello/pulp3/repository/yum.rb +70 -12
- data/app/services/katello/pulp3/repository.rb +7 -91
- data/app/services/katello/pulp3/service_common.rb +66 -0
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +4 -1
- data/app/services/katello/ui_notifications/content_view/delete_latest_version_failure.rb +22 -0
- data/app/views/foreman/job_templates/change_content_source.erb +1 -1
- data/app/views/foreman/job_templates/install_errata.erb +5 -5
- data/app/views/foreman/job_templates/install_errata_by_search_query.erb +7 -6
- data/app/views/foreman/job_templates/install_group.erb +4 -4
- data/app/views/foreman/job_templates/install_package.erb +4 -4
- data/app/views/foreman/job_templates/install_packages_by_search_query.erb +3 -3
- data/app/views/foreman/job_templates/remove_group.erb +4 -4
- data/app/views/foreman/job_templates/remove_package.erb +4 -4
- data/app/views/foreman/job_templates/remove_packages_by_search_query.erb +3 -3
- data/app/views/foreman/job_templates/resolve_traces.erb +2 -2
- data/app/views/foreman/job_templates/restart_services.erb +3 -3
- data/app/views/foreman/job_templates/update_group.erb +4 -4
- data/app/views/foreman/job_templates/update_package.erb +4 -4
- data/app/views/foreman/job_templates/update_packages_by_search_query.erb +3 -3
- data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +15 -0
- data/app/views/katello/api/v2/alternate_content_sources/index.json.rabl +7 -0
- data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +3 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +1 -1
- data/app/views/katello/api/v2/content_view_version_export_histories/show.json.rabl +2 -3
- data/app/views/katello/api/v2/content_view_versions/base.json.rabl +1 -1
- data/app/views/katello/api/v2/content_views/base.json.rabl +1 -0
- data/app/views/katello/api/v2/environments/show.json.rabl +2 -0
- data/app/views/katello/api/v2/errata/_counts.json.rabl +2 -2
- data/app/views/katello/api/v2/host_module_streams/base.json.rabl +2 -2
- data/app/views/katello/api/v2/hosts/host_collections.json.rabl +1 -1
- data/app/views/katello/api/v2/organizations/show.json.rabl +7 -1
- data/app/views/katello/api/v2/repositories/show.json.rabl +2 -1
- data/app/views/katello/sync_management/_repo.html.erb +8 -29
- data/config/routes/api/v2.rb +7 -0
- data/db/migrate/20150930183738_migrate_content_hosts.rb +0 -399
- data/db/migrate/20171025163149_remove_use_pulp_oauth_setting.rb +1 -1
- data/db/migrate/20171114150937_cleanup_installed_packages.rb +1 -1
- data/db/migrate/20180402160223_clean_up_force_post_sync_action_setting.rb +1 -1
- data/db/migrate/20211129200124_remove_dependency_solving_algorithm_setting.rb +1 -1
- data/db/migrate/20211220185935_clean_duplicate_content_units.rb +10 -12
- data/db/migrate/20220110223754_update_disconnected_settings.rb +5 -5
- data/db/migrate/20220117151612_add_alternate_content_sources.rb +48 -0
- data/db/migrate/20220124191056_add_type_to_cdn_configuration.rb +9 -4
- data/db/migrate/20220209203251_add_generated_for_to_content_views.rb +13 -0
- data/db/migrate/20220209205137_expand_sync_timeout_settings.rb +7 -7
- data/db/migrate/20220228173251_remove_drpm_from_ignorable_content.rb +12 -0
- data/db/migrate/20220404190836_delete_old_setting_data.rb +9 -0
- data/db/migrate/20220405220616_update_cdn_configuration_type.rb +11 -0
- data/db/migrate/20220419193414_content_settings_to_dsl_category.rb +5 -0
- data/db/seeds.d/110-content-view-autopublish.rb +13 -0
- data/db/seeds.d/150-module_job_templates.rb +1 -1
- data/engines/bastion/README.md +1 -0
- data/engines/bastion/app/assets/javascripts/bastion/components/bst-modal.directive.js +1 -0
- data/engines/bastion/app/views/bastion/layouts/assets.html.erb +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.controller.js +10 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-module-streams.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-installed.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-traces.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-actions.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-applicable.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.controller.js +8 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/content.service.js +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-deb-repositories.html +26 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-debs.html +27 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.routes.js +22 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +13 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +63 -17
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +7 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details.controller.js +10 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-details.html +21 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +8 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/new-repository.controller.js +7 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +2 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/discovery-create.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/views/discovery-create.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.routes.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/content-access-mode-banner.html +6 -1
- data/lib/katello/engine.rb +1 -5
- data/lib/katello/permission_creator.rb +32 -4
- data/lib/katello/plugin.rb +378 -4
- data/lib/katello/tasks/reset.rake.bak +67 -0
- data/lib/katello/tasks/update_content_default_http_proxy.rake +2 -3
- data/lib/katello/version.rb +1 -1
- data/locale/action_names.rb +47 -41
- data/locale/bn/LC_MESSAGES/katello.mo +0 -0
- data/locale/bn/katello.po +820 -106
- data/locale/bn/katello.po.time_stamp +0 -0
- data/locale/cs/LC_MESSAGES/katello.mo +0 -0
- data/locale/cs/katello.po +818 -104
- data/locale/cs/katello.po.time_stamp +0 -0
- data/locale/de/LC_MESSAGES/katello.mo +0 -0
- data/locale/de/katello.po +893 -179
- data/locale/de/katello.po.time_stamp +0 -0
- data/locale/en/LC_MESSAGES/katello.mo +0 -0
- data/locale/en/katello.po +817 -103
- data/locale/en/katello.po.time_stamp +0 -0
- data/locale/es/LC_MESSAGES/katello.mo +0 -0
- data/locale/es/katello.po +882 -168
- data/locale/es/katello.po.time_stamp +0 -0
- data/locale/fr/LC_MESSAGES/katello.mo +0 -0
- data/locale/fr/katello.po +1219 -505
- data/locale/fr/katello.po.time_stamp +0 -0
- data/locale/gu/LC_MESSAGES/katello.mo +0 -0
- data/locale/gu/katello.po +826 -112
- data/locale/gu/katello.po.time_stamp +0 -0
- data/locale/hi/LC_MESSAGES/katello.mo +0 -0
- data/locale/hi/katello.po +826 -112
- data/locale/hi/katello.po.time_stamp +0 -0
- data/locale/it/LC_MESSAGES/katello.mo +0 -0
- data/locale/it/katello.po +863 -148
- data/locale/it/katello.po.time_stamp +0 -0
- data/locale/ja/LC_MESSAGES/katello.mo +0 -0
- data/locale/ja/katello.po +1216 -499
- data/locale/ja/katello.po.time_stamp +0 -0
- data/locale/katello.pot +3847 -2507
- data/locale/kn/LC_MESSAGES/katello.mo +0 -0
- data/locale/kn/katello.po +826 -112
- data/locale/kn/katello.po.time_stamp +0 -0
- data/locale/ko/LC_MESSAGES/katello.mo +0 -0
- data/locale/ko/katello.po +912 -198
- data/locale/ko/katello.po.time_stamp +0 -0
- data/locale/mr/LC_MESSAGES/katello.mo +0 -0
- data/locale/mr/katello.po +826 -112
- data/locale/mr/katello.po.time_stamp +0 -0
- data/locale/or/LC_MESSAGES/katello.mo +0 -0
- data/locale/or/katello.po +826 -112
- data/locale/or/katello.po.time_stamp +0 -0
- data/locale/pa/LC_MESSAGES/katello.mo +0 -0
- data/locale/pa/katello.po +826 -112
- data/locale/pa/katello.po.time_stamp +0 -0
- data/locale/pt/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt/katello.po +817 -103
- data/locale/pt/katello.po.time_stamp +0 -0
- data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt_BR/katello.po +879 -165
- data/locale/pt_BR/katello.po.time_stamp +0 -0
- data/locale/ru/LC_MESSAGES/katello.mo +0 -0
- data/locale/ru/katello.po +927 -213
- data/locale/ru/katello.po.time_stamp +0 -0
- data/locale/ta/LC_MESSAGES/katello.mo +0 -0
- data/locale/ta/katello.po +820 -106
- data/locale/ta/katello.po.time_stamp +0 -0
- data/locale/te/LC_MESSAGES/katello.mo +0 -0
- data/locale/te/katello.po +826 -112
- data/locale/te/katello.po.time_stamp +0 -0
- data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_CN/katello.po +1202 -486
- data/locale/zh_CN/katello.po.time_stamp +0 -0
- data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_TW/katello.po +856 -142
- data/locale/zh_TW/katello.po.time_stamp +0 -0
- data/webpack/components/EditableTextInput/EditableTextInput.js +20 -5
- data/webpack/components/Errata/index.js +38 -8
- data/webpack/components/Packages/index.js +1 -4
- data/webpack/components/Search/Search.js +18 -3
- data/webpack/components/SelectAllCheckbox/index.js +1 -0
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +4 -2
- data/webpack/components/Table/EmptyStateMessage.js +21 -7
- data/webpack/components/Table/MainTable.js +29 -4
- data/webpack/components/Table/TableHooks.js +63 -19
- data/webpack/components/Table/TableWrapper.js +4 -2
- data/webpack/components/Table/components/SortableColumnHeaders.js +19 -0
- data/webpack/components/Table/components/TranslatedPlural.js +57 -0
- data/webpack/components/TypeAhead/TypeAhead.js +8 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +13 -11
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +5 -2
- data/webpack/components/extensions/HostDetails/ActionsBar/index.js +27 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +256 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +202 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/HostContentViewActions.js +19 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/HostContentViewConstants.js +2 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/changeHostCVModal.test.js +131 -0
- data/webpack/components/extensions/HostDetails/Cards/{__tests__ → ContentViewDetailsCard/__tests__}/contentViewDetailsCard.test.js +22 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/contentViews.fixtures.json +443 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/envPaths.fixtures.json +320 -0
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.js +57 -33
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.scss +3 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsActions.js +30 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js +187 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsConstants.js +7 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +227 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsSelectors.js +18 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/availableHostCollections.fixtures.json +106 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsCard.test.js +110 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsModal.test.js +235 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/removableHostCollections.fixtures.json +45 -0
- data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +33 -8
- data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +44 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/RegistrationCard.js +107 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +38 -0
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +62 -39
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/HostErrataActions.js +1 -7
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsActions.js +1 -3
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsConstants.js +28 -0
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +486 -116
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/__tests__/moduleStreamsTab.test.js +147 -1
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/__tests__/modules.fixtures.json +6 -3
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/HostPackagesActions.js +1 -7
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +2 -1
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +48 -19
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionActions.js +35 -47
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionConstants.js +1 -0
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsActions.js +33 -54
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsConstants.js +20 -0
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +269 -132
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +47 -11
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +30 -42
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +36 -1
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +94 -46
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +18 -2
- data/webpack/components/extensions/HostDetails/Tabs/customizedRexUrlHelpers.js +6 -0
- data/webpack/containers/Application/config.js +5 -0
- data/webpack/global_index.js +30 -7
- data/webpack/global_test_setup.js +13 -0
- data/webpack/redux/actions/RedHatRepositories/enabled.js +2 -1
- data/webpack/redux/actions/RedHatRepositories/helpers.js +9 -8
- data/webpack/scenes/AlternateContentSources/ACSActions.js +53 -0
- data/webpack/scenes/AlternateContentSources/ACSConstants.js +4 -0
- data/webpack/scenes/AlternateContentSources/ACSIndexPage.js +23 -0
- data/webpack/scenes/AlternateContentSources/ACSSelectors.js +15 -0
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +152 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsIndex.fixtures.json +91 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +67 -0
- data/webpack/scenes/AlternateContentSources/index.js +4 -0
- data/webpack/scenes/Content/Details/ContentRepositories.js +1 -0
- data/webpack/scenes/Content/Table/ContentTable.js +1 -0
- data/webpack/scenes/ContentViews/ContentViewsActions.js +6 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +11 -3
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +2 -1
- data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +10 -1
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +4 -3
- data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +1 -1
- data/webpack/scenes/ContentViews/Delete/ContentViewDeleteWizard.js +7 -5
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionFinish.js +29 -21
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +15 -8
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +3 -3
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +4 -4
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +3 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +4 -4
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +34 -8
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +33 -29
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +130 -79
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +17 -3
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +6 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +41 -21
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +38 -20
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +2 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +8 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +9 -1
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVRpmMatchContentModal.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/Rules/ContainerTag/AddEditContainerTagRuleModal.js +27 -12
- data/webpack/scenes/ContentViews/Details/Filters/Rules/Package/AddEditPackageRuleModal.js +39 -17
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +27 -10
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +46 -23
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +3 -2
- data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +5 -2
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +161 -108
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +7 -7
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewRepoAdd.fixture.json +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/ActionSummary.js +58 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteContextWrapper.js +45 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteHelpers.js +30 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteModal.js +56 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ConfirmBulkDelete.js +126 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/FinishBulkDelete.js +61 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignActivationKeys.js +196 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignHosts.js +220 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReviewEnvironments.js +104 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +122 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteVersions.fixtures.json +600 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/contentView.fixtures.json +1504 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/contentViewVersion.fixtures.json +936 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/environmentPaths.fixtures.json +261 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/hosts.fixtures.json +163 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/bulkDeleteSteps.js +79 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +192 -167
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveCVVersionWizard.js +2 -5
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionDeleteFinish.js +38 -53
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionRemoveReview.js +1 -1
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +6 -12
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedActivationKeys.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedHosts.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.js +8 -20
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +23 -13
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +3 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.fixtures.json +4 -4
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +0 -3
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +4 -4
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +12 -14
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Publish/CVPublishFinish.js +96 -117
- data/webpack/scenes/ContentViews/Publish/PublishContentViewWizard.js +13 -19
- data/webpack/scenes/ContentViews/Publish/__tests__/publishContentView.test.js +9 -20
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +165 -148
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +2 -0
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +4 -4
- data/webpack/scenes/ContentViews/components/ContentViewIcon.js +14 -3
- data/webpack/scenes/ContentViews/components/ContentViewsCounter.js +1 -1
- data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +4 -3
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +9 -5
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.scss +6 -1
- data/webpack/scenes/ContentViews/components/TaskPresenter/TaskPresenter.js +40 -35
- data/webpack/scenes/ContentViews/expansions/DetailsExpansion.js +2 -2
- data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +1 -1
- data/webpack/scenes/ContentViews/expansions/RelatedContentViewComponentsModal.js +4 -4
- data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsModal.test.js +1 -1
- data/webpack/scenes/ContentViews/helpers.js +3 -0
- data/webpack/scenes/Hosts/ChangeContentSource/helpers.js +5 -0
- data/webpack/scenes/RedHatRepositories/RedHatRepositoriesPage.js +3 -3
- data/webpack/scenes/RedHatRepositories/components/EnabledRepository/EnabledRepository.js +2 -1
- data/webpack/scenes/RedHatRepositories/components/EnabledRepository/__tests__/EnabledRepository.test.js +2 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnConfigurationConstants.js +3 -3
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnTypeForm.js +2 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/{AirGappedTypeForm.js → ExportSyncForm.js} +7 -6
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/{UpstreamServerTypeForm.js → NetworkSyncForm.js} +15 -7
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/{AirGappedTypeForm.test.js → ExportSyncForm.test.js} +4 -4
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/{UpstreamServerTypeForm.test.js → NetworkSyncForm.test.js} +8 -8
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/index.js +11 -11
- data/webpack/scenes/Subscriptions/SubscriptionConstants.js +1 -0
- data/webpack/scenes/Subscriptions/SubscriptionsPage.js +8 -7
- data/webpack/scenes/Tasks/TaskActions.js +6 -0
- data/webpack/scenes/Tasks/TaskSelectors.js +11 -0
- data/webpack/scenes/Tasks/helpers.js +33 -5
- data/webpack/utils/helpers.js +2 -0
- metadata +158 -40
- data/app/models/setting/content.rb +0 -201
- data/webpack/components/Table/__test__/useBulkSelect.test.js +0 -99
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard.js +0 -96
- data/webpack/scenes/ContentViews/Details/DetailsContainer.js +0 -36
data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js
CHANGED
@@ -54,9 +54,9 @@ test('Can enable and disable add repositories button', async (done) => {
|
|
54
54
|
);
|
55
55
|
|
56
56
|
await patientlyWaitFor(() => expect(getByText(firstRepo.name)).toBeInTheDocument());
|
57
|
-
expect(getByLabelText('Select all
|
57
|
+
expect(getByLabelText('Select all')).toBeInTheDocument();
|
58
58
|
expect(getByLabelText('add_repositories')).toHaveAttribute('aria-disabled', 'true');
|
59
|
-
getByLabelText('Select all
|
59
|
+
getByLabelText('Select all').click();
|
60
60
|
await patientlyWaitFor(() => {
|
61
61
|
expect(getByLabelText('add_repositories')).toHaveAttribute('aria-disabled', 'false');
|
62
62
|
});
|
@@ -66,7 +66,7 @@ test('Can enable and disable add repositories button', async (done) => {
|
|
66
66
|
|
67
67
|
test('Can add repositories', async (done) => {
|
68
68
|
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
69
|
-
const cvAddparams = { include_permissions: true, repository_ids: [58, 62, 64, 106] };
|
69
|
+
const cvAddparams = { include_permissions: true, repository_ids: [58, 62, 64, 106, 107] };
|
70
70
|
|
71
71
|
const repoAddscope = nockInstance
|
72
72
|
.put(cvDetailsPath, cvAddparams)
|
@@ -88,9 +88,9 @@ test('Can add repositories', async (done) => {
|
|
88
88
|
);
|
89
89
|
|
90
90
|
await patientlyWaitFor(() => expect(getByText(firstRepo.name)).toBeInTheDocument());
|
91
|
-
expect(getByLabelText('Select all
|
91
|
+
expect(getByLabelText('Select all')).toBeInTheDocument();
|
92
92
|
expect(getByLabelText('add_repositories')).toHaveAttribute('aria-disabled', 'true');
|
93
|
-
getByLabelText('Select all
|
93
|
+
getByLabelText('Select all').click();
|
94
94
|
getByLabelText('add_repositories').click();
|
95
95
|
await patientlyWaitFor(() => expect(getByText(firstRepo.name)).toBeInTheDocument());
|
96
96
|
|
@@ -123,8 +123,8 @@ test('Can remove repositories', async (done) => {
|
|
123
123
|
);
|
124
124
|
|
125
125
|
await patientlyWaitFor(() => expect(getByText(firstRepo.name)).toBeInTheDocument());
|
126
|
-
expect(getByLabelText('Select all
|
127
|
-
getByLabelText('Select all
|
126
|
+
expect(getByLabelText('Select all')).toBeInTheDocument();
|
127
|
+
getByLabelText('Select all').click();
|
128
128
|
await patientlyWaitFor(() => {
|
129
129
|
expect(getByLabelText('bulk_actions')).toHaveAttribute('aria-expanded', 'false');
|
130
130
|
});
|
@@ -0,0 +1,58 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { PropTypes } from 'prop-types';
|
3
|
+
import {
|
4
|
+
Flex,
|
5
|
+
FlexItem,
|
6
|
+
Label,
|
7
|
+
Text,
|
8
|
+
} from '@patternfly/react-core';
|
9
|
+
import { ExclamationTriangleIcon } from '@patternfly/react-icons';
|
10
|
+
import {
|
11
|
+
global_warning_color_100 as warningColor,
|
12
|
+
} from '@patternfly/react-tokens';
|
13
|
+
|
14
|
+
const ActionSummary = ({ title, text, selectedEnv: { name, id } }) => (
|
15
|
+
<div>
|
16
|
+
{title &&
|
17
|
+
<h3 style={{ margin: '8px 0' }}><b>{title}</b></h3>
|
18
|
+
}
|
19
|
+
{text &&
|
20
|
+
<Flex>
|
21
|
+
<FlexItem style={{ marginRight: '8px' }}>
|
22
|
+
<ExclamationTriangleIcon color={warningColor.value} />
|
23
|
+
</FlexItem>
|
24
|
+
<FlexItem style={{ marginRight: '8px' }}>
|
25
|
+
<Text>{text}</Text>
|
26
|
+
</FlexItem>
|
27
|
+
{name && id &&
|
28
|
+
<FlexItem>
|
29
|
+
<Label isTruncated color="purple" href={`/lifecycle_environments/${id}`}>{name}</Label>
|
30
|
+
</FlexItem>
|
31
|
+
}
|
32
|
+
</Flex>
|
33
|
+
}
|
34
|
+
</div>);
|
35
|
+
|
36
|
+
|
37
|
+
ActionSummary.propTypes = {
|
38
|
+
title: PropTypes.oneOfType([
|
39
|
+
PropTypes.string,
|
40
|
+
PropTypes.object, // React component
|
41
|
+
]),
|
42
|
+
text: PropTypes.oneOfType([
|
43
|
+
PropTypes.string,
|
44
|
+
PropTypes.object, // React component
|
45
|
+
]),
|
46
|
+
selectedEnv: PropTypes.shape({
|
47
|
+
id: PropTypes.number,
|
48
|
+
name: PropTypes.string,
|
49
|
+
}),
|
50
|
+
};
|
51
|
+
|
52
|
+
ActionSummary.defaultProps = {
|
53
|
+
title: undefined,
|
54
|
+
text: undefined,
|
55
|
+
selectedEnv: {},
|
56
|
+
};
|
57
|
+
|
58
|
+
export default ActionSummary;
|
@@ -0,0 +1,45 @@
|
|
1
|
+
import React, {
|
2
|
+
createContext,
|
3
|
+
useState,
|
4
|
+
} from 'react';
|
5
|
+
|
6
|
+
import { PropTypes } from 'prop-types';
|
7
|
+
|
8
|
+
export const BulkDeleteContext = createContext({});
|
9
|
+
|
10
|
+
const BulkDeleteContextWrapper = ({
|
11
|
+
children, versions, onClose,
|
12
|
+
}) => {
|
13
|
+
const [selectedEnvForAK, setSelectedEnvForAK] = useState([]);
|
14
|
+
const [selectedCVForAK, setSelectedCVForAK] = useState(null);
|
15
|
+
const [selectedEnvForHosts, setSelectedEnvForHosts] = useState([]);
|
16
|
+
const [selectedCVForHosts, setSelectedCVForHosts] = useState(null);
|
17
|
+
const [currentStep, setCurrentStep] = useState(1);
|
18
|
+
|
19
|
+
return (
|
20
|
+
<BulkDeleteContext.Provider value={{
|
21
|
+
onClose,
|
22
|
+
versions,
|
23
|
+
selectedEnvForAK,
|
24
|
+
setSelectedEnvForAK,
|
25
|
+
selectedCVForAK,
|
26
|
+
setSelectedCVForAK,
|
27
|
+
selectedEnvForHosts,
|
28
|
+
setSelectedEnvForHosts,
|
29
|
+
selectedCVForHosts,
|
30
|
+
setSelectedCVForHosts,
|
31
|
+
currentStep,
|
32
|
+
setCurrentStep,
|
33
|
+
}}
|
34
|
+
>
|
35
|
+
{children}
|
36
|
+
</BulkDeleteContext.Provider>);
|
37
|
+
};
|
38
|
+
|
39
|
+
BulkDeleteContextWrapper.propTypes = {
|
40
|
+
versions: PropTypes.arrayOf(PropTypes.shape({})).isRequired,
|
41
|
+
onClose: PropTypes.func.isRequired,
|
42
|
+
children: PropTypes.element.isRequired,
|
43
|
+
};
|
44
|
+
|
45
|
+
export default BulkDeleteContextWrapper;
|
@@ -0,0 +1,30 @@
|
|
1
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
2
|
+
import { sum } from 'lodash';
|
3
|
+
|
4
|
+
export const getNumberOfActivationKeys = versions =>
|
5
|
+
sum(versions.map(({ environments }) =>
|
6
|
+
sum(environments.map(({ activation_key_count: akCount }) => akCount))));
|
7
|
+
|
8
|
+
export const getNumberOfHosts = versions =>
|
9
|
+
sum(versions.map(({ environments }) =>
|
10
|
+
sum(environments.map(({ host_count: hostCount }) => hostCount))));
|
11
|
+
|
12
|
+
// Gets a non-duplicated list of environments from within a given set of versions
|
13
|
+
export const getEnvironmentList = (versions) => {
|
14
|
+
const envIds = [];
|
15
|
+
const environmentList = [];
|
16
|
+
versions.forEach(({ environments }) => environments.forEach((env) => {
|
17
|
+
if (!envIds.includes(env.id)) {
|
18
|
+
environmentList.push(env);
|
19
|
+
envIds.push(env.id);
|
20
|
+
}
|
21
|
+
}));
|
22
|
+
return environmentList;
|
23
|
+
};
|
24
|
+
|
25
|
+
export const getNumberOfEnvironments = versions => getEnvironmentList(versions).length;
|
26
|
+
|
27
|
+
// Creates a string from a list of versions: '3.0' or '3.0 and 2.0' or '3.0, 2.0 and 1.0' etc.
|
28
|
+
export const getVersionListString = versions => versions.map(({ version }, index) =>
|
29
|
+
`${index > 0 && index === (versions.length - 1) ?
|
30
|
+
__(' and') : ''} ${version}${versions.length - index > 2 ? ',' : ''}`).join('');
|
@@ -0,0 +1,56 @@
|
|
1
|
+
import React, { useContext } from 'react';
|
2
|
+
|
3
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
+
import { PropTypes } from 'prop-types';
|
5
|
+
import { FormattedMessage } from 'react-intl';
|
6
|
+
|
7
|
+
import { Wizard } from '@patternfly/react-core';
|
8
|
+
|
9
|
+
import BulkDeleteContextWrapper, {
|
10
|
+
BulkDeleteContext,
|
11
|
+
} from './BulkDeleteContextWrapper';
|
12
|
+
import {
|
13
|
+
getVersionListString,
|
14
|
+
} from './BulkDeleteHelpers';
|
15
|
+
import bulkDeleteSteps from './bulkDeleteSteps';
|
16
|
+
|
17
|
+
const BulkDeleteModal = ({ versions, onClose }) => {
|
18
|
+
const WizardWithContext = () => {
|
19
|
+
const context = useContext(BulkDeleteContext);
|
20
|
+
const versionList = getVersionListString(versions);
|
21
|
+
const description =
|
22
|
+
(<FormattedMessage
|
23
|
+
id="bulk-delete-modal-title"
|
24
|
+
values={{ versionList }}
|
25
|
+
defaultMessage={versions.length === 1 ?
|
26
|
+
__('Deleting version {versionList}') :
|
27
|
+
__('Deleting versions: {versionList}')}
|
28
|
+
/>);
|
29
|
+
|
30
|
+
return (
|
31
|
+
<Wizard
|
32
|
+
title={versions.length === 1 ?
|
33
|
+
__('Delete version') :
|
34
|
+
__('Delete versions')}
|
35
|
+
description={description}
|
36
|
+
steps={bulkDeleteSteps(context)}
|
37
|
+
onGoToStep={({ id }) => context.setCurrentStep(id)}
|
38
|
+
onNext={({ id }) => context.setCurrentStep(id)}
|
39
|
+
onBack={({ id }) => context.setCurrentStep(id)}
|
40
|
+
onClose={onClose}
|
41
|
+
isOpen
|
42
|
+
/>);
|
43
|
+
};
|
44
|
+
|
45
|
+
return (
|
46
|
+
<BulkDeleteContextWrapper {...{ versions, onClose }}>
|
47
|
+
<WizardWithContext />
|
48
|
+
</BulkDeleteContextWrapper>
|
49
|
+
);
|
50
|
+
};
|
51
|
+
|
52
|
+
BulkDeleteModal.propTypes = {
|
53
|
+
versions: PropTypes.arrayOf(PropTypes.shape({})).isRequired,
|
54
|
+
onClose: PropTypes.func.isRequired,
|
55
|
+
};
|
56
|
+
export default BulkDeleteModal;
|
@@ -0,0 +1,126 @@
|
|
1
|
+
import React, { useContext } from 'react';
|
2
|
+
|
3
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
+
import { first } from 'lodash';
|
5
|
+
import { FormattedMessage } from 'react-intl';
|
6
|
+
import { useSelector } from 'react-redux';
|
7
|
+
|
8
|
+
import {
|
9
|
+
Flex,
|
10
|
+
FlexItem,
|
11
|
+
Label,
|
12
|
+
} from '@patternfly/react-core';
|
13
|
+
|
14
|
+
import WizardHeader from '../../../../components/WizardHeader';
|
15
|
+
import { selectContentViews } from '../../../../ContentViewSelectors';
|
16
|
+
import ActionSummary from '../ActionSummary';
|
17
|
+
import { BulkDeleteContext } from '../BulkDeleteContextWrapper';
|
18
|
+
import {
|
19
|
+
getEnvironmentList,
|
20
|
+
getNumberOfActivationKeys,
|
21
|
+
getNumberOfHosts,
|
22
|
+
getVersionListString,
|
23
|
+
} from '../BulkDeleteHelpers';
|
24
|
+
|
25
|
+
export default () => {
|
26
|
+
const {
|
27
|
+
versions, selectedCVForHosts, selectedEnvForHosts, selectedCVForAK, selectedEnvForAK,
|
28
|
+
} = useContext(BulkDeleteContext);
|
29
|
+
const { results: contentViewResults = [] } = useSelector(selectContentViews);
|
30
|
+
const versionList = getVersionListString(versions);
|
31
|
+
const numberOfActivationKeys = getNumberOfActivationKeys(versions);
|
32
|
+
const numberOfHosts = getNumberOfHosts(versions);
|
33
|
+
const affectedVersions = versions.filter(({ environments }) => !!environments.length);
|
34
|
+
const affectedVersionsListString = getVersionListString(affectedVersions);
|
35
|
+
const environments = getEnvironmentList(versions);
|
36
|
+
const pluralEnvironments = environments.length > 1;
|
37
|
+
|
38
|
+
return (
|
39
|
+
<>
|
40
|
+
<WizardHeader
|
41
|
+
title={__('Review details')}
|
42
|
+
/>
|
43
|
+
<ActionSummary
|
44
|
+
title={__('Versions')}
|
45
|
+
text={<FormattedMessage
|
46
|
+
id="bulk-delete-summary-versions"
|
47
|
+
values={{
|
48
|
+
versionList,
|
49
|
+
versionOrVersions: versions.length > 1 ?
|
50
|
+
__('Versions') : __('Version'),
|
51
|
+
}}
|
52
|
+
defaultMessage={__('{versionOrVersions} {versionList} will be deleted and will no longer be available for promotion.')}
|
53
|
+
/>}
|
54
|
+
/>
|
55
|
+
{!!affectedVersions.length &&
|
56
|
+
<div>
|
57
|
+
<ActionSummary
|
58
|
+
title={__('Environments')}
|
59
|
+
text={
|
60
|
+
<FormattedMessage
|
61
|
+
id="bulk-delete-summary-environments"
|
62
|
+
values={{
|
63
|
+
versionList: affectedVersionsListString,
|
64
|
+
versionOrVersions: affectedVersions.length > 1 ? __('Versions ') : __('Version '),
|
65
|
+
envLabel: (() => {
|
66
|
+
const { id, name } = first(environments);
|
67
|
+
return <Label isTruncated color="purple" href={`/lifecycle_environments/${id}`}>{name}</Label>;
|
68
|
+
})(),
|
69
|
+
}}
|
70
|
+
defaultMessage={pluralEnvironments ?
|
71
|
+
__('{versionOrVersions} {versionList} will be removed from the following environments:') :
|
72
|
+
__('{versionOrVersions} {versionList} will be removed from the {envLabel} environment.')}
|
73
|
+
/>
|
74
|
+
}
|
75
|
+
/>
|
76
|
+
{pluralEnvironments &&
|
77
|
+
<Flex>
|
78
|
+
{environments.map(({ name, id }) => (
|
79
|
+
<FlexItem key={id}>
|
80
|
+
<Label isTruncated color="purple" href={`/lifecycle_environments/${id}`}>{name}</Label>
|
81
|
+
</FlexItem>))
|
82
|
+
}
|
83
|
+
</Flex>}
|
84
|
+
</div>
|
85
|
+
}
|
86
|
+
{!!numberOfHosts &&
|
87
|
+
<ActionSummary
|
88
|
+
title={__('Hosts')}
|
89
|
+
text={
|
90
|
+
<FormattedMessage
|
91
|
+
id="bulk-delete-summary-hosts"
|
92
|
+
values={{
|
93
|
+
numberOfHosts,
|
94
|
+
cvName: contentViewResults
|
95
|
+
.find(({ id }) => id === selectedCVForHosts)?.name || '',
|
96
|
+
}}
|
97
|
+
defaultMessage={numberOfHosts > 1 ?
|
98
|
+
__('{numberOfHosts} hosts will be assigned to content view {cvName} in') :
|
99
|
+
__('{numberOfHosts} host will be assigned to content view {cvName} in')}
|
100
|
+
/>
|
101
|
+
}
|
102
|
+
selectedEnv={first(selectedEnvForHosts)}
|
103
|
+
/>}
|
104
|
+
{!!numberOfActivationKeys &&
|
105
|
+
<ActionSummary
|
106
|
+
title={__('Activation keys')}
|
107
|
+
text={
|
108
|
+
<FormattedMessage
|
109
|
+
id="bulk-delete-summary-activation-keys"
|
110
|
+
values={{
|
111
|
+
numberOfActivationKeys,
|
112
|
+
cvName: contentViewResults
|
113
|
+
.find(({ id }) => id === selectedCVForAK)?.name || '',
|
114
|
+
}}
|
115
|
+
defaultMessage={numberOfActivationKeys > 1 ?
|
116
|
+
__('{numberOfActivationKeys} activation keys will be assigned to content view {cvName} in') :
|
117
|
+
__('{numberOfActivationKeys} activation key will be assigned to content view {cvName} in')}
|
118
|
+
/>
|
119
|
+
}
|
120
|
+
selectedEnv={first(selectedEnvForAK)}
|
121
|
+
/>
|
122
|
+
}
|
123
|
+
</>
|
124
|
+
);
|
125
|
+
};
|
126
|
+
|
@@ -0,0 +1,61 @@
|
|
1
|
+
import React, { useContext } from 'react';
|
2
|
+
|
3
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
+
import { first } from 'lodash';
|
5
|
+
import {
|
6
|
+
useDispatch,
|
7
|
+
} from 'react-redux';
|
8
|
+
import useDeepCompareEffect from 'use-deep-compare-effect';
|
9
|
+
|
10
|
+
import Loading from '../../../../../../components/Loading';
|
11
|
+
import getContentViewDetails, {
|
12
|
+
bulkDeleteContentViewVersion,
|
13
|
+
} from '../../../ContentViewDetailActions';
|
14
|
+
|
15
|
+
import { BulkDeleteContext } from '../BulkDeleteContextWrapper';
|
16
|
+
|
17
|
+
export default () => {
|
18
|
+
const {
|
19
|
+
onClose,
|
20
|
+
versions,
|
21
|
+
selectedEnvForAK,
|
22
|
+
selectedCVForAK,
|
23
|
+
selectedEnvForHosts,
|
24
|
+
selectedCVForHosts,
|
25
|
+
} = useContext(BulkDeleteContext);
|
26
|
+
const { content_view: { id: cvId } } = first(versions);
|
27
|
+
|
28
|
+
const dispatch = useDispatch();
|
29
|
+
|
30
|
+
// Call the remove api on load
|
31
|
+
useDeepCompareEffect(() => {
|
32
|
+
dispatch(bulkDeleteContentViewVersion(
|
33
|
+
cvId,
|
34
|
+
{
|
35
|
+
bulk_content_view_version_ids: {
|
36
|
+
included: {
|
37
|
+
ids: versions.map(({ id }) => id),
|
38
|
+
},
|
39
|
+
excluded: {},
|
40
|
+
},
|
41
|
+
id: cvId,
|
42
|
+
system_content_view_id: selectedCVForHosts ?? undefined,
|
43
|
+
system_environment_id: first(selectedEnvForHosts)?.id ?? undefined,
|
44
|
+
key_content_view_id: selectedCVForAK ?? undefined,
|
45
|
+
key_environment_id: first(selectedEnvForAK)?.id ?? undefined,
|
46
|
+
},
|
47
|
+
// Callback to update on success
|
48
|
+
() => {
|
49
|
+
onClose(true);
|
50
|
+
dispatch(getContentViewDetails(cvId));
|
51
|
+
},
|
52
|
+
// onError
|
53
|
+
() => { onClose(true); },
|
54
|
+
));
|
55
|
+
}, [dispatch, cvId, versions,
|
56
|
+
selectedCVForHosts, selectedEnvForHosts, selectedCVForAK, selectedEnvForAK, onClose]);
|
57
|
+
|
58
|
+
|
59
|
+
return <Loading loadingText={__('Please wait while the task starts..')} />;
|
60
|
+
};
|
61
|
+
|
@@ -0,0 +1,196 @@
|
|
1
|
+
import React, {
|
2
|
+
useContext,
|
3
|
+
useState,
|
4
|
+
} from 'react';
|
5
|
+
|
6
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
7
|
+
import { STATUS } from 'foremanReact/constants';
|
8
|
+
import { first } from 'lodash';
|
9
|
+
import { FormattedMessage } from 'react-intl';
|
10
|
+
import {
|
11
|
+
useDispatch,
|
12
|
+
useSelector,
|
13
|
+
} from 'react-redux';
|
14
|
+
import useDeepCompareEffect from 'use-deep-compare-effect';
|
15
|
+
|
16
|
+
import {
|
17
|
+
Button,
|
18
|
+
ExpandableSection,
|
19
|
+
Popover,
|
20
|
+
PopoverPosition,
|
21
|
+
Select,
|
22
|
+
SelectDirection,
|
23
|
+
SelectOption,
|
24
|
+
TextContent,
|
25
|
+
} from '@patternfly/react-core';
|
26
|
+
import { OutlinedQuestionCircleIcon } from '@patternfly/react-icons';
|
27
|
+
|
28
|
+
import EnvironmentPaths
|
29
|
+
from '../../../../components/EnvironmentPaths/EnvironmentPaths';
|
30
|
+
import WizardHeader from '../../../../components/WizardHeader';
|
31
|
+
import getContentViews from '../../../../ContentViewsActions';
|
32
|
+
import {
|
33
|
+
selectContentViews,
|
34
|
+
selectContentViewStatus,
|
35
|
+
} from '../../../../ContentViewSelectors';
|
36
|
+
import AffectedActivationKeys from '../../Delete/affectedActivationKeys';
|
37
|
+
import { BulkDeleteContext } from '../BulkDeleteContextWrapper';
|
38
|
+
import {
|
39
|
+
getEnvironmentList,
|
40
|
+
getNumberOfActivationKeys,
|
41
|
+
} from '../BulkDeleteHelpers';
|
42
|
+
|
43
|
+
export default () => {
|
44
|
+
const dispatch = useDispatch();
|
45
|
+
const {
|
46
|
+
selectedEnvForAK,
|
47
|
+
setSelectedEnvForAK,
|
48
|
+
versions,
|
49
|
+
selectedCVForAK,
|
50
|
+
setSelectedCVForAK,
|
51
|
+
} = useContext(BulkDeleteContext);
|
52
|
+
|
53
|
+
const { results = [] } = useSelector(selectContentViews);
|
54
|
+
const { content_view: { id: cvId } } = first(versions);
|
55
|
+
const contentViewsInEnvStatus = useSelector(selectContentViewStatus);
|
56
|
+
const cvInEnvLoading = contentViewsInEnvStatus === STATUS.PENDING;
|
57
|
+
const [toggleCVSelect, setToggleCVSelect] = useState(false);
|
58
|
+
|
59
|
+
const numberOfActivationKeys = getNumberOfActivationKeys(versions);
|
60
|
+
const versionEnvironments = getEnvironmentList(versions);
|
61
|
+
|
62
|
+
useDeepCompareEffect(
|
63
|
+
() => {
|
64
|
+
if (selectedEnvForAK.length) {
|
65
|
+
dispatch(getContentViews({
|
66
|
+
environment_id: first(selectedEnvForAK).id,
|
67
|
+
include_default: true,
|
68
|
+
full_result: true,
|
69
|
+
}));
|
70
|
+
}
|
71
|
+
},
|
72
|
+
[selectedEnvForAK, dispatch],
|
73
|
+
);
|
74
|
+
|
75
|
+
const contentViewEligible = (id) => {
|
76
|
+
if (id === cvId) {
|
77
|
+
return (versionEnvironments.filter(env =>
|
78
|
+
env.id === first(selectedEnvForAK)?.id).length === 0);
|
79
|
+
}
|
80
|
+
return true;
|
81
|
+
};
|
82
|
+
|
83
|
+
const selectOptions = results.filter(({ id }) => contentViewEligible(id))
|
84
|
+
.map(({ id, name }) => (
|
85
|
+
<SelectOption
|
86
|
+
key={id}
|
87
|
+
value={id}
|
88
|
+
>
|
89
|
+
{name}
|
90
|
+
</SelectOption>));
|
91
|
+
|
92
|
+
const placeHolder = (() => {
|
93
|
+
switch (true) {
|
94
|
+
case cvInEnvLoading && !!selectedEnvForAK.length:
|
95
|
+
return __('Loading...');
|
96
|
+
case selectedEnvForAK.length === 0:
|
97
|
+
return __('Select an environment above');
|
98
|
+
case selectOptions.length > 0:
|
99
|
+
return __('Select a content view');
|
100
|
+
default:
|
101
|
+
return __('No content views available');
|
102
|
+
}
|
103
|
+
})();
|
104
|
+
|
105
|
+
const setUserCheckedItems = (value) => {
|
106
|
+
setSelectedCVForAK(null);
|
107
|
+
setSelectedEnvForAK(value);
|
108
|
+
};
|
109
|
+
|
110
|
+
const onSelect = (_event, selection) => {
|
111
|
+
setSelectedCVForAK(selection);
|
112
|
+
setToggleCVSelect(false);
|
113
|
+
};
|
114
|
+
|
115
|
+
return (
|
116
|
+
<>
|
117
|
+
<WizardHeader
|
118
|
+
title={numberOfActivationKeys > 1 ?
|
119
|
+
__('Reassign affected activation keys') :
|
120
|
+
__('Reassign affected activation key')}
|
121
|
+
description={
|
122
|
+
<>
|
123
|
+
<FormattedMessage
|
124
|
+
id="there-are-x-activation-keys"
|
125
|
+
values={{
|
126
|
+
numberOfActivationKeys,
|
127
|
+
}}
|
128
|
+
defaultMessage={numberOfActivationKeys > 1 ?
|
129
|
+
__('There are {numberOfActivationKeys} activation keys that need to be reassigned.') :
|
130
|
+
__('There is {numberOfActivationKeys} activation key that needs to be reassigned.')
|
131
|
+
}
|
132
|
+
/>
|
133
|
+
<br />
|
134
|
+
<>
|
135
|
+
{numberOfActivationKeys > 1 ?
|
136
|
+
__('Please select a lifecycle environment and a content view to move these activation keys.') :
|
137
|
+
__('Please select a lifecycle environment and a content view to move this activation key.')}
|
138
|
+
<Popover
|
139
|
+
appendTo={() => document.body}
|
140
|
+
aria-label="activationKeys-popover"
|
141
|
+
position={PopoverPosition.top}
|
142
|
+
bodyContent={
|
143
|
+
__('Before removing versions you must move activation keys to an environment where the associated version is not in use.')
|
144
|
+
}
|
145
|
+
>
|
146
|
+
<Button ouiaId="reassign-activation-keys-info" style={{ padding: '8px' }} variant="plain" aria-label="popoverButton">
|
147
|
+
<OutlinedQuestionCircleIcon />
|
148
|
+
</Button>
|
149
|
+
</Popover>
|
150
|
+
</>
|
151
|
+
</>
|
152
|
+
}
|
153
|
+
/>
|
154
|
+
<ExpandableSection
|
155
|
+
toggleTextCollapsed={__('Show affected activation keys')}
|
156
|
+
toggleTextExpanded={__('Hide affected activation keys')}
|
157
|
+
>
|
158
|
+
<AffectedActivationKeys
|
159
|
+
{...{
|
160
|
+
cvId,
|
161
|
+
}}
|
162
|
+
versionEnvironments={versionEnvironments}
|
163
|
+
deleteCV
|
164
|
+
/>
|
165
|
+
</ExpandableSection >
|
166
|
+
<EnvironmentPaths
|
167
|
+
userCheckedItems={selectedEnvForAK}
|
168
|
+
setUserCheckedItems={setUserCheckedItems}
|
169
|
+
publishing={false}
|
170
|
+
headerText={__('Select an environment')}
|
171
|
+
multiSelect={false}
|
172
|
+
/>
|
173
|
+
<TextContent>
|
174
|
+
{__('Select a content view')}
|
175
|
+
</TextContent>
|
176
|
+
<Select
|
177
|
+
selections={selectedCVForAK}
|
178
|
+
onSelect={onSelect}
|
179
|
+
isDisabled={cvInEnvLoading || !selectOptions?.length || !selectedEnvForAK?.length}
|
180
|
+
id="selectCV"
|
181
|
+
name="selectCV"
|
182
|
+
aria-label="selectCV"
|
183
|
+
placeholderText={placeHolder}
|
184
|
+
isOpen={toggleCVSelect}
|
185
|
+
onToggle={setToggleCVSelect}
|
186
|
+
menuAppendTo={() => document.body}
|
187
|
+
direction={SelectDirection.up}
|
188
|
+
maxHeight={300}
|
189
|
+
width={350}
|
190
|
+
>
|
191
|
+
{selectOptions}
|
192
|
+
</Select>
|
193
|
+
</>
|
194
|
+
);
|
195
|
+
};
|
196
|
+
|