katello 4.5.0.rc2 → 4.6.0.rc2
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_dynflow_proxy_controller.rb +10 -0
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +3 -0
- data/app/controllers/katello/api/v2/activation_keys_controller.rb +7 -0
- data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +52 -22
- data/app/controllers/katello/api/v2/content_exports_controller.rb +33 -3
- data/app/controllers/katello/api/v2/content_uploads_controller.rb +2 -0
- data/app/controllers/katello/api/v2/content_view_filter_rules_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_views_controller.rb +1 -1
- data/app/controllers/katello/api/v2/debs_controller.rb +42 -10
- data/app/controllers/katello/api/v2/host_collections_controller.rb +5 -1
- data/app/controllers/katello/api/v2/host_errata_controller.rb +1 -0
- data/app/controllers/katello/api/v2/host_module_streams_controller.rb +9 -1
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +8 -1
- data/app/controllers/katello/api/v2/organizations_controller.rb +3 -1
- data/app/controllers/katello/api/v2/simple_content_access_controller.rb +8 -0
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +34 -11
- data/app/controllers/katello/concerns/organizations_controller_extensions.rb +7 -16
- data/app/lib/actions/katello/alternate_content_source/alternate_content_source_common.rb +16 -0
- data/app/lib/actions/katello/alternate_content_source/create.rb +11 -5
- data/app/lib/actions/katello/alternate_content_source/destroy.rb +3 -4
- data/app/lib/actions/katello/alternate_content_source/refresh.rb +3 -5
- data/app/lib/actions/katello/alternate_content_source/update.rb +57 -13
- data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +2 -2
- data/app/lib/actions/katello/content_view/promote_to_environment.rb +4 -2
- data/app/lib/actions/katello/content_view/publish.rb +5 -2
- data/app/lib/actions/katello/organization/environment_contents_refresh.rb +20 -0
- data/app/lib/actions/katello/organization/manifest_refresh.rb +10 -4
- data/app/lib/actions/katello/organization/simple_content_access/toggle.rb +1 -9
- data/app/lib/actions/katello/repository/create.rb +9 -0
- data/app/lib/actions/katello/repository/destroy.rb +21 -0
- data/app/lib/actions/katello/repository/errata_mail.rb +3 -3
- data/app/lib/actions/katello/repository/refresh_repository.rb +3 -0
- data/app/lib/actions/katello/repository/update.rb +33 -0
- data/app/lib/actions/katello/repository/update_redhat_repository.rb +1 -1
- data/app/lib/actions/pulp3/alternate_content_source/create.rb +5 -4
- data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +5 -4
- data/app/lib/actions/pulp3/alternate_content_source/delete.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/refresh.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/update.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +5 -5
- data/app/lib/actions/pulp3/capsule_content/reclaim_space.rb +1 -0
- data/app/lib/actions/pulp3/content_view_version/create_export_history.rb +3 -1
- data/app/lib/actions/pulp3/content_view_version/create_exporter.rb +9 -2
- data/app/lib/actions/pulp3/content_view_version/create_syncable_export_history.rb +45 -0
- data/app/lib/actions/pulp3/content_view_version/destroy_exporter.rb +6 -1
- data/app/lib/actions/pulp3/content_view_version/export.rb +8 -3
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +6 -7
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh.rb +2 -2
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh_remote.rb +18 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/export.rb +28 -13
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_library.rb +6 -4
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_repository.rb +6 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/syncable_export.rb +82 -0
- data/app/lib/actions/pulp3/orchestration/repository/generate_metadata.rb +1 -1
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +25 -12
- data/app/lib/katello/errors.rb +1 -1
- data/app/lib/katello/resources/candlepin/owner.rb +9 -2
- data/app/lib/katello/validators/alternate_content_source_products_validator.rb +17 -0
- data/app/models/katello/alternate_content_source.rb +39 -8
- data/app/models/katello/alternate_content_source_product.rb +13 -0
- data/app/models/katello/authorization/repository.rb +4 -2
- data/app/models/katello/concerns/host_managed_extensions.rb +12 -2
- data/app/models/katello/concerns/pulp_database_unit.rb +2 -2
- data/app/models/katello/concerns/smart_proxy_extensions.rb +5 -6
- data/app/models/katello/content_view.rb +50 -32
- data/app/models/katello/content_view_deb_filter.rb +51 -0
- data/app/models/katello/content_view_deb_filter_rule.rb +24 -0
- data/app/models/katello/content_view_filter.rb +10 -3
- data/app/models/katello/glue/candlepin/owner.rb +0 -1
- data/app/models/katello/installed_package.rb +1 -0
- data/app/models/katello/product.rb +3 -0
- data/app/models/katello/repository.rb +5 -3
- data/app/models/katello/rpm.rb +1 -0
- data/app/models/katello/smart_proxy_alternate_content_source.rb +6 -0
- data/app/services/cert/certs.rb +8 -16
- data/app/services/katello/organization_creator.rb +18 -7
- data/app/services/katello/pulp/server.rb +2 -2
- data/app/services/katello/pulp3/alternate_content_source.rb +22 -4
- data/app/services/katello/pulp3/api/apt.rb +12 -0
- data/app/services/katello/pulp3/api/core.rb +8 -0
- data/app/services/katello/pulp3/api/generic.rb +0 -4
- data/app/services/katello/pulp3/content_view_version/export.rb +61 -17
- data/app/services/katello/pulp3/content_view_version/import.rb +12 -5
- data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +20 -5
- data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +3 -1
- data/app/services/katello/pulp3/content_view_version/syncable_format_export.rb +34 -0
- data/app/services/katello/pulp3/deb.rb +3 -1
- data/app/services/katello/pulp3/pulp_content_unit.rb +2 -0
- data/app/services/katello/pulp3/repository/apt.rb +186 -2
- data/app/services/katello/pulp3/repository.rb +5 -4
- data/app/services/katello/pulp3/service_common.rb +1 -1
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +1 -1
- data/app/views/foreman/job_templates/install_errata_by_search_query.erb +4 -3
- data/app/views/foreman/smart_proxies/show.html.erb +3 -3
- data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +18 -3
- data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +20 -0
- data/app/views/katello/api/v2/ansible_collections/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +1 -1
- data/app/views/katello/api/v2/content_view_filters/base.json.rabl +5 -0
- data/app/views/katello/api/v2/module_streams/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/organizations/show.json.rabl +1 -1
- data/app/views/katello/api/v2/repository_sets/show.json.rabl +4 -0
- data/app/views/katello/layouts/foreman_with_bastion.html.erb +1 -1
- data/app/views/katello/layouts/react.html.erb +1 -1
- data/app/views/overrides/organizations/_edit_override.html.erb +5 -8
- data/app/views/overrides/organizations/_index_row_override.html.erb +1 -1
- data/app/views/overrides/organizations/_step_1_override.html.erb +5 -0
- data/ca/redhat-uep.pem +18 -23
- data/config/katello.yaml.example +0 -2
- data/config/routes/api/v2.rb +2 -0
- data/config/routes/overrides.rb +1 -0
- data/db/migrate/20201116161820_create_content_view_deb_filter_rules.rb +17 -0
- data/db/migrate/20211220185935_clean_duplicate_content_units.rb +11 -9
- data/db/migrate/20220524132259_remove_last_refreshed_from_katello_alternate_content_sources.rb +5 -0
- data/db/migrate/20220601163911_add_vendor_to_katello_installed_packages.rb +5 -0
- data/db/migrate/20220610165621_add_repositories_and_products_to_acs.rb +23 -0
- data/engines/bastion/app/views/bastion/layouts/application.html.erb +1 -1
- data/engines/bastion/app/views/bastion/layouts/application_ie.html.erb +1 -1
- data/engines/bastion/app/views/bastion/layouts/assets.html.erb +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/activation-keys.routes.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages.controller.js +11 -3
- 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/environments/details/environment-content.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-content-views.html +1 -1
- 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/views/environments.html +3 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +4 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +0 -3
- data/engines/bastion_katello/lib/bastion_katello/engine.rb +0 -1
- data/lib/katello/engine.rb +1 -2
- data/lib/katello/permission_creator.rb +2 -2
- data/lib/katello/permissions/host_permissions.rb +1 -0
- data/lib/katello/plugin.rb +6 -12
- data/lib/katello/tasks/refresh_alternate_content_sources.rake +9 -4
- data/lib/katello/tasks/refresh_repos.rake +8 -0
- data/lib/katello/version.rb +1 -1
- data/locale/action_names.rb +49 -46
- data/locale/bn/katello.po +361 -53
- data/locale/cs/katello.po +361 -53
- data/locale/de/katello.po +366 -58
- data/locale/en/katello.po +361 -53
- data/locale/es/katello.po +364 -56
- data/locale/fr/katello.po +374 -66
- data/locale/gu/katello.po +361 -53
- data/locale/hi/katello.po +361 -53
- data/locale/it/katello.po +361 -53
- data/locale/ja/katello.po +374 -66
- data/locale/katello.pot +1626 -1079
- data/locale/kn/katello.po +361 -53
- data/locale/ko/katello.po +361 -53
- data/locale/mr/katello.po +361 -53
- data/locale/or/katello.po +361 -53
- data/locale/pa/katello.po +361 -53
- data/locale/pt/katello.po +361 -53
- data/locale/pt_BR/katello.po +364 -56
- data/locale/ru/katello.po +361 -53
- data/locale/ta/katello.po +361 -53
- data/locale/te/katello.po +361 -53
- data/locale/zh_CN/katello.po +374 -66
- data/locale/zh_TW/katello.po +361 -53
- data/webpack/components/EditableTextInput/EditableTextInput.js +3 -16
- data/webpack/components/EditableTextInput/PencilEditButton.js +33 -0
- data/webpack/components/Errata/index.js +18 -3
- data/webpack/components/Loading.js +1 -1
- data/webpack/components/RoutedTabs/index.js +1 -17
- data/webpack/components/Search/Search.js +0 -1
- data/webpack/components/Search/__tests__/search.test.js +1 -2
- data/webpack/components/SelectAllCheckbox/index.js +7 -4
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +1 -0
- data/webpack/components/Table/EmptyStateMessage.js +77 -2
- data/webpack/components/Table/MainTable.js +46 -4
- data/webpack/components/Table/TableHooks.js +8 -4
- data/webpack/components/Table/TableWrapper.js +14 -8
- data/webpack/components/TypeAhead/TypeAhead.js +26 -11
- data/webpack/components/TypeAhead/pf3Search/TypeAheadItems.js +1 -1
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +1 -0
- data/webpack/components/extensions/HostDetails/ActionsBar/index.js +8 -1
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +2 -1
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +9 -4
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeActions.js +37 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.js +175 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.scss +6 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeConstants.js +6 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeEditModal.js +301 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeSelectors.js +25 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeCard.test.js +109 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeEditModal.test.js +161 -0
- data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +12 -12
- data/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js +103 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +1 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/RegistrationCard.js +1 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +26 -4
- data/webpack/components/extensions/HostDetails/HostDetailsConstants.js +3 -1
- data/webpack/components/extensions/HostDetails/HostDetailsReducer.js +14 -0
- data/webpack/components/extensions/HostDetails/HostDetailsSelectors.js +8 -2
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +9 -1
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +23 -8
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +11 -9
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +58 -8
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +2 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +30 -3
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySets.fixtures.json +3 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +48 -20
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +1 -10
- data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +1 -1
- data/webpack/components/extensions/RegistrationCommands/index.js +49 -17
- data/webpack/containers/Application/config.js +5 -10
- data/webpack/global_index.js +19 -7
- data/webpack/global_test_setup.js +14 -2
- data/webpack/ouia_id_check.js +95 -0
- data/webpack/redux/actions/RedHatRepositories/helpers.js +2 -0
- data/webpack/redux/reducers/index.js +2 -4
- data/webpack/scenes/AlternateContentSources/ACSActions.js +36 -3
- data/webpack/scenes/AlternateContentSources/ACSConstants.js +3 -0
- data/webpack/scenes/AlternateContentSources/ACSSelectors.js +15 -6
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +73 -42
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +26 -10
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSProducts.js +44 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSReview.js +59 -45
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +4 -3
- data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +0 -1
- data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +35 -19
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +120 -13
- data/webpack/scenes/AlternateContentSources/Create/__tests__/products.fixtures.json +92 -0
- data/webpack/scenes/AlternateContentSources/Details/ACSExpandableDetails.js +459 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditCredentials.js +354 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditDetails.js +104 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditProducts.js +120 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditSmartProxies.js +118 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditURLPaths.js +118 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSEdits.test.js +242 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSExpandableDetails.test.js +106 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/acsDetails.fixtures.json +49 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/acsProducts.fixtures.json +95 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/simplifiedAcsDetails.fixtures.json +39 -0
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +215 -87
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.scss +3 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +1 -2
- data/webpack/scenes/Content/__tests__/contentTable.test.js +1 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +15 -4
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +2 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +113 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +89 -0
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +32 -9
- data/webpack/scenes/ContentViews/Details/Filters/Add/__tests__/cvFilterAdd.test.js +13 -3
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +39 -27
- data/webpack/scenes/ContentViews/Details/Filters/CVDebFilterContent.js +236 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVFilterDetailType.js +10 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +3 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +3 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +17 -4
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +34 -22
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVDebMatchContentModal.js +97 -0
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentModal.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Filters/Rules/DebPackage/AddEditDebPackageRuleModal.js +128 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +56 -3
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +62 -8
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/ContentViewPackageGroupFilter.test.js +1 -5
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +32 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataIDFilter.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilter.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVContainerImageFilterContent.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVPackageFilterRules.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyContentViewFilters.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +5 -1
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +3 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.js +143 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.scss +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareConfig.js +314 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareHeader.js +186 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareTable.js +74 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/AnsibleCollectionsCompareAllContentData.fixtures.json +63 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionCompare.test.js +657 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionEmptyContentCompareData.fixtures.json +14 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ContainerTagsCompareAllContentData.fixtures.json +95 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/DebPackagesCompareAllContentData.fixtures.json +87 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareAllContentData.fixtures.json +319 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareThreeContentTypesData.fixtures.json +131 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareAllContentData.fixtures.json +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareThreeContentTypesData.fixtures.json +48 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ModuleStreamsCompareAllContentData.fixtures.json +239 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PackageGroupsCompareAllContentData.fixtures.json +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PythonPackagesCompareAllContentData.fixtures.json +315 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareAllContentData.fixtures.json +470 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareThreeContentTypesData.fixtures.json +475 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewDetails.fixtures.json +160 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionOneDetials.fixtures.json +161 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionThreeDetails.fixtures.json +154 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionTwoDetails.fixtures.json +211 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersions.fixtures.json +1013 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionOneDetails.fixtures.json +145 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionTwoDetails.fixtures.json +145 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +102 -36
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +4 -2
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +113 -40
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +96 -81
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +1 -2
- data/webpack/scenes/ContentViews/__tests__/mockDetails.fixtures.json +7 -2
- data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +1 -1
- data/webpack/scenes/Subscriptions/Manifest/ManageManifestModal.js +0 -30
- data/webpack/test-utils/nockWrapper.js +7 -0
- metadata +83 -181
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +0 -751
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-deletion.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-activation-keys.controller.js +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-confirm.controller.js +0 -65
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +0 -82
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-environments.controller.js +0 -76
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion.controller.js +0 -160
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/content-view-deletion.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-activation-keys.html +0 -94
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-confirm.html +0 -76
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-content-hosts.html +0 -88
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-environments.html +0 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-component.factory.js +0 -32
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-available-content-views.controller.js +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-content-views-list.controller.js +0 -68
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-available-content-views.html +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-content-views-list.html +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite.html +0 -24
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-deb-repositories.controller.js +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-docker-repositories.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-file-repositories.controller.js +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-ostree-repositories.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-repositories.controller.js +0 -45
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-deb-repositories-list.controller.js +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-details.controller.js +0 -100
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-docker-repositories-list.controller.js +0 -49
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-file-repositories-list.controller.js +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-ostree-repositories-list.controller.js +0 -49
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-promotion.controller.js +0 -129
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-publish.controller.js +0 -46
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories-list.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories.service.js +0 -91
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-versions.controller.js +0 -240
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-errata-filter.controller.js +0 -115
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-module-stream-filter.controller.js +0 -68
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-package-group-filter.controller.js +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/date-type-errata-filter.controller.js +0 -77
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/docker-tag-filter.controller.js +0 -137
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/edit-filter.controller.js +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter-list.controller.js +0 -78
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter.controller.js +0 -74
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-content-type.filter.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-details.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-helper.service.js +0 -30
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-repositories.controller.js +0 -86
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-rule-matching-package-modal.controller.js +0 -37
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-type.filter.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter.factory.js +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filters.controller.js +0 -85
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/module-stream-list-filter.controller.js +0 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/new-filter.controller.js +0 -100
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-filter.controller.js +0 -179
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-group-list-filter.controller.js +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/rule.factory.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata-filter.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata.html +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-filter.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-tag-filter-details.html +0 -65
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/edit-filter.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter-details.html +0 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter.html +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-details.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-repositories.html +0 -121
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-rule-matching-package-modal.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filters.html +0 -85
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter-details.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/new-filter.html +0 -62
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +0 -182
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter-details.html +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/partials/filter-repositories-count.html +0 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.controller.js +0 -47
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.factory.js +0 -22
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/views/content-view-history.html +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-copy.html +0 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-deb-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details-tasks.html +0 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +0 -144
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-docker-repositories.html +0 -114
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-file-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-info.html +0 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-ostree-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-promotion.html +0 -59
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-publish.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-repositories.html +0 -116
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +0 -126
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/content-view-new.controller.js +0 -78
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/views/content-view-new.html +0 -127
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +0 -138
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version.controller.js +0 -59
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-apt.html +0 -25
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-components.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-deb.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-details.html +0 -15
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-docker.html +0 -23
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-errata.html +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-file.html +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-module-streams.html +0 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-package-groups.html +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-packages.html +0 -27
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-yum.html +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version.html +0 -83
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/views/content-views.html +0 -74
- data/lib/katello/tasks/reset.rake.bak +0 -67
- data/locale/bn/LC_MESSAGES/katello.mo +0 -0
- data/locale/cs/LC_MESSAGES/katello.mo +0 -0
- data/locale/de/LC_MESSAGES/katello.mo +0 -0
- data/locale/en/LC_MESSAGES/katello.mo +0 -0
- data/locale/es/LC_MESSAGES/katello.mo +0 -0
- data/locale/fr/LC_MESSAGES/katello.mo +0 -0
- data/locale/gu/LC_MESSAGES/katello.mo +0 -0
- data/locale/hi/LC_MESSAGES/katello.mo +0 -0
- data/locale/it/LC_MESSAGES/katello.mo +0 -0
- data/locale/ja/LC_MESSAGES/katello.mo +0 -0
- data/locale/kn/LC_MESSAGES/katello.mo +0 -0
- data/locale/ko/LC_MESSAGES/katello.mo +0 -0
- data/locale/mr/LC_MESSAGES/katello.mo +0 -0
- data/locale/or/LC_MESSAGES/katello.mo +0 -0
- data/locale/pa/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
- data/locale/ru/LC_MESSAGES/katello.mo +0 -0
- data/locale/ta/LC_MESSAGES/katello.mo +0 -0
- data/locale/te/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsActions.js +0 -30
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsConstants.js +0 -3
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsPage.js +0 -80
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsReducer.js +0 -39
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTableSchema.js +0 -60
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTables.scss +0 -0
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetails.js +0 -94
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsActions.js +0 -23
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsConstants.js +0 -3
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsReducer.js +0 -30
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionsSchema.js +0 -35
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailInfo.test.js +0 -16
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.fixtures.js +0 -25
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.test.js +0 -27
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsActions.test.js +0 -41
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsReducer.test.js +0 -33
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailInfo.test.js.snap +0 -83
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetails.test.js.snap +0 -190
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsActions.test.js.snap +0 -58
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsReducer.test.js.snap +0 -50
- data/webpack/scenes/AnsibleCollections/Details/index.js +0 -17
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionPage.test.js +0 -23
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollections.fixtures.js +0 -52
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsActions.test.js +0 -48
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsReducer.test.js +0 -46
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsTable.test.js +0 -25
- data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionPage.test.js.snap +0 -73
- data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionsTable.test.js.snap +0 -81
- data/webpack/scenes/AnsibleCollections/index.js +0 -17
- data/webpack/scenes/Subscriptions/Manifest/__tests__/ManageManifestModal.test.js +0 -123
@@ -37,6 +37,14 @@ import {
|
|
37
37
|
REPOSITORY_TYPES,
|
38
38
|
RPM_PACKAGE_GROUPS_CONTENT,
|
39
39
|
RPM_PACKAGES_CONTENT,
|
40
|
+
cvRPMPackagesCompareKey,
|
41
|
+
cvPackageGroupsCompareKey,
|
42
|
+
cvErrataCompareKey,
|
43
|
+
cvModuleStreamsCompareKey,
|
44
|
+
cvDockerTagsCompareKey,
|
45
|
+
cvDebPackagesCompareKey,
|
46
|
+
filesCompareKey,
|
47
|
+
genericContentCompareKey,
|
40
48
|
} from '../ContentViewsConstants';
|
41
49
|
|
42
50
|
export const selectCVDetails = (state, cvId) =>
|
@@ -126,6 +134,87 @@ export const selectCVHistoriesStatus = (state, cvId) =>
|
|
126
134
|
export const selectCVHistoriesError = (state, cvId) =>
|
127
135
|
selectAPIError(state, cvDetailsHistoryKey(cvId));
|
128
136
|
|
137
|
+
export const selectRPMPackagesComparison = (state, versionOne, versionTwo, viewBy) =>
|
138
|
+
selectAPIResponse(state, cvRPMPackagesCompareKey(versionOne, versionTwo, viewBy)) || {};
|
139
|
+
|
140
|
+
export const selectRPMPackagesComparisonStatus = (state, versionOne, versionTwo, viewBy) =>
|
141
|
+
selectAPIStatus(state, cvRPMPackagesCompareKey(versionOne, versionTwo, viewBy)) || STATUS.PENDING;
|
142
|
+
|
143
|
+
export const selectRPMPackagesComparisonError = (state, versionOne, versionTwo, viewBy) =>
|
144
|
+
selectAPIError(state, cvRPMPackagesCompareKey(versionOne, versionTwo, viewBy));
|
145
|
+
|
146
|
+
export const selectErrataComparison = (state, versionOne, versionTwo, viewBy) =>
|
147
|
+
selectAPIResponse(state, cvErrataCompareKey(versionOne, versionTwo, viewBy)) || {};
|
148
|
+
|
149
|
+
export const selectErrataComparisonStatus = (state, versionOne, versionTwo, viewBy) =>
|
150
|
+
selectAPIStatus(state, cvErrataCompareKey(versionOne, versionTwo, viewBy)) || STATUS.PENDING;
|
151
|
+
|
152
|
+
export const selectErrataComparisonError = (state, versionOne, versionTwo, viewBy) =>
|
153
|
+
selectAPIError(state, cvErrataCompareKey(versionOne, versionTwo, viewBy));
|
154
|
+
|
155
|
+
export const selectPackageGroupsComparison = (state, versionOne, versionTwo, viewBy) =>
|
156
|
+
selectAPIResponse(state, cvPackageGroupsCompareKey(versionOne, versionTwo, viewBy)) || {};
|
157
|
+
|
158
|
+
export const selectPackageGroupsComparisonStatus = (state, versionOne, versionTwo, viewBy) =>
|
159
|
+
selectAPIStatus(state, cvPackageGroupsCompareKey(versionOne, versionTwo, viewBy))
|
160
|
+
|| STATUS.PENDING;
|
161
|
+
|
162
|
+
export const selectPackageGroupsComparisonError = (state, versionOne, versionTwo, viewBy) =>
|
163
|
+
selectAPIError(state, cvPackageGroupsCompareKey(versionOne, versionTwo, viewBy));
|
164
|
+
|
165
|
+
export const selectModuleStreamsComparison = (state, versionOne, versionTwo, viewBy) =>
|
166
|
+
selectAPIResponse(state, cvModuleStreamsCompareKey(versionOne, versionTwo, viewBy)) || {};
|
167
|
+
|
168
|
+
export const selectModuleStreamsComparisonStatus = (state, versionOne, versionTwo, viewBy) =>
|
169
|
+
selectAPIStatus(state, cvModuleStreamsCompareKey(versionOne, versionTwo, viewBy))
|
170
|
+
|| STATUS.PENDING;
|
171
|
+
|
172
|
+
export const selectModuleStreamsComparisonError = (state, versionOne, versionTwo, viewBy) =>
|
173
|
+
selectAPIError(state, cvModuleStreamsCompareKey(versionOne, versionTwo, viewBy));
|
174
|
+
|
175
|
+
export const selectDockerTagsComparison = (state, versionOne, versionTwo, viewBy) =>
|
176
|
+
selectAPIResponse(state, cvDockerTagsCompareKey(versionOne, versionTwo, viewBy)) || {};
|
177
|
+
|
178
|
+
export const selectDockerTagsComparisonStatus = (state, versionOne, versionTwo, viewBy) =>
|
179
|
+
selectAPIStatus(state, cvDockerTagsCompareKey(versionOne, versionTwo, viewBy)) || STATUS.PENDING;
|
180
|
+
|
181
|
+
export const selectDockerTagsComparisonError = (state, versionOne, versionTwo, viewBy) =>
|
182
|
+
selectAPIError(state, cvDockerTagsCompareKey(versionOne, versionTwo, viewBy));
|
183
|
+
|
184
|
+
export const selectDebPackagesComparison = (state, versionOne, versionTwo, viewBy) =>
|
185
|
+
selectAPIResponse(state, cvDebPackagesCompareKey(versionOne, versionTwo, viewBy)) || {};
|
186
|
+
|
187
|
+
export const selectDebPackagesComparisonStatus = (state, versionOne, versionTwo, viewBy) =>
|
188
|
+
selectAPIStatus(state, cvDebPackagesCompareKey(versionOne, versionTwo, viewBy)) || STATUS.PENDING;
|
189
|
+
|
190
|
+
export const selectDebPackagesComparisonError = (state, versionOne, versionTwo, viewBy) =>
|
191
|
+
selectAPIError(state, cvDebPackagesCompareKey(versionOne, versionTwo, viewBy));
|
192
|
+
|
193
|
+
export const selectFilesComparison = (state, versionOne, versionTwo, viewBy) =>
|
194
|
+
selectAPIResponse(state, filesCompareKey(versionOne, versionTwo, viewBy)) || {};
|
195
|
+
|
196
|
+
export const selectFilesComparisonStatus = (state, versionOne, versionTwo, viewBy) =>
|
197
|
+
selectAPIStatus(state, filesCompareKey(versionOne, versionTwo, viewBy)) || STATUS.PENDING;
|
198
|
+
|
199
|
+
export const selectFilesComparisonError = (state, versionOne, versionTwo, viewBy) =>
|
200
|
+
selectAPIError(state, filesCompareKey(versionOne, versionTwo, viewBy));
|
201
|
+
|
202
|
+
export const selectGenericContentComparison =
|
203
|
+
(state, versionOne, versionTwo, pluralLabel, viewBy) =>
|
204
|
+
selectAPIResponse(
|
205
|
+
state,
|
206
|
+
genericContentCompareKey(pluralLabel, versionOne, versionTwo, viewBy),
|
207
|
+
) || {};
|
208
|
+
|
209
|
+
export const selectGenericContentComparisonStatus =
|
210
|
+
(state, versionOne, versionTwo, pluralLabel, viewBy) =>
|
211
|
+
selectAPIStatus(state, genericContentCompareKey(pluralLabel, versionOne, versionTwo, viewBy))
|
212
|
+
|| STATUS.PENDING;
|
213
|
+
|
214
|
+
export const selectGenericContentComparisonError =
|
215
|
+
(state, versionOne, versionTwo, pluralLabel, viewBy) =>
|
216
|
+
selectAPIError(state, genericContentCompareKey(pluralLabel, versionOne, versionTwo, viewBy));
|
217
|
+
|
129
218
|
export const selectCVFilterRules = (state, filterId) =>
|
130
219
|
selectAPIResponse(state, cvFilterRulesKey(filterId));
|
131
220
|
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import React, { useState } from 'react';
|
1
|
+
import React, { useState, useEffect } from 'react';
|
2
2
|
import useDeepCompareEffect from 'use-deep-compare-effect';
|
3
3
|
import { Redirect } from 'react-router-dom';
|
4
4
|
import { useDispatch, useSelector } from 'react-redux';
|
@@ -9,12 +9,11 @@ import {
|
|
9
9
|
Modal, ModalVariant, Form, FormGroup, TextInput, ActionGroup, Button, Radio, TextArea,
|
10
10
|
Split, SplitItem, Select, SelectOption,
|
11
11
|
} from '@patternfly/react-core';
|
12
|
-
import { addCVFilterRule, createContentViewFilter } from '../../ContentViewDetailActions';
|
13
|
-
import {
|
14
|
-
selectCreateContentViewFilter, selectCreateContentViewFilterStatus,
|
12
|
+
import { addCVFilterRule, createContentViewFilter, getRepositoryTypes } from '../../ContentViewDetailActions';
|
13
|
+
import { selectCreateContentViewFilter, selectCreateContentViewFilterStatus,
|
15
14
|
selectCreateContentViewFilterError, selectCreateFilterRule,
|
16
15
|
selectCreateFilterRuleError, selectCreateFilterRuleStatus,
|
17
|
-
} from '../../../Details/ContentViewDetailSelectors';
|
16
|
+
selectRepoTypes, selectRepoTypesStatus } from '../../../Details/ContentViewDetailSelectors';
|
18
17
|
import { FILTER_TYPES } from '../../../ContentViewsConstants';
|
19
18
|
import ContentType from '../ContentType';
|
20
19
|
|
@@ -32,7 +31,14 @@ const CVFilterAddModal = ({ cvId, onClose }) => {
|
|
32
31
|
const ruleResponse = useSelector(state => selectCreateFilterRule(state));
|
33
32
|
const ruleStatus = useSelector(state => selectCreateFilterRuleStatus(state));
|
34
33
|
const ruleError = useSelector(state => selectCreateFilterRuleError(state));
|
34
|
+
const repoTypesResponse = useSelector(state => selectRepoTypes(state));
|
35
|
+
const repoTypesStatus = useSelector(state => selectRepoTypesStatus(state));
|
35
36
|
const [redirect, setRedirect] = useState(false);
|
37
|
+
const [repoTypes, setRepoTypes] = useState([]);
|
38
|
+
|
39
|
+
useEffect(() => {
|
40
|
+
dispatch(getRepositoryTypes());
|
41
|
+
}, [dispatch]);
|
36
42
|
|
37
43
|
const onSubmit = () => {
|
38
44
|
setSaving(true);
|
@@ -75,6 +81,26 @@ const CVFilterAddModal = ({ cvId, onClose }) => {
|
|
75
81
|
}
|
76
82
|
}, [response, status, ruleResponse, ruleStatus, ruleError, saving]);
|
77
83
|
|
84
|
+
useDeepCompareEffect(() => {
|
85
|
+
if (repoTypesStatus === STATUS.RESOLVED && repoTypesResponse) {
|
86
|
+
const allRepoTypes = [];
|
87
|
+
repoTypesResponse.forEach((repoType) => {
|
88
|
+
const { name: repoTypeName } = repoType;
|
89
|
+
allRepoTypes.push(repoTypeName);
|
90
|
+
});
|
91
|
+
setRepoTypes(allRepoTypes);
|
92
|
+
}
|
93
|
+
}, [repoTypesResponse, repoTypesStatus]);
|
94
|
+
|
95
|
+
const filterTypeOptions = () => {
|
96
|
+
const filterTypeSelectOpions = FILTER_TYPES.map(item =>
|
97
|
+
<SelectOption key={item} value={item}><ContentType type={item} /></SelectOption>);
|
98
|
+
if (repoTypes.includes('deb')) {
|
99
|
+
filterTypeSelectOpions.push(<SelectOption key="deb" value="deb"><ContentType type="deb" /></SelectOption>);
|
100
|
+
}
|
101
|
+
return filterTypeSelectOpions;
|
102
|
+
};
|
103
|
+
|
78
104
|
if (redirect) {
|
79
105
|
const { id } = response;
|
80
106
|
return (<Redirect to={`/filters/${id}`} />);
|
@@ -114,10 +140,7 @@ const CVFilterAddModal = ({ cvId, onClose }) => {
|
|
114
140
|
name="content_type"
|
115
141
|
aria-label="ContentType"
|
116
142
|
>
|
117
|
-
{
|
118
|
-
FILTER_TYPES.map(item =>
|
119
|
-
<SelectOption key={item} value={item}><ContentType type={item} /></SelectOption>)
|
120
|
-
}
|
143
|
+
{ filterTypeOptions() }
|
121
144
|
</Select>
|
122
145
|
</FormGroup>
|
123
146
|
<FormGroup>
|
@@ -1,13 +1,14 @@
|
|
1
1
|
import React from 'react';
|
2
|
-
import {
|
2
|
+
import { fireEvent, patientlyWaitFor, renderWithRedux } from 'react-testing-lib-wrapper';
|
3
3
|
|
4
4
|
|
5
5
|
import api from '../../../../../../services/api';
|
6
6
|
import CVFilterAddModal from '../CVFilterAddModal';
|
7
|
-
import {
|
7
|
+
import { assertNockRequest, nockInstance } from '../../../../../../test-utils/nockWrapper';
|
8
8
|
import cvCreateData from './cvFilterCreateResult.fixtures.json';
|
9
9
|
|
10
10
|
const cvCreateFilterPath = api.getApiUrl('/content_view_filters?content_view_id=5');
|
11
|
+
const repoTypesResponse = [{ name: 'deb' }, { name: 'docker' }, { name: 'file' }, { name: 'ostree' }, { name: 'yum' }];
|
11
12
|
|
12
13
|
const setIsOpen = jest.fn();
|
13
14
|
|
@@ -26,6 +27,10 @@ test('Can save content view filter from form', (done) => {
|
|
26
27
|
const createFilterscope = nockInstance
|
27
28
|
.post(cvCreateFilterPath, createDetails)
|
28
29
|
.reply(201, createdCVDetails);
|
30
|
+
const repoTypeScope = nockInstance
|
31
|
+
.get(api.getApiUrl('/repositories/repository_types'))
|
32
|
+
.query(true)
|
33
|
+
.reply(200, repoTypesResponse);
|
29
34
|
const { queryByText, getByLabelText } = renderWithRedux(form);
|
30
35
|
expect(queryByText('Description')).toBeInTheDocument();
|
31
36
|
|
@@ -33,6 +38,7 @@ test('Can save content view filter from form', (done) => {
|
|
33
38
|
fireEvent.change(getByLabelText('input_description'), { target: { value: 'Creating filter' } });
|
34
39
|
|
35
40
|
fireEvent.submit(getByLabelText('create_filter'));
|
41
|
+
assertNockRequest(repoTypeScope);
|
36
42
|
assertNockRequest(createFilterscope, done);
|
37
43
|
});
|
38
44
|
|
@@ -40,6 +46,10 @@ test('Closes content view filter form upon save', async (done) => {
|
|
40
46
|
const createFilterscope = nockInstance
|
41
47
|
.post(cvCreateFilterPath, createDetails)
|
42
48
|
.reply(201, createdCVDetails);
|
49
|
+
const repoTypeScope = nockInstance
|
50
|
+
.get(api.getApiUrl('/repositories/repository_types'))
|
51
|
+
.query(true)
|
52
|
+
.reply(200, repoTypesResponse);
|
43
53
|
const { queryByText, getByLabelText } = renderWithRedux(form);
|
44
54
|
fireEvent.change(getByLabelText('input_name'), { target: { value: 'test' } });
|
45
55
|
fireEvent.change(getByLabelText('input_description'), { target: { value: 'Creating filter' } });
|
@@ -48,6 +58,6 @@ test('Closes content view filter form upon save', async (done) => {
|
|
48
58
|
await patientlyWaitFor(() => {
|
49
59
|
expect(queryByText('Description')).not.toBeInTheDocument();
|
50
60
|
});
|
51
|
-
|
61
|
+
assertNockRequest(repoTypeScope);
|
52
62
|
assertNockRequest(createFilterscope, done);
|
53
63
|
});
|
@@ -10,10 +10,10 @@ import {
|
|
10
10
|
TabTitleText,
|
11
11
|
Split,
|
12
12
|
SplitItem,
|
13
|
-
Button,
|
14
13
|
Dropdown,
|
15
14
|
DropdownItem,
|
16
15
|
KebabToggle,
|
16
|
+
Button,
|
17
17
|
} from '@patternfly/react-core';
|
18
18
|
import { STATUS } from 'foremanReact/constants';
|
19
19
|
import { translate as __ } from 'foremanReact/common/I18n';
|
@@ -30,7 +30,7 @@ import AffectedRepositoryTable from './AffectedRepositories/AffectedRepositoryTa
|
|
30
30
|
import { hasPermission } from '../../helpers';
|
31
31
|
|
32
32
|
const emptyContentTitle = __('No rules have been added to this filter.');
|
33
|
-
const emptyContentBody = __(
|
33
|
+
const emptyContentBody = __('Items will appear here when a filter rule is added.');
|
34
34
|
const emptySearchTitle = __('No matching filter rules found.');
|
35
35
|
const emptySearchBody = __('Try changing your search settings.');
|
36
36
|
|
@@ -55,7 +55,16 @@ const CVContainerImageFilterContent = ({
|
|
55
55
|
const hasSelected = rows.some(({ selected }) => selected);
|
56
56
|
const metadata = omit(response, ['results']);
|
57
57
|
const { permissions } = details;
|
58
|
-
|
58
|
+
const showPrimaryAction = true;
|
59
|
+
const primaryActionButton =
|
60
|
+
(
|
61
|
+
<Button
|
62
|
+
ouiaId="add-content-view-container-image-filter-button"
|
63
|
+
onClick={() => setModalOpen(true)}
|
64
|
+
variant="primary"
|
65
|
+
aria-label="add_filter_rule_empty_state"
|
66
|
+
> {__('Add filter rule')}
|
67
|
+
</Button>);
|
59
68
|
const onClose = () => {
|
60
69
|
setModalOpen(false);
|
61
70
|
setSelectedFilterRuleData(undefined);
|
@@ -130,6 +139,8 @@ const CVContainerImageFilterContent = ({
|
|
130
139
|
searchQuery,
|
131
140
|
updateSearchQuery,
|
132
141
|
status,
|
142
|
+
showPrimaryAction,
|
143
|
+
primaryActionButton,
|
133
144
|
}}
|
134
145
|
ouiaId="content-view-container-image-filter"
|
135
146
|
actionResolver={hasPermission(permissions, 'edit_content_views') ? actionResolver : null}
|
@@ -140,30 +151,31 @@ const CVContainerImageFilterContent = ({
|
|
140
151
|
fetchItems={useCallback(params => getCVFilterRules(filterId, params), [filterId])}
|
141
152
|
actionButtons={hasPermission(permissions, 'edit_content_views') &&
|
142
153
|
<>
|
143
|
-
|
144
|
-
<
|
145
|
-
<
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
<
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
{
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
154
|
+
{status === STATUS.RESOLVED && rows.length !== 0 &&
|
155
|
+
<Split hasGutter>
|
156
|
+
<SplitItem>
|
157
|
+
<Button
|
158
|
+
ouiaId="add-content-view-container-image-filter-button"
|
159
|
+
onClick={() => setModalOpen(true)}
|
160
|
+
variant="primary"
|
161
|
+
aria-label="add_filter_rule"
|
162
|
+
>
|
163
|
+
{__('Add filter rule')}
|
164
|
+
</Button>
|
165
|
+
</SplitItem>
|
166
|
+
<SplitItem>
|
167
|
+
<Dropdown
|
168
|
+
toggle={<KebabToggle aria-label="bulk_actions" onToggle={toggleBulkAction} />}
|
169
|
+
isOpen={bulkActionOpen}
|
170
|
+
isPlain
|
171
|
+
dropdownItems={[
|
172
|
+
<DropdownItem aria-label="bulk_remove" key="bulk_remove" isDisabled={!hasSelected} component="button" onClick={bulkRemove}>
|
173
|
+
{__('Remove')}
|
174
|
+
</DropdownItem>]
|
175
|
+
}
|
176
|
+
/>
|
177
|
+
</SplitItem>
|
178
|
+
</Split>}
|
167
179
|
{modalOpen &&
|
168
180
|
<AddEditContainerTagRuleModal
|
169
181
|
{...{
|
@@ -0,0 +1,236 @@
|
|
1
|
+
import React, { useState, useEffect, useCallback } from 'react';
|
2
|
+
import useDeepCompareEffect from 'use-deep-compare-effect';
|
3
|
+
import PropTypes from 'prop-types';
|
4
|
+
import { shallowEqual, useSelector, useDispatch } from 'react-redux';
|
5
|
+
import { TableVariant } from '@patternfly/react-table';
|
6
|
+
import { Tabs, Tab, TabTitleText, Split, SplitItem, Button, Dropdown, DropdownItem, KebabToggle } from '@patternfly/react-core';
|
7
|
+
import { STATUS } from 'foremanReact/constants';
|
8
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
9
|
+
import onSelect from '../../../../components/Table/helpers';
|
10
|
+
import TableWrapper from '../../../../components/Table/TableWrapper';
|
11
|
+
import {
|
12
|
+
selectCVFilterDetails,
|
13
|
+
selectCVFilterRules,
|
14
|
+
selectCVFilterRulesStatus,
|
15
|
+
} from '../ContentViewDetailSelectors';
|
16
|
+
import { deleteContentViewFilterRules, getCVFilterRules, removeCVFilterRule } from '../ContentViewDetailActions';
|
17
|
+
import CVDebMatchContentModal from './MatchContentModal/CVDebMatchContentModal';
|
18
|
+
import AddEditDebPackageRuleModal from './Rules/DebPackage/AddEditDebPackageRuleModal';
|
19
|
+
import AffectedRepositoryTable from './AffectedRepositories/AffectedRepositoryTable';
|
20
|
+
import { hasPermission } from '../../helpers';
|
21
|
+
|
22
|
+
const CVDebFilterContent = ({
|
23
|
+
cvId, filterId, inclusion, showAffectedRepos, setShowAffectedRepos, details,
|
24
|
+
}) => {
|
25
|
+
const response = useSelector(state => selectCVFilterRules(state, filterId), shallowEqual);
|
26
|
+
const { results, ...metadata } = response;
|
27
|
+
const status = useSelector(state => selectCVFilterRulesStatus(state, filterId), shallowEqual);
|
28
|
+
const loading = status === STATUS.PENDING;
|
29
|
+
const filterDetails = useSelector(state =>
|
30
|
+
selectCVFilterDetails(state, cvId, filterId), shallowEqual);
|
31
|
+
const { repositories = [] } = filterDetails;
|
32
|
+
const dispatch = useDispatch();
|
33
|
+
const { permissions } = details;
|
34
|
+
|
35
|
+
const [rows, setRows] = useState([]);
|
36
|
+
const [searchQuery, updateSearchQuery] = useState('');
|
37
|
+
const [activeTabKey, setActiveTabKey] = useState(0);
|
38
|
+
const [filterRuleId, setFilterRuleId] = useState(undefined);
|
39
|
+
const [bulkActionOpen, setBulkActionOpen] = useState(false);
|
40
|
+
const deselectAll = () => setRows(rows.map(row => ({ ...row, selected: false })));
|
41
|
+
const toggleBulkAction = () => setBulkActionOpen(prevState => !prevState);
|
42
|
+
const hasSelected = rows.some(({ selected }) => selected);
|
43
|
+
const [modalOpen, setModalOpen] = useState(false);
|
44
|
+
const [selectedFilterRuleData, setSelectedFilterRuleData] = useState(undefined);
|
45
|
+
const [showMatchContent, setShowMatchContent] = useState(false);
|
46
|
+
|
47
|
+
const onClose = () => {
|
48
|
+
setModalOpen(false);
|
49
|
+
setShowMatchContent(false);
|
50
|
+
setSelectedFilterRuleData(undefined);
|
51
|
+
};
|
52
|
+
|
53
|
+
const columnHeaders = [
|
54
|
+
__('Deb name'),
|
55
|
+
__('Architecture'),
|
56
|
+
__('Versions'),
|
57
|
+
];
|
58
|
+
|
59
|
+
const versionText = (rule) => {
|
60
|
+
const { version, min_version: minVersion, max_version: maxVersion } = rule;
|
61
|
+
|
62
|
+
if (rule.version) return `Version ${version}`;
|
63
|
+
if (rule.min_version && !rule.max_version) return `Greater than version ${minVersion}`;
|
64
|
+
if (!rule.min_version && rule.max_version) return `Less than version ${maxVersion}`;
|
65
|
+
if (rule.min_version && rule.max_version) {
|
66
|
+
return `Between versions ${rule.min_version} and ${rule.max_version}`;
|
67
|
+
}
|
68
|
+
return 'All versions';
|
69
|
+
};
|
70
|
+
|
71
|
+
const buildRows = useCallback(() => {
|
72
|
+
const newRows = [];
|
73
|
+
results.forEach((rule) => {
|
74
|
+
const {
|
75
|
+
name, architecture, id, ...rest
|
76
|
+
} = rule;
|
77
|
+
|
78
|
+
const cells = [
|
79
|
+
{ title: name },
|
80
|
+
{ title: architecture || 'All architectures' },
|
81
|
+
{ title: versionText(rule) },
|
82
|
+
];
|
83
|
+
|
84
|
+
newRows.push({
|
85
|
+
cells, id, name, arch: architecture, ...rest,
|
86
|
+
});
|
87
|
+
});
|
88
|
+
|
89
|
+
return newRows;
|
90
|
+
}, [results]);
|
91
|
+
|
92
|
+
useDeepCompareEffect(() => {
|
93
|
+
if (!loading && results) {
|
94
|
+
const newRows = buildRows(results);
|
95
|
+
setRows(newRows);
|
96
|
+
}
|
97
|
+
}, [response, results, loading, buildRows]);
|
98
|
+
|
99
|
+
useEffect(() => {
|
100
|
+
if (!repositories.length && showAffectedRepos) {
|
101
|
+
setActiveTabKey(1);
|
102
|
+
} else {
|
103
|
+
setActiveTabKey(0);
|
104
|
+
}
|
105
|
+
}, [showAffectedRepos, repositories.length]);
|
106
|
+
|
107
|
+
const emptyContentTitle = __('No rules have been added to this filter.');
|
108
|
+
const emptyContentBody = __("Add to this filter using the 'Add Deb rule' button.");
|
109
|
+
const emptySearchTitle = __('No matching rules found.');
|
110
|
+
const emptySearchBody = __('Try changing your search settings.');
|
111
|
+
const tabTitle = (inclusion ? __('Included') : __('Excluded')) + __(' DEBs');
|
112
|
+
|
113
|
+
|
114
|
+
const actionResolver = () => [
|
115
|
+
{
|
116
|
+
title: __('Remove'),
|
117
|
+
onClick: (_event, _rowId, { id }) => {
|
118
|
+
dispatch(removeCVFilterRule(filterId, id, () =>
|
119
|
+
dispatch(getCVFilterRules(filterId))));
|
120
|
+
},
|
121
|
+
},
|
122
|
+
{
|
123
|
+
title: __('Edit'),
|
124
|
+
onClick: (_event, _rowId, ruleDetails) => {
|
125
|
+
setSelectedFilterRuleData(ruleDetails);
|
126
|
+
setModalOpen(true);
|
127
|
+
},
|
128
|
+
},
|
129
|
+
{
|
130
|
+
title: __('View matching content'),
|
131
|
+
onClick: (_event, _rowId, { id }) => {
|
132
|
+
setFilterRuleId(id);
|
133
|
+
setShowMatchContent(true);
|
134
|
+
},
|
135
|
+
},
|
136
|
+
];
|
137
|
+
|
138
|
+
const bulkRemove = () => {
|
139
|
+
setBulkActionOpen(false);
|
140
|
+
const debFilterIds =
|
141
|
+
rows.filter(row => row.selected).map(selected => selected.id);
|
142
|
+
dispatch(deleteContentViewFilterRules(filterId, debFilterIds, () =>
|
143
|
+
dispatch(getCVFilterRules(filterId))));
|
144
|
+
deselectAll();
|
145
|
+
};
|
146
|
+
|
147
|
+
return (
|
148
|
+
<Tabs activeKey={activeTabKey} onSelect={(_event, eventKey) => setActiveTabKey(eventKey)}>
|
149
|
+
<Tab eventKey={0} title={<TabTitleText>{tabTitle}</TabTitleText>}>
|
150
|
+
<div className="tab-body-with-spacing">
|
151
|
+
<TableWrapper
|
152
|
+
{...{
|
153
|
+
rows,
|
154
|
+
metadata,
|
155
|
+
emptyContentTitle,
|
156
|
+
emptyContentBody,
|
157
|
+
emptySearchTitle,
|
158
|
+
emptySearchBody,
|
159
|
+
searchQuery,
|
160
|
+
updateSearchQuery,
|
161
|
+
status,
|
162
|
+
}}
|
163
|
+
ouiaId="content-view-deb-filter-table"
|
164
|
+
actionResolver={hasPermission(permissions, 'edit_content_views') ? actionResolver : null}
|
165
|
+
status={status}
|
166
|
+
onSelect={hasPermission(permissions, 'edit_content_views') ? onSelect(rows, setRows) : null}
|
167
|
+
cells={columnHeaders}
|
168
|
+
variant={TableVariant.compact}
|
169
|
+
autocompleteEndpoint={`/content_view_filters/${filterId}/rules/auto_complete_search`}
|
170
|
+
fetchItems={useCallback(params => getCVFilterRules(filterId, params), [filterId])}
|
171
|
+
actionButtons={
|
172
|
+
<>
|
173
|
+
{showMatchContent &&
|
174
|
+
<CVDebMatchContentModal
|
175
|
+
key={`${filterId}-${filterRuleId}`}
|
176
|
+
filterRuleId={filterRuleId}
|
177
|
+
filterId={filterId}
|
178
|
+
onClose={onClose}
|
179
|
+
/>}
|
180
|
+
<Split hasGutter>
|
181
|
+
<SplitItem>
|
182
|
+
<Button onClick={() => setModalOpen(true)} variant="secondary" aria-label="create_deb_rule">
|
183
|
+
{__('Add DEB rule')}
|
184
|
+
</Button>
|
185
|
+
</SplitItem>
|
186
|
+
<SplitItem>
|
187
|
+
<Dropdown
|
188
|
+
toggle={<KebabToggle aria-label="bulk_actions" onToggle={toggleBulkAction} />}
|
189
|
+
isOpen={bulkActionOpen}
|
190
|
+
isPlain
|
191
|
+
dropdownItems={[
|
192
|
+
<DropdownItem aria-label="bulk_remove" key="bulk_remove" isDisabled={!hasSelected} component="button" onClick={bulkRemove}>
|
193
|
+
{__('Remove')}
|
194
|
+
</DropdownItem>]
|
195
|
+
}
|
196
|
+
/>
|
197
|
+
</SplitItem>
|
198
|
+
</Split>
|
199
|
+
{modalOpen &&
|
200
|
+
<AddEditDebPackageRuleModal
|
201
|
+
filterId={filterId}
|
202
|
+
onClose={onClose}
|
203
|
+
selectedFilterRuleData={selectedFilterRuleData}
|
204
|
+
/>}
|
205
|
+
</>}
|
206
|
+
/>
|
207
|
+
</div>
|
208
|
+
</Tab>
|
209
|
+
{(repositories.length || showAffectedRepos) &&
|
210
|
+
<Tab eventKey={1} title={<TabTitleText>{__('Affected Repositories')}</TabTitleText>}>
|
211
|
+
<div className="tab-body-with-spacing">
|
212
|
+
<AffectedRepositoryTable cvId={cvId} filterId={filterId} repoType="deb" setShowAffectedRepos={setShowAffectedRepos} details={details} />
|
213
|
+
</div>
|
214
|
+
</Tab>}
|
215
|
+
</Tabs>
|
216
|
+
);
|
217
|
+
};
|
218
|
+
|
219
|
+
CVDebFilterContent.propTypes = {
|
220
|
+
cvId: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
221
|
+
filterId: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
222
|
+
inclusion: PropTypes.bool,
|
223
|
+
showAffectedRepos: PropTypes.bool.isRequired,
|
224
|
+
setShowAffectedRepos: PropTypes.func.isRequired,
|
225
|
+
details: PropTypes.shape({
|
226
|
+
permissions: PropTypes.shape({}),
|
227
|
+
repository_ids: PropTypes.arrayOf(PropTypes.number),
|
228
|
+
}).isRequired,
|
229
|
+
};
|
230
|
+
|
231
|
+
CVDebFilterContent.defaultProps = {
|
232
|
+
cvId: '',
|
233
|
+
filterId: '',
|
234
|
+
inclusion: false,
|
235
|
+
};
|
236
|
+
export default CVDebFilterContent;
|
@@ -264,6 +264,7 @@ const CVErrataIDFilterContent = ({
|
|
264
264
|
status,
|
265
265
|
activeFilters,
|
266
266
|
defaultFilters,
|
267
|
+
resetFilters,
|
267
268
|
}}
|
268
269
|
ouiaId="content-view-errata-by-id-filter-table"
|
269
270
|
actionResolver={hasPermission(permissions, 'edit_content_views') ? actionResolver : null}
|
@@ -7,6 +7,7 @@ import CVContainerImageFilterContent from './CVContainerImageFilterContent';
|
|
7
7
|
import CVModuleStreamFilterContent from './CVModuleStreamFilterContent';
|
8
8
|
import CVErrataIDFilterContent from './CVErrataIDFilterContent';
|
9
9
|
import CVErrataDateFilterContent from './CVErrataDateFilterContent';
|
10
|
+
import CVDebFilterContent from './CVDebFilterContent';
|
10
11
|
|
11
12
|
const CVFilterDetailType = ({
|
12
13
|
cvId, filterId, inclusion, type, showAffectedRepos, setShowAffectedRepos, rules, details,
|
@@ -63,6 +64,15 @@ const CVFilterDetailType = ({
|
|
63
64
|
setShowAffectedRepos={setShowAffectedRepos}
|
64
65
|
details={details}
|
65
66
|
/>);
|
67
|
+
case 'deb':
|
68
|
+
return (<CVDebFilterContent
|
69
|
+
cvId={cvId}
|
70
|
+
filterId={filterId}
|
71
|
+
inclusion={inclusion}
|
72
|
+
showAffectedRepos={showAffectedRepos}
|
73
|
+
setShowAffectedRepos={setShowAffectedRepos}
|
74
|
+
details={details}
|
75
|
+
/>);
|
66
76
|
default:
|
67
77
|
return null;
|
68
78
|
}
|
@@ -75,6 +75,8 @@ const CVModuleStreamFilterContent = ({
|
|
75
75
|
];
|
76
76
|
const selectedAdded = allAddedNotAdded[selectedIndex];
|
77
77
|
|
78
|
+
const resetFilters = () => setSelectedIndex(0);
|
79
|
+
|
78
80
|
const fetchItems = useCallback((params) => {
|
79
81
|
const adjustedParams = { ...params };
|
80
82
|
switch (selectedIndex) {
|
@@ -215,6 +217,7 @@ const CVModuleStreamFilterContent = ({
|
|
215
217
|
updateSearchQuery,
|
216
218
|
error,
|
217
219
|
status,
|
220
|
+
resetFilters,
|
218
221
|
}}
|
219
222
|
ouiaId="content-view-module-stream-filter-table"
|
220
223
|
additionalListeners={[selectedIndex]}
|
@@ -69,6 +69,7 @@ const CVPackageGroupFilterContent = ({
|
|
69
69
|
ADDED,
|
70
70
|
NOT_ADDED,
|
71
71
|
];
|
72
|
+
|
72
73
|
const selectedAdded = allAddedNotAdded[selectedIndex];
|
73
74
|
|
74
75
|
const fetchItems = useCallback((params) => {
|
@@ -187,7 +188,7 @@ const CVPackageGroupFilterContent = ({
|
|
187
188
|
const emptyContentBody = __("Add to this filter using the 'Add filter rule' button.");
|
188
189
|
const emptySearchTitle = __('No matching filter rules found.');
|
189
190
|
const emptySearchBody = __('Try changing your search settings.');
|
190
|
-
|
191
|
+
const resetFilters = () => setSelectedIndex(0);
|
191
192
|
|
192
193
|
return (
|
193
194
|
<Tabs className="margin-0-24" activeKey={activeTabKey} onSelect={(_event, eventKey) => setActiveTabKey(eventKey)}>
|
@@ -205,6 +206,7 @@ const CVPackageGroupFilterContent = ({
|
|
205
206
|
updateSearchQuery,
|
206
207
|
error,
|
207
208
|
status,
|
209
|
+
resetFilters,
|
208
210
|
}}
|
209
211
|
ouiaId="content-view-package-group-filter-table"
|
210
212
|
additionalListeners={[selectedIndex]}
|