katello 4.5.0 → 4.6.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_dynflow_proxy_controller.rb +10 -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/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 +4 -2
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_repository.rb +4 -2
- 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 +1 -1
- 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/concerns/host_managed_extensions.rb +13 -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 +41 -29
- 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 +2 -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/content_view_version/export.rb +38 -11
- 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 +4 -3
- 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/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/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/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/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/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/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/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 +173 -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 +108 -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 +100 -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 +82 -167
- 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
@@ -1,80 +0,0 @@
|
|
1
|
-
import React, { Component } from 'react';
|
2
|
-
import PropTypes from 'prop-types';
|
3
|
-
import qs from 'query-string';
|
4
|
-
import { translate as __ } from 'foremanReact/common/I18n';
|
5
|
-
import { orgId } from '../../services/api';
|
6
|
-
import TableSchema from './AnsibleCollectionsTableSchema';
|
7
|
-
import ContentPage from '../../components/Content/ContentPage';
|
8
|
-
|
9
|
-
class AnsibleCollectionsPage extends Component {
|
10
|
-
constructor(props) {
|
11
|
-
super(props);
|
12
|
-
|
13
|
-
const queryParams = qs.parse(this.props.location.search);
|
14
|
-
this.state = {
|
15
|
-
searchQuery: queryParams.search || '',
|
16
|
-
};
|
17
|
-
}
|
18
|
-
|
19
|
-
componentDidMount() {
|
20
|
-
this.props.getAnsibleCollections({
|
21
|
-
search: this.state.searchQuery,
|
22
|
-
});
|
23
|
-
}
|
24
|
-
|
25
|
-
onPaginationChange = (pagination) => {
|
26
|
-
this.props.getAnsibleCollections({
|
27
|
-
...pagination,
|
28
|
-
});
|
29
|
-
};
|
30
|
-
|
31
|
-
onSearch = (search) => {
|
32
|
-
this.props.getAnsibleCollections({ search });
|
33
|
-
};
|
34
|
-
|
35
|
-
getAutoCompleteParams = search => ({
|
36
|
-
endpoint: '/ansible_collections/auto_complete_search',
|
37
|
-
params: {
|
38
|
-
organization_id: orgId(),
|
39
|
-
search,
|
40
|
-
},
|
41
|
-
});
|
42
|
-
|
43
|
-
updateSearchQuery = (searchQuery) => {
|
44
|
-
this.setState({ searchQuery });
|
45
|
-
};
|
46
|
-
|
47
|
-
render() {
|
48
|
-
const { ansibleCollections } = this.props;
|
49
|
-
return (
|
50
|
-
<ContentPage
|
51
|
-
header={__('Ansible Collections')}
|
52
|
-
content={ansibleCollections}
|
53
|
-
tableSchema={TableSchema}
|
54
|
-
onSearch={this.onSearch}
|
55
|
-
getAutoCompleteParams={this.getAutoCompleteParams}
|
56
|
-
updateSearchQuery={this.updateSearchQuery}
|
57
|
-
initialInputValue={this.state.searchQuery}
|
58
|
-
onPaginationChange={this.onPaginationChange}
|
59
|
-
/>
|
60
|
-
);
|
61
|
-
}
|
62
|
-
}
|
63
|
-
|
64
|
-
AnsibleCollectionsPage.propTypes = {
|
65
|
-
location: PropTypes.shape({
|
66
|
-
search: PropTypes.oneOfType([
|
67
|
-
PropTypes.shape({}),
|
68
|
-
PropTypes.string,
|
69
|
-
]),
|
70
|
-
}),
|
71
|
-
getAnsibleCollections: PropTypes.func.isRequired,
|
72
|
-
ansibleCollections: PropTypes.shape({}).isRequired,
|
73
|
-
};
|
74
|
-
|
75
|
-
AnsibleCollectionsPage.defaultProps = {
|
76
|
-
location: { search: '' },
|
77
|
-
};
|
78
|
-
|
79
|
-
|
80
|
-
export default AnsibleCollectionsPage;
|
@@ -1,39 +0,0 @@
|
|
1
|
-
import { initialApiState } from '../../services/api';
|
2
|
-
import {
|
3
|
-
ANSIBLE_COLLECTIONS_REQUEST,
|
4
|
-
ANSIBLE_COLLECTIONS_SUCCESS,
|
5
|
-
ANSIBLE_COLLECTIONS_ERROR,
|
6
|
-
} from './AnsibleCollectionsConstants';
|
7
|
-
|
8
|
-
const initialState = initialApiState;
|
9
|
-
|
10
|
-
export default (state = initialState, action) => {
|
11
|
-
switch (action.type) {
|
12
|
-
case ANSIBLE_COLLECTIONS_REQUEST: {
|
13
|
-
return state.set('loading', true);
|
14
|
-
}
|
15
|
-
case ANSIBLE_COLLECTIONS_SUCCESS: {
|
16
|
-
const {
|
17
|
-
results, page, per_page, subtotal, // eslint-disable-line camelcase
|
18
|
-
} = action.response;
|
19
|
-
return state.merge({
|
20
|
-
results,
|
21
|
-
loading: false,
|
22
|
-
pagination: {
|
23
|
-
page: Number(page),
|
24
|
-
perPage: Number(per_page || state.pagination.perPage), // eslint-disable-line camelcase
|
25
|
-
},
|
26
|
-
itemCount: Number(subtotal),
|
27
|
-
});
|
28
|
-
}
|
29
|
-
case ANSIBLE_COLLECTIONS_ERROR: {
|
30
|
-
return state.merge({
|
31
|
-
error: action.error,
|
32
|
-
loading: false,
|
33
|
-
});
|
34
|
-
}
|
35
|
-
default: {
|
36
|
-
return state;
|
37
|
-
}
|
38
|
-
}
|
39
|
-
};
|
@@ -1,60 +0,0 @@
|
|
1
|
-
import React from 'react';
|
2
|
-
import { Link } from 'react-router-dom';
|
3
|
-
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
-
import { urlBuilder } from 'foremanReact/common/urlHelpers';
|
5
|
-
import {
|
6
|
-
headerFormatter,
|
7
|
-
cellFormatter,
|
8
|
-
} from '../../components/pf3Table/formatters';
|
9
|
-
|
10
|
-
const TableSchema = [
|
11
|
-
{
|
12
|
-
property: 'name',
|
13
|
-
header: {
|
14
|
-
label: __('Name'),
|
15
|
-
formatters: [headerFormatter],
|
16
|
-
},
|
17
|
-
cell: {
|
18
|
-
formatters: [
|
19
|
-
(value, { rowData }) => (
|
20
|
-
<td>
|
21
|
-
<Link to={urlBuilder('legacy_ansible_collections', '', rowData.id)}>{rowData.name}</Link>
|
22
|
-
</td>
|
23
|
-
),
|
24
|
-
],
|
25
|
-
},
|
26
|
-
},
|
27
|
-
{
|
28
|
-
property: 'namespace',
|
29
|
-
header: {
|
30
|
-
label: __('Author'),
|
31
|
-
formatters: [headerFormatter],
|
32
|
-
},
|
33
|
-
cell: {
|
34
|
-
formatters: [cellFormatter],
|
35
|
-
},
|
36
|
-
},
|
37
|
-
{
|
38
|
-
property: 'version',
|
39
|
-
header: {
|
40
|
-
label: __('Version'),
|
41
|
-
formatters: [headerFormatter],
|
42
|
-
},
|
43
|
-
cell: {
|
44
|
-
formatters: [cellFormatter],
|
45
|
-
},
|
46
|
-
},
|
47
|
-
{
|
48
|
-
property: 'checksum',
|
49
|
-
header: {
|
50
|
-
label: __('Checksum'),
|
51
|
-
formatters: [headerFormatter],
|
52
|
-
},
|
53
|
-
cell: {
|
54
|
-
formatters: [cellFormatter],
|
55
|
-
},
|
56
|
-
},
|
57
|
-
];
|
58
|
-
|
59
|
-
export default TableSchema;
|
60
|
-
|
File without changes
|
@@ -1,94 +0,0 @@
|
|
1
|
-
import React, { Component } from 'react';
|
2
|
-
import BreadcrumbsBar from 'foremanReact/components/BreadcrumbBar';
|
3
|
-
import { PropTypes } from 'prop-types';
|
4
|
-
import { translate as __ } from 'foremanReact/common/I18n';
|
5
|
-
import api from '../../../services/api';
|
6
|
-
import ContentDetails from '../../../components/Content/Details/ContentDetails';
|
7
|
-
import ansibleCollectionsSchema from './AnsibleCollectionsSchema';
|
8
|
-
|
9
|
-
class AnsibleCollectionDetails extends Component {
|
10
|
-
componentDidMount() {
|
11
|
-
this.updateAnsibleCollection();
|
12
|
-
}
|
13
|
-
|
14
|
-
componentDidUpdate(prevProps) {
|
15
|
-
const { match: { params: prevRouterParams } } = this.props;
|
16
|
-
const { match: { params: currentRouterParams } } = prevProps;
|
17
|
-
if (prevRouterParams.id && (prevRouterParams.id !== currentRouterParams.id)) {
|
18
|
-
this.updateAnsibleCollection();
|
19
|
-
}
|
20
|
-
}
|
21
|
-
|
22
|
-
updateAnsibleCollection = () => {
|
23
|
-
const ansibleCollectionId = parseInt(this.props.match.params.id, 10);
|
24
|
-
this.props.getAnsibleCollectionDetails(ansibleCollectionId);
|
25
|
-
};
|
26
|
-
|
27
|
-
handleBreadcrumbSwitcherItem = (e, url) => {
|
28
|
-
this.props.history.push(url);
|
29
|
-
e.preventDefault();
|
30
|
-
};
|
31
|
-
|
32
|
-
render() {
|
33
|
-
const { ansibleCollectionDetails } = this.props;
|
34
|
-
const {
|
35
|
-
loading, name, namespace, version,
|
36
|
-
} = ansibleCollectionDetails;
|
37
|
-
|
38
|
-
const resource = {
|
39
|
-
nameField: 'name',
|
40
|
-
resourceUrl: api.getApiUrl('/ansible_collections'),
|
41
|
-
switcherItemUrl: '/ansible_collections/:id',
|
42
|
-
};
|
43
|
-
|
44
|
-
return (
|
45
|
-
<div>
|
46
|
-
{!loading && <BreadcrumbsBar
|
47
|
-
onSwitcherItemClick={(e, url) => this.handleBreadcrumbSwitcherItem(e, url)}
|
48
|
-
data={{
|
49
|
-
isSwitchable: true,
|
50
|
-
breadcrumbItems: [
|
51
|
-
{
|
52
|
-
caption: __('Ansible Collection Details'),
|
53
|
-
onClick: () =>
|
54
|
-
this.props.history.push('/ansible_collections'),
|
55
|
-
},
|
56
|
-
{
|
57
|
-
caption: `${name}-${namespace}-${version}`,
|
58
|
-
},
|
59
|
-
],
|
60
|
-
resource,
|
61
|
-
}}
|
62
|
-
/>}
|
63
|
-
<ContentDetails
|
64
|
-
contentDetails={ansibleCollectionDetails}
|
65
|
-
schema={ansibleCollectionsSchema(ansibleCollectionDetails)}
|
66
|
-
/>
|
67
|
-
</div>
|
68
|
-
);
|
69
|
-
}
|
70
|
-
}
|
71
|
-
|
72
|
-
AnsibleCollectionDetails.propTypes = {
|
73
|
-
getAnsibleCollectionDetails: PropTypes.func.isRequired,
|
74
|
-
history: PropTypes.shape({ push: PropTypes.func.isRequired }).isRequired,
|
75
|
-
location: PropTypes.shape({}).isRequired,
|
76
|
-
match: PropTypes.shape({
|
77
|
-
params: PropTypes.shape({
|
78
|
-
id: PropTypes.string.isRequired,
|
79
|
-
}).isRequired,
|
80
|
-
}).isRequired,
|
81
|
-
ansibleCollectionDetails: PropTypes.shape({
|
82
|
-
loading: PropTypes.bool,
|
83
|
-
name: PropTypes.string,
|
84
|
-
namespace: PropTypes.string,
|
85
|
-
version: PropTypes.string,
|
86
|
-
// Disabling rule as existing code failed due to an eslint-plugin-react update
|
87
|
-
/* eslint-disable react/forbid-prop-types */
|
88
|
-
repositories: PropTypes.array,
|
89
|
-
tags: PropTypes.array,
|
90
|
-
/* eslint-enable react/forbid-prop-types */
|
91
|
-
}).isRequired,
|
92
|
-
};
|
93
|
-
|
94
|
-
export default AnsibleCollectionDetails;
|
@@ -1,23 +0,0 @@
|
|
1
|
-
import api, { orgId } from '../../../services/api';
|
2
|
-
import {
|
3
|
-
ANSIBLE_COLLECTION_DETAILS_ERROR,
|
4
|
-
ANSIBLE_COLLECTION_DETAILS_REQUEST,
|
5
|
-
ANSIBLE_COLLECTION_DETAILS_SUCCESS,
|
6
|
-
} from './AnsibleCollectionDetailsConstants';
|
7
|
-
import { apiError } from '../../../utils/helpers';
|
8
|
-
|
9
|
-
export const getAnsibleCollectionDetails = ansibleCollectionId => async (dispatch) => {
|
10
|
-
dispatch({ type: ANSIBLE_COLLECTION_DETAILS_REQUEST });
|
11
|
-
|
12
|
-
try {
|
13
|
-
const { data } = await api.get(`/ansible_collections/${ansibleCollectionId}`, {}, { organization_id: orgId() });
|
14
|
-
return dispatch({
|
15
|
-
type: ANSIBLE_COLLECTION_DETAILS_SUCCESS,
|
16
|
-
response: data,
|
17
|
-
});
|
18
|
-
} catch (error) {
|
19
|
-
return dispatch(apiError(ANSIBLE_COLLECTION_DETAILS_ERROR, error));
|
20
|
-
}
|
21
|
-
};
|
22
|
-
|
23
|
-
export default getAnsibleCollectionDetails;
|
@@ -1,30 +0,0 @@
|
|
1
|
-
import { initialApiState } from '../../../services/api';
|
2
|
-
import {
|
3
|
-
ANSIBLE_COLLECTION_DETAILS_REQUEST,
|
4
|
-
ANSIBLE_COLLECTION_DETAILS_SUCCESS,
|
5
|
-
ANSIBLE_COLLECTION_DETAILS_ERROR,
|
6
|
-
} from './AnsibleCollectionDetailsConstants';
|
7
|
-
|
8
|
-
export default (state = initialApiState, action) => {
|
9
|
-
switch (action.type) {
|
10
|
-
case ANSIBLE_COLLECTION_DETAILS_REQUEST: {
|
11
|
-
return state.set('loading', true);
|
12
|
-
}
|
13
|
-
case ANSIBLE_COLLECTION_DETAILS_SUCCESS: {
|
14
|
-
const ansibleCollectionDetails = action.response;
|
15
|
-
return state.merge({
|
16
|
-
...ansibleCollectionDetails,
|
17
|
-
loading: false,
|
18
|
-
});
|
19
|
-
}
|
20
|
-
case ANSIBLE_COLLECTION_DETAILS_ERROR: {
|
21
|
-
return state.merge({
|
22
|
-
error: action.payload.message,
|
23
|
-
loading: false,
|
24
|
-
});
|
25
|
-
}
|
26
|
-
default: {
|
27
|
-
return state;
|
28
|
-
}
|
29
|
-
}
|
30
|
-
};
|
@@ -1,35 +0,0 @@
|
|
1
|
-
import React from 'react';
|
2
|
-
import { translate as __ } from 'foremanReact/common/I18n';
|
3
|
-
import ContentDetailInfo from '../../../components/Content/Details/ContentDetailInfo';
|
4
|
-
import ContentDetailRepositories from '../../../components/Content/Details/ContentDetailRepositories';
|
5
|
-
|
6
|
-
export const displayMap = new Map([
|
7
|
-
['name', __('Name')],
|
8
|
-
['description', __('Description')],
|
9
|
-
['namespace', __('Author')],
|
10
|
-
['version', __('Version')],
|
11
|
-
['checksum', __('Checksum')],
|
12
|
-
['tags', __('Tags')],
|
13
|
-
]);
|
14
|
-
|
15
|
-
export default (detailInfo) => {
|
16
|
-
const { repositories } = detailInfo;
|
17
|
-
|
18
|
-
return [
|
19
|
-
{
|
20
|
-
key: 1,
|
21
|
-
tabHeader: __('Details'),
|
22
|
-
tabContent: (
|
23
|
-
<ContentDetailInfo contentDetails={detailInfo} displayMap={displayMap} />
|
24
|
-
),
|
25
|
-
},
|
26
|
-
{
|
27
|
-
key: 2,
|
28
|
-
tabHeader: __('Repositories'),
|
29
|
-
tabContent: (repositories && repositories.length ?
|
30
|
-
<ContentDetailRepositories repositories={repositories} /> :
|
31
|
-
__('No repositories to show')
|
32
|
-
),
|
33
|
-
},
|
34
|
-
];
|
35
|
-
};
|
data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailInfo.test.js
DELETED
@@ -1,16 +0,0 @@
|
|
1
|
-
import { testComponentSnapshotsWithFixtures } from 'react-redux-test-utils';
|
2
|
-
import ContentDetailInfo from '../../../../components/Content/Details/ContentDetailInfo';
|
3
|
-
import { details } from './AnsibleCollectionDetails.fixtures';
|
4
|
-
import { displayMap } from '../AnsibleCollectionsSchema';
|
5
|
-
|
6
|
-
const fixtures = {
|
7
|
-
'renders with ansible collection info': {
|
8
|
-
contentDetails: details,
|
9
|
-
displayMap,
|
10
|
-
},
|
11
|
-
};
|
12
|
-
|
13
|
-
describe('Ansible Collection detail info component', () => {
|
14
|
-
describe('rendering', () =>
|
15
|
-
testComponentSnapshotsWithFixtures(ContentDetailInfo, fixtures));
|
16
|
-
});
|
data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.fixtures.js
DELETED
@@ -1,25 +0,0 @@
|
|
1
|
-
import Immutable from 'seamless-immutable';
|
2
|
-
import { initialApiState } from '../../../../services/api';
|
3
|
-
|
4
|
-
export const initialState = initialApiState;
|
5
|
-
|
6
|
-
export const details = {
|
7
|
-
id: 2,
|
8
|
-
name: 'collection_demo',
|
9
|
-
namespace: 'newswangerd',
|
10
|
-
version: '1.0.5',
|
11
|
-
checksum: '60bf94a30d3b7015c7cdc2a99f0a440f68f71cb56c934ba3787e52a6061fa2d5',
|
12
|
-
repositories: [
|
13
|
-
{
|
14
|
-
id: 2,
|
15
|
-
name: 'ans_collection',
|
16
|
-
product_id: 2,
|
17
|
-
product_name: 'pulp3_products',
|
18
|
-
},
|
19
|
-
],
|
20
|
-
};
|
21
|
-
|
22
|
-
export const loadingState = Immutable({
|
23
|
-
...initialState,
|
24
|
-
loading: true,
|
25
|
-
});
|
@@ -1,27 +0,0 @@
|
|
1
|
-
import { testComponentSnapshotsWithFixtures } from 'react-redux-test-utils';
|
2
|
-
import AnsibleCollectionDetails from '../AnsibleCollectionDetails';
|
3
|
-
import { details, loadingState } from './AnsibleCollectionDetails.fixtures';
|
4
|
-
|
5
|
-
const mockFunc = jest.fn();
|
6
|
-
|
7
|
-
const baseProps = {
|
8
|
-
getAnsibleCollectionDetails: mockFunc,
|
9
|
-
location: { search: '' },
|
10
|
-
history: { push: mockFunc },
|
11
|
-
ansibleCollectionDetails: details,
|
12
|
-
match: { params: { id: String(details.id) } },
|
13
|
-
};
|
14
|
-
|
15
|
-
const fixtures = {
|
16
|
-
'renders with ansible collection provided': {
|
17
|
-
...baseProps,
|
18
|
-
},
|
19
|
-
'renders with loading state': {
|
20
|
-
...baseProps,
|
21
|
-
ansibleCollectionDetails: loadingState,
|
22
|
-
},
|
23
|
-
};
|
24
|
-
|
25
|
-
describe('Ansible Collection details page', () => {
|
26
|
-
describe('rendering', () => testComponentSnapshotsWithFixtures(AnsibleCollectionDetails, fixtures));
|
27
|
-
});
|
data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsActions.test.js
DELETED
@@ -1,41 +0,0 @@
|
|
1
|
-
import { testActionSnapshotWithFixtures } from 'react-redux-test-utils';
|
2
|
-
import api from '../../../../services/api';
|
3
|
-
import { apiError } from '../../../../utils/helpers';
|
4
|
-
import { getAnsibleCollectionDetails } from '../AnsibleCollectionDetailsActions';
|
5
|
-
import { details } from './AnsibleCollectionDetails.fixtures';
|
6
|
-
|
7
|
-
jest.mock('../../../../services/api');
|
8
|
-
jest.mock('../../../../utils/helpers');
|
9
|
-
|
10
|
-
const fixtures = {
|
11
|
-
'should load ansible collection details on success': () => async (dispatch) => {
|
12
|
-
await getAnsibleCollectionDetails('1')(dispatch);
|
13
|
-
|
14
|
-
expect(api.get.mock.calls).toMatchSnapshot('API get call');
|
15
|
-
expect(apiError).not.toHaveBeenCalled();
|
16
|
-
},
|
17
|
-
'should load fail on bad api call': () => (dispatch) => {
|
18
|
-
api.get.mockImplementation(async () => {
|
19
|
-
throw new Error('some-error');
|
20
|
-
});
|
21
|
-
|
22
|
-
return getAnsibleCollectionDetails('1')(dispatch);
|
23
|
-
},
|
24
|
-
};
|
25
|
-
|
26
|
-
describe('Ansible Collection details actions', () => {
|
27
|
-
beforeEach(() => {
|
28
|
-
api.get.mockImplementation(async () => ({
|
29
|
-
data: {
|
30
|
-
results: details,
|
31
|
-
},
|
32
|
-
}));
|
33
|
-
});
|
34
|
-
afterEach(() => {
|
35
|
-
jest.resetAllMocks();
|
36
|
-
jest.restoreAllMocks();
|
37
|
-
jest.resetModules();
|
38
|
-
});
|
39
|
-
|
40
|
-
testActionSnapshotWithFixtures(fixtures);
|
41
|
-
});
|
data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsReducer.test.js
DELETED
@@ -1,33 +0,0 @@
|
|
1
|
-
import { testReducerSnapshotWithFixtures } from 'react-redux-test-utils';
|
2
|
-
import reducer from '../AnsibleCollectionDetailsReducer';
|
3
|
-
import {
|
4
|
-
ANSIBLE_COLLECTION_DETAILS_REQUEST,
|
5
|
-
ANSIBLE_COLLECTION_DETAILS_SUCCESS,
|
6
|
-
ANSIBLE_COLLECTION_DETAILS_ERROR,
|
7
|
-
} from '../AnsibleCollectionDetailsConstants';
|
8
|
-
|
9
|
-
const fixtures = {
|
10
|
-
'should return the initial state': {},
|
11
|
-
'should handle ANSIBLE_COLLECTION_DETAILS_REQUEST': {
|
12
|
-
action: {
|
13
|
-
type: ANSIBLE_COLLECTION_DETAILS_REQUEST,
|
14
|
-
},
|
15
|
-
},
|
16
|
-
'should handle ANSIBLE_COLLECTION_DETAILS_SUCCESS': {
|
17
|
-
action: {
|
18
|
-
type: ANSIBLE_COLLECTION_DETAILS_SUCCESS,
|
19
|
-
payload: {
|
20
|
-
results: { data: { id: 1 } },
|
21
|
-
},
|
22
|
-
},
|
23
|
-
},
|
24
|
-
'should handle ANSIBLE_COLLECTION_DETAILS_ERROR': {
|
25
|
-
action: {
|
26
|
-
type: ANSIBLE_COLLECTION_DETAILS_ERROR,
|
27
|
-
payload: new Error('things have gone terribly wrong'),
|
28
|
-
},
|
29
|
-
},
|
30
|
-
};
|
31
|
-
|
32
|
-
describe('AnsibleCollectionDetails reducer', () =>
|
33
|
-
testReducerSnapshotWithFixtures(reducer, fixtures));
|
@@ -1,83 +0,0 @@
|
|
1
|
-
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
-
|
3
|
-
exports[`Ansible Collection detail info component rendering renders with ansible collection info 1`] = `
|
4
|
-
<Table
|
5
|
-
bordered={false}
|
6
|
-
bsClass="table"
|
7
|
-
condensed={false}
|
8
|
-
hover={false}
|
9
|
-
responsive={false}
|
10
|
-
striped={false}
|
11
|
-
>
|
12
|
-
<tbody>
|
13
|
-
<tr
|
14
|
-
key="name"
|
15
|
-
>
|
16
|
-
<td>
|
17
|
-
<b>
|
18
|
-
Name
|
19
|
-
</b>
|
20
|
-
</td>
|
21
|
-
<td>
|
22
|
-
collection_demo
|
23
|
-
</td>
|
24
|
-
</tr>
|
25
|
-
<tr
|
26
|
-
key="description"
|
27
|
-
>
|
28
|
-
<td>
|
29
|
-
<b>
|
30
|
-
Description
|
31
|
-
</b>
|
32
|
-
</td>
|
33
|
-
<td />
|
34
|
-
</tr>
|
35
|
-
<tr
|
36
|
-
key="namespace"
|
37
|
-
>
|
38
|
-
<td>
|
39
|
-
<b>
|
40
|
-
Author
|
41
|
-
</b>
|
42
|
-
</td>
|
43
|
-
<td>
|
44
|
-
newswangerd
|
45
|
-
</td>
|
46
|
-
</tr>
|
47
|
-
<tr
|
48
|
-
key="version"
|
49
|
-
>
|
50
|
-
<td>
|
51
|
-
<b>
|
52
|
-
Version
|
53
|
-
</b>
|
54
|
-
</td>
|
55
|
-
<td>
|
56
|
-
1.0.5
|
57
|
-
</td>
|
58
|
-
</tr>
|
59
|
-
<tr
|
60
|
-
key="checksum"
|
61
|
-
>
|
62
|
-
<td>
|
63
|
-
<b>
|
64
|
-
Checksum
|
65
|
-
</b>
|
66
|
-
</td>
|
67
|
-
<td>
|
68
|
-
60bf94a30d3b7015c7cdc2a99f0a440f68f71cb56c934ba3787e52a6061fa2d5
|
69
|
-
</td>
|
70
|
-
</tr>
|
71
|
-
<tr
|
72
|
-
key="tags"
|
73
|
-
>
|
74
|
-
<td>
|
75
|
-
<b>
|
76
|
-
Tags
|
77
|
-
</b>
|
78
|
-
</td>
|
79
|
-
<td />
|
80
|
-
</tr>
|
81
|
-
</tbody>
|
82
|
-
</Table>
|
83
|
-
`;
|