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
@@ -3,16 +3,31 @@ module Katello
|
|
3
3
|
module ContentViewVersion
|
4
4
|
class Export
|
5
5
|
include ImportExportCommon
|
6
|
-
|
6
|
+
SYNCABLE = "syncable".freeze
|
7
|
+
IMPORTABLE = "importable".freeze
|
8
|
+
FORMATS = [SYNCABLE, IMPORTABLE].freeze
|
9
|
+
|
10
|
+
attr_reader :smart_proxy, :content_view_version, :destination_server, :from_content_view_version, :repository, :base_path
|
11
|
+
def self.create(options)
|
12
|
+
if options.delete(:format) == SYNCABLE
|
13
|
+
SyncableFormatExport.new(options)
|
14
|
+
else
|
15
|
+
self.new(options)
|
16
|
+
end
|
17
|
+
end
|
7
18
|
|
8
19
|
def initialize(smart_proxy:,
|
9
20
|
content_view_version: nil,
|
10
21
|
destination_server: nil,
|
11
|
-
from_content_view_version: nil
|
22
|
+
from_content_view_version: nil,
|
23
|
+
repository: nil,
|
24
|
+
base_path: nil)
|
12
25
|
@smart_proxy = smart_proxy
|
13
26
|
@content_view_version = content_view_version
|
14
27
|
@destination_server = destination_server
|
15
28
|
@from_content_view_version = from_content_view_version
|
29
|
+
@repository = repository
|
30
|
+
@base_path = base_path
|
16
31
|
end
|
17
32
|
|
18
33
|
def repository_hrefs
|
@@ -37,21 +52,27 @@ module Katello
|
|
37
52
|
end
|
38
53
|
|
39
54
|
def generate_exporter_path
|
40
|
-
|
41
|
-
"#{content_view_version.
|
55
|
+
return base_path if base_path
|
56
|
+
export_path = "#{content_view_version.content_view}/#{content_view_version.version}/"
|
57
|
+
export_path += "#{destination_server}/" unless destination_server.blank?
|
58
|
+
export_path += "#{date_dir}".gsub(/\s/, '_')
|
59
|
+
@base_path = "#{Setting['pulpcore_export_destination']}/#{content_view_version.organization.label}/#{export_path}"
|
42
60
|
end
|
43
61
|
|
44
62
|
def date_dir
|
45
63
|
DateTime.now.to_s.gsub(/\W/, '-')
|
46
64
|
end
|
47
65
|
|
48
|
-
def create_exporter
|
49
|
-
api.exporter_api
|
50
|
-
|
51
|
-
|
66
|
+
def create_exporter
|
67
|
+
exporter_api = api.exporter_api
|
68
|
+
options = { name: generate_id(content_view_version), path: generate_exporter_path }
|
69
|
+
options[:repositories] = repository_hrefs
|
70
|
+
|
71
|
+
exporter_api.create(options)
|
52
72
|
end
|
53
73
|
|
54
|
-
def create_export(
|
74
|
+
def create_export(exporter_data, chunk_size: nil)
|
75
|
+
exporter_href = exporter_data[:pulp_href]
|
55
76
|
options = { versions: version_hrefs }
|
56
77
|
options[:chunk_size] = "#{chunk_size}GB" if chunk_size
|
57
78
|
if from_content_view_version
|
@@ -77,14 +98,16 @@ module Katello
|
|
77
98
|
options[:start_versions] = start_versions
|
78
99
|
options[:full] = 'false'
|
79
100
|
end
|
80
|
-
|
101
|
+
export_api = api.export_api
|
102
|
+
[export_api.create(exporter_href, options)]
|
81
103
|
end
|
82
104
|
|
83
105
|
def fetch_export(exporter_href)
|
84
106
|
api.export_api.list(exporter_href).results.first
|
85
107
|
end
|
86
108
|
|
87
|
-
def destroy_exporter(
|
109
|
+
def destroy_exporter(exporter_data)
|
110
|
+
exporter_href = exporter_data[:pulp_href]
|
88
111
|
export_data = fetch_export(exporter_href)
|
89
112
|
api.exporter_api.partial_update(exporter_href, :last_export => nil)
|
90
113
|
api.export_api.delete(export_data.pulp_href) unless export_data.blank?
|
@@ -162,6 +185,10 @@ module Katello
|
|
162
185
|
generated_for: generated_for).send(select_method)
|
163
186
|
end
|
164
187
|
|
188
|
+
def format
|
189
|
+
is_a?(SyncableFormatExport) ? SYNCABLE : IMPORTABLE
|
190
|
+
end
|
191
|
+
|
165
192
|
def self.find_library_export_view(create_by_default: false,
|
166
193
|
destination_server:,
|
167
194
|
organization:)
|
@@ -16,10 +16,12 @@ module Katello
|
|
16
16
|
|
17
17
|
def generate!
|
18
18
|
ret = { organization: organization.name,
|
19
|
+
base_path: Setting['pulpcore_export_destination'],
|
19
20
|
repositories: {},
|
20
21
|
content_view: content_view.slice(:name, :label, :description, :generated_for),
|
21
22
|
content_view_version: content_view_version.slice(:major, :minor, :description),
|
22
|
-
incremental: from_content_view_version.present
|
23
|
+
incremental: from_content_view_version.present?,
|
24
|
+
format: export_service.format
|
23
25
|
}
|
24
26
|
|
25
27
|
unless from_content_view_version.blank?
|
@@ -0,0 +1,34 @@
|
|
1
|
+
module Katello
|
2
|
+
module Pulp3
|
3
|
+
module ContentViewVersion
|
4
|
+
class SyncableFormatExport < Export
|
5
|
+
def create_exporter
|
6
|
+
api.yum_exporter_api.create(name: "#{generate_id(content_view_version)}-#{repository.id}",
|
7
|
+
path: generate_repository_exporter_path,
|
8
|
+
method: :hardlink)
|
9
|
+
end
|
10
|
+
|
11
|
+
def create_export(exporter_data, _options = {})
|
12
|
+
[api.yum_export_api.create(exporter_data[:pulp_href], publication: repository.publication_href)]
|
13
|
+
end
|
14
|
+
|
15
|
+
def fetch_export(exporter_href)
|
16
|
+
api.yum_export_api.list(exporter_href).results.first
|
17
|
+
end
|
18
|
+
|
19
|
+
def destroy_exporter(exporter_data)
|
20
|
+
exporter_href = exporter_data[:pulp_href]
|
21
|
+
export_data = fetch_export(exporter_href)
|
22
|
+
api.yum_export_api.delete(export_data.pulp_href)
|
23
|
+
api.yum_exporter_api.delete(exporter_href)
|
24
|
+
end
|
25
|
+
|
26
|
+
def generate_repository_exporter_path
|
27
|
+
_org, _content, content_path = repository.library_instance_or_self.relative_path.split("/", 3)
|
28
|
+
content_path = content_path.sub(%r|^/|, '')
|
29
|
+
"#{generate_exporter_path}/#{content_path}".gsub(/\s/, '_')
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -9,6 +9,7 @@ module Katello
|
|
9
9
|
end
|
10
10
|
|
11
11
|
def self.content_api_create(opts = {})
|
12
|
+
opts.delete(:relative_path) if opts.key?(:relative_path)
|
12
13
|
self.content_api.create(opts)
|
13
14
|
end
|
14
15
|
|
@@ -24,7 +25,8 @@ module Katello
|
|
24
25
|
end
|
25
26
|
|
26
27
|
def self.generate_model_row(unit)
|
27
|
-
|
28
|
+
unit = unit.try(:with_indifferent_access)
|
29
|
+
return {
|
28
30
|
pulp_id: unit[unit_identifier],
|
29
31
|
checksum: unit[:sha256],
|
30
32
|
filename: unit[:relative_path],
|
@@ -146,6 +146,8 @@ module Katello
|
|
146
146
|
elsif repository.generic?
|
147
147
|
duplicate_sha_path_content_list = content_backend_service.content_api(repository.repository_type, unit_type_id).list(
|
148
148
|
filter_label => checksum)
|
149
|
+
elsif unit_type_id == 'deb'
|
150
|
+
duplicate_sha_path_content_list = content_backend_service.content_api.list(filter_label => checksum)
|
149
151
|
else
|
150
152
|
duplicate_sha_path_content_list = content_backend_service.content_api.list(
|
151
153
|
filter_label => checksum,
|
@@ -4,6 +4,7 @@ module Katello
|
|
4
4
|
module Pulp3
|
5
5
|
class Repository
|
6
6
|
class Apt < ::Katello::Pulp3::Repository
|
7
|
+
UNIT_LIMIT = 10_000
|
7
8
|
SIGNING_SERVICE_NAME = 'katello_deb_sign'.freeze
|
8
9
|
|
9
10
|
def remote_options
|
@@ -66,8 +67,191 @@ module Katello
|
|
66
67
|
"/pulp/deb/#{repo.relative_path}/".sub('//', '/')
|
67
68
|
end
|
68
69
|
|
69
|
-
def
|
70
|
-
|
70
|
+
def multi_copy_units(repo_id_map, dependency_solving)
|
71
|
+
tasks = []
|
72
|
+
|
73
|
+
if repo_id_map.values.pluck(:content_unit_hrefs).flatten.any?
|
74
|
+
data = PulpDebClient::Copy.new
|
75
|
+
data.dependency_solving = dependency_solving
|
76
|
+
data.config = []
|
77
|
+
repo_id_map.each do |source_repo_ids, dest_repo_id_map|
|
78
|
+
dest_repo = ::Katello::Repository.find(dest_repo_id_map[:dest_repo])
|
79
|
+
dest_repo_href = ::Katello::Pulp3::Repository::Apt.new(dest_repo, SmartProxy.pulp_primary).repository_reference.repository_href
|
80
|
+
content_unit_hrefs = dest_repo_id_map[:content_unit_hrefs]
|
81
|
+
# Not needed during incremental update due to dest_base_version
|
82
|
+
source_repo_ids.each do |source_repo_id|
|
83
|
+
source_repo_version = ::Katello::Repository.find(source_repo_id).version_href
|
84
|
+
config = { source_repo_version: source_repo_version, dest_repo: dest_repo_href, content: content_unit_hrefs }
|
85
|
+
config[:dest_base_version] = dest_repo_id_map[:base_version] if dest_repo_id_map[:base_version]
|
86
|
+
data.config << config
|
87
|
+
end
|
88
|
+
end
|
89
|
+
tasks << copy_content_chunked(data)
|
90
|
+
else
|
91
|
+
tasks << remove_all_content_from_mapping(repo_id_map)
|
92
|
+
end
|
93
|
+
tasks.flatten
|
94
|
+
end
|
95
|
+
|
96
|
+
def copy_api_data_dup(data)
|
97
|
+
data_dup = PulpDebClient::Copy.new
|
98
|
+
data_dup.dependency_solving = data.dependency_solving
|
99
|
+
data_dup.config = []
|
100
|
+
data.config.each do |repo_config|
|
101
|
+
config_hash = {
|
102
|
+
source_repo_version: repo_config[:source_repo_version],
|
103
|
+
dest_repo: repo_config[:dest_repo],
|
104
|
+
content: []
|
105
|
+
}
|
106
|
+
config_hash[:dest_base_version] = repo_config[:dest_base_version] if repo_config[:dest_base_version]
|
107
|
+
data_dup.config << config_hash
|
108
|
+
end
|
109
|
+
data_dup
|
110
|
+
end
|
111
|
+
|
112
|
+
def copy_content_chunked(data)
|
113
|
+
tasks = []
|
114
|
+
# Don't chunk if there aren't enough content units
|
115
|
+
if data.config.sum { |repo_config| repo_config[:content].size } <= UNIT_LIMIT
|
116
|
+
return api.copy_api.copy_content(data)
|
117
|
+
end
|
118
|
+
|
119
|
+
unit_copy_counter = 0
|
120
|
+
i = 0
|
121
|
+
leftover_units = data.config.first[:content].deep_dup
|
122
|
+
|
123
|
+
# Copy data and clear its content fields
|
124
|
+
data_dup = copy_api_data_dup(data)
|
125
|
+
|
126
|
+
while i < data_dup.config.size
|
127
|
+
# Copy all units within repo or only some?
|
128
|
+
if leftover_units.length < UNIT_LIMIT - unit_copy_counter
|
129
|
+
copy_amount = leftover_units.length
|
130
|
+
else
|
131
|
+
copy_amount = UNIT_LIMIT - unit_copy_counter
|
132
|
+
end
|
133
|
+
|
134
|
+
data_dup.config[i][:content] = leftover_units.pop(copy_amount)
|
135
|
+
unit_copy_counter += copy_amount
|
136
|
+
if unit_copy_counter != 0
|
137
|
+
tasks << api.copy_api.copy_content(data_dup)
|
138
|
+
unit_copy_counter = 0
|
139
|
+
end
|
140
|
+
|
141
|
+
if leftover_units.empty?
|
142
|
+
# Nothing more to copy -- clear current config's content
|
143
|
+
data_dup.config[i][:content] = []
|
144
|
+
i += 1
|
145
|
+
# Fetch unit list for next data config
|
146
|
+
leftover_units = data.config[i][:content].deep_dup unless i == data_dup.config.size
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
tasks
|
151
|
+
end
|
152
|
+
|
153
|
+
def remove_all_content_from_mapping(repo_id_map)
|
154
|
+
tasks = []
|
155
|
+
repo_id_map.each do |_source_repo_ids, dest_repo_id_map|
|
156
|
+
dest_repo = ::Katello::Repository.find(dest_repo_id_map[:dest_repo])
|
157
|
+
dest_repo_href = ::Katello::Pulp3::Repository::Apt.new(dest_repo, SmartProxy.pulp_primary).repository_reference.repository_href
|
158
|
+
tasks << remove_all_content_from_repo(dest_repo_href)
|
159
|
+
end
|
160
|
+
tasks
|
161
|
+
end
|
162
|
+
|
163
|
+
def remove_all_content_from_repo(repo_href)
|
164
|
+
data = PulpDebClient::RepositoryAddRemoveContent.new(
|
165
|
+
remove_content_units: ['*'])
|
166
|
+
api.repositories_api.modify(repo_href, data)
|
167
|
+
end
|
168
|
+
|
169
|
+
def remove_all_content
|
170
|
+
data = PulpDebClient::RepositoryAddRemoveContent.new(
|
171
|
+
remove_content_units: ['*'])
|
172
|
+
api.repositories_api.modify(repository_reference.repository_href, data)
|
173
|
+
end
|
174
|
+
|
175
|
+
def add_filter_content(source_repo_ids, filters, filter_list_map)
|
176
|
+
filters.each do |filter|
|
177
|
+
if filter.inclusion
|
178
|
+
source_repo_ids.each do |repo_id|
|
179
|
+
filter_list_map[:whitelist_ids] += filter.content_unit_pulp_ids(::Katello::Repository.find(repo_id))
|
180
|
+
end
|
181
|
+
else
|
182
|
+
source_repo_ids.each do |repo_id|
|
183
|
+
filter_list_map[:blacklist_ids] += filter.content_unit_pulp_ids(::Katello::Repository.find(repo_id))
|
184
|
+
end
|
185
|
+
end
|
186
|
+
end
|
187
|
+
filter_list_map
|
188
|
+
end
|
189
|
+
|
190
|
+
def add_debs(source_repo_ids, filters, filter_list_map)
|
191
|
+
if (filter_list_map[:whitelist_ids].empty? && filters.select { |filter| filter.inclusion }.empty?)
|
192
|
+
filter_list_map[:whitelist_ids] += source_repo_ids.collect do |source_repo_id|
|
193
|
+
source_repo = ::Katello::Repository.find(source_repo_id)
|
194
|
+
source_repo.debs.pluck(:pulp_id).sort
|
195
|
+
end
|
196
|
+
end
|
197
|
+
filter_list_map
|
198
|
+
end
|
199
|
+
|
200
|
+
def copy_content_from_mapping(repo_id_map, options = {})
|
201
|
+
repo_id_map.each do |source_repo_ids, dest_repo_map|
|
202
|
+
filters = ContentViewDebFilter.where(:id => options[:filter_ids])
|
203
|
+
|
204
|
+
filter_list_map = { whitelist_ids: [], blacklist_ids: [] }
|
205
|
+
filter_list_map = add_filter_content(source_repo_ids, filters, filter_list_map)
|
206
|
+
filter_list_map = add_debs(source_repo_ids, filters, filter_list_map)
|
207
|
+
|
208
|
+
whitelist_ids = filter_list_map[:whitelist_ids].flatten&.uniq
|
209
|
+
blacklist_ids = filter_list_map[:blacklist_ids].flatten&.uniq
|
210
|
+
content_unit_hrefs = whitelist_ids - blacklist_ids
|
211
|
+
|
212
|
+
dest_repo_map[:content_unit_hrefs] = content_unit_hrefs.uniq.sort
|
213
|
+
end
|
214
|
+
|
215
|
+
dependency_solving = options[:solve_dependencies] || false
|
216
|
+
|
217
|
+
multi_copy_units(repo_id_map, dependency_solving)
|
218
|
+
end
|
219
|
+
|
220
|
+
def copy_units(content_unit_hrefs, remove_all)
|
221
|
+
remove_all = true if remove_all.nil?
|
222
|
+
tasks = []
|
223
|
+
|
224
|
+
if content_unit_hrefs.sort!.any?
|
225
|
+
first_slice = remove_all
|
226
|
+
content_unit_hrefs.each_slice(UNIT_LIMIT) do |slice|
|
227
|
+
tasks << add_content(slice, first_slice)
|
228
|
+
first_slice = false
|
229
|
+
end
|
230
|
+
else
|
231
|
+
tasks << remove_all_content
|
232
|
+
end
|
233
|
+
tasks
|
234
|
+
end
|
235
|
+
|
236
|
+
def copy_content_for_source(source_repository, options = {})
|
237
|
+
# copy_units_by_href(source_repository.debs.pluck(:pulp_id))
|
238
|
+
filters = ContentViewDebFilter.where(:id => options[:filter_ids])
|
239
|
+
|
240
|
+
whitelist_ids = []
|
241
|
+
blacklist_ids = []
|
242
|
+
filters.each do |filter|
|
243
|
+
if filter.inclusion
|
244
|
+
whitelist_ids += filter.content_unit_pulp_ids(source_repository)
|
245
|
+
else
|
246
|
+
blacklist_ids += filter.content_unit_pulp_ids(source_repository)
|
247
|
+
end
|
248
|
+
end
|
249
|
+
|
250
|
+
whitelist_ids = source_repository.debs.pluck(:pulp_id).sort if (whitelist_ids.empty? && filters.select { |filter| filter.inclusion }.empty?)
|
251
|
+
|
252
|
+
content_unit_hrefs = whitelist_ids - blacklist_ids
|
253
|
+
|
254
|
+
copy_units(content_unit_hrefs.uniq, options[:remove_all])
|
71
255
|
end
|
72
256
|
|
73
257
|
def regenerate_applicability
|
@@ -77,7 +77,7 @@ module Katello
|
|
77
77
|
if remote_options[:url].blank?
|
78
78
|
if href
|
79
79
|
repo.update(remote_href: nil)
|
80
|
-
delete_remote href
|
80
|
+
delete_remote(href: href)
|
81
81
|
end
|
82
82
|
else
|
83
83
|
if href
|
@@ -97,8 +97,9 @@ module Katello
|
|
97
97
|
end
|
98
98
|
end
|
99
99
|
|
100
|
-
def delete_remote(
|
101
|
-
|
100
|
+
def delete_remote(options = {})
|
101
|
+
options[:href] ||= repo.remote_href
|
102
|
+
ignore_404_exception { remote_options[:url]&.start_with?('uln') ? api.remotes_uln_api.delete(options[:href]) : api.remotes_api.delete(options[:href]) } if options[:href]
|
102
103
|
end
|
103
104
|
|
104
105
|
def self.instance_for_type(repo, smart_proxy)
|
@@ -43,7 +43,7 @@ module Katello
|
|
43
43
|
response = api.remotes_api.create(remote_file_data)
|
44
44
|
end
|
45
45
|
#delete is async, but if its not properly deleted, orphan cleanup will take care of it later
|
46
|
-
delete_remote(response.pulp_href)
|
46
|
+
delete_remote(href: response.pulp_href)
|
47
47
|
end
|
48
48
|
end
|
49
49
|
|
@@ -1,11 +1,11 @@
|
|
1
1
|
<% if @smart_proxy.pulp_mirror? -%>
|
2
2
|
<div ng-controller="CapsuleContentController">
|
3
|
-
<%= render :
|
3
|
+
<%= render :template => 'smart_proxies/show' %>
|
4
4
|
</div>
|
5
5
|
<% elsif @smart_proxy.pulp_primary? -%>
|
6
6
|
<div ng-controller="PulpPrimaryController">
|
7
|
-
<%= render :
|
7
|
+
<%= render :template => 'smart_proxies/show' %>
|
8
8
|
</div>
|
9
9
|
<% else -%>
|
10
|
-
<%= render :
|
10
|
+
<%= render :template => 'smart_proxies/show' %>
|
11
11
|
<% end -%>
|
@@ -1,8 +1,23 @@
|
|
1
|
-
object @resource
|
2
|
-
|
3
1
|
extends 'katello/api/v2/common/identifier'
|
4
2
|
|
5
|
-
|
3
|
+
if @object.respond_to?(:alternate_content_source_type)
|
4
|
+
if @object.custom?
|
5
|
+
attributes :name, :alternate_content_source_type, :content_type, :base_url, :subpaths, :upstream_username, :smart_proxies, :verify_ssl
|
6
|
+
child :ssl_ca_cert => :ssl_ca_cert do |_object|
|
7
|
+
attributes :id, :name
|
8
|
+
end
|
9
|
+
|
10
|
+
child :ssl_client_cert => :ssl_client_cert do |_object|
|
11
|
+
attributes :id, :name
|
12
|
+
end
|
13
|
+
|
14
|
+
child :ssl_client_key => :ssl_client_key do |_object|
|
15
|
+
attributes :id, :name
|
16
|
+
end
|
17
|
+
elsif @object.simplified?
|
18
|
+
attributes :name, :alternate_content_source_type, :content_type, :products, :smart_proxies
|
19
|
+
end
|
20
|
+
end
|
6
21
|
|
7
22
|
child :latest_dynflow_refresh_task => :last_refresh do |_object|
|
8
23
|
attributes :id, :username, :started_at, :ended_at, :state, :result, :progress
|
@@ -1,3 +1,23 @@
|
|
1
1
|
object @resource
|
2
2
|
|
3
3
|
extends "katello/api/v2/alternate_content_sources/base"
|
4
|
+
|
5
|
+
if @resource.respond_to?(:simplified?)
|
6
|
+
if @resource.simplified?
|
7
|
+
node :products do |acs|
|
8
|
+
acs.products.map do |product|
|
9
|
+
{ id: product.id, organization_id: product.organization.id, name: product.name, label: product.label }
|
10
|
+
end
|
11
|
+
end
|
12
|
+
else
|
13
|
+
node :upstream_password_exists do |_acs|
|
14
|
+
@resource.upstream_password.present?
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
node :smart_proxies do |acs|
|
20
|
+
acs.smart_proxies.map do |smart_proxy|
|
21
|
+
{ id: smart_proxy.id, name: smart_proxy.name, url: smart_proxy.url, download_policy: smart_proxy.download_policy }
|
22
|
+
end
|
23
|
+
end
|
@@ -47,6 +47,11 @@ node :rules do |filter|
|
|
47
47
|
partial('katello/api/v2/content_view_filter_rules/show', :object => rule)
|
48
48
|
end
|
49
49
|
|
50
|
+
elsif filter.respond_to?(:deb_rules)
|
51
|
+
filter.deb_rules.map do |rule|
|
52
|
+
partial('katello/api/v2/content_view_filter_rules/show', :object => rule)
|
53
|
+
end
|
54
|
+
|
50
55
|
else
|
51
56
|
[]
|
52
57
|
end
|
@@ -12,13 +12,10 @@
|
|
12
12
|
'data-url' => "/katello/api/v2/organizations/#{@taxonomy.id}/download_debug_certificate"
|
13
13
|
end %>
|
14
14
|
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
tag1 + tag2
|
21
|
-
end %>
|
22
|
-
<% end %>
|
15
|
+
<%= field(f, _('Simple Content Access')) do
|
16
|
+
tag1 = hidden_field_tag 'simple_content_access', '0'
|
17
|
+
tag2 = check_box_tag 'simple_content_access', '1', @taxonomy.simple_content_access?(cached: false)
|
18
|
+
tag1 + tag2
|
19
|
+
end %>
|
23
20
|
|
24
21
|
<% end %>
|
@@ -1,5 +1,10 @@
|
|
1
1
|
<% if @taxonomy.is_a?(Organization) %>
|
2
2
|
|
3
3
|
<%= text_f f, :label, :class => 'input-xlarge' %>
|
4
|
+
<%= field(f, _('Simple Content Access')) do
|
5
|
+
tag1 = hidden_field_tag 'simple_content_access', '0'
|
6
|
+
tag2 = check_box_tag 'simple_content_access', '1', true
|
7
|
+
tag1 + tag2
|
8
|
+
end %>
|
4
9
|
|
5
10
|
<% end %>
|
data/ca/redhat-uep.pem
CHANGED
@@ -39,12 +39,12 @@ tcci9LFHGvijIy4VUDQK8HmGjIxJPrIIe1nB5BkiGyjwn00D5q+BwYVst1C68Rwx
|
|
39
39
|
iRZpyzOZmeineJvhrJZ4Tvs=
|
40
40
|
-----END CERTIFICATE-----
|
41
41
|
-----BEGIN CERTIFICATE-----
|
42
|
-
|
42
|
+
MIIGejCCBGKgAwIBAgIJAJGKz8qFAAAIMA0GCSqGSIb3DQEBDAUAMIGwMQswCQYD
|
43
43
|
VQQGEwJVUzEXMBUGA1UECAwOTm9ydGggQ2Fyb2xpbmExEDAOBgNVBAcMB1JhbGVp
|
44
44
|
Z2gxFjAUBgNVBAoMDVJlZCBIYXQsIEluYy4xGDAWBgNVBAsMD1JlZCBIYXQgTmV0
|
45
45
|
d29yazEeMBwGA1UEAwwVRW50aXRsZW1lbnQgTWFzdGVyIENBMSQwIgYJKoZIhvcN
|
46
|
-
|
47
|
-
|
46
|
+
AQkBFhVjYS1zdXBwb3J0QHJlZGhhdC5jb20wHhcNMTgwOTEyMTgxMzIxWhcNMzAw
|
47
|
+
MzE1MTgxMzIxWjCBsTELMAkGA1UEBhMCVVMxFzAVBgNVBAgMDk5vcnRoIENhcm9s
|
48
48
|
aW5hMRYwFAYDVQQKDA1SZWQgSGF0LCBJbmMuMRgwFgYDVQQLDA9SZWQgSGF0IE5l
|
49
49
|
dHdvcmsxMTAvBgNVBAMMKFJlZCBIYXQgRW50aXRsZW1lbnQgT3BlcmF0aW9ucyBB
|
50
50
|
dXRob3JpdHkxJDAiBgkqhkiG9w0BCQEWFWNhLXN1cHBvcnRAcmVkaGF0LmNvbTCC
|
@@ -59,26 +59,21 @@ tUeKQUFwIXqSjuOoZDu80H6NQb+4dnRSjWlx/m7HPk75m0zErshpB2HSKUnrs4wR
|
|
59
59
|
i7GsWDDcqBus7eLMwUZPvDNVcLQu/2Y4DUHNbJbn7+DwEqi5D0heC+dyY8iS45gp
|
60
60
|
I/yhVvq/GfKL+dqjaNaE4CorJJA5qJ9f383Ol/aub+aJeBahCBNuVa2daA9Bo3BA
|
61
61
|
dnL7KkILPFyCcEhQITnu70Qn9sQlwYcRoYF2LWAm9DtLrBT0Y0w7wQHh8vNhwEQ7
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
8BVvKkHtixygyo+EO+NEotZGw3cn+/7soo9B1bWXk3PFSwEr+KwINACFGv2zcGLI
|
78
|
-
oeP4iK6DHZImWEV4tgMrQyXatEyPh2axPWU3SjY/fr1Ub5gEt+WpCtyYIN4ObBaN
|
79
|
-
eL3NPfTj79/VFZ22PhUInmGY/VK/ymvl/dkWyWi8zD8Aq55ofZ33FvQ46dcLp1pV
|
80
|
-
KWApIVqO27uhL6YxXDFi6n7RXACEIVz6JqDh5fGmOH1F+vfumZKzW78LlVD2QY15
|
81
|
-
rmCh0i9+AUCiUsNyYdJbSZDPiFPBwlwUoQ==
|
62
|
+
k5G87WpwzcC8y6ePR0vFAgMBAAGjgZMwgZAwHQYDVR0OBBYEFMRJeFZFnR4sYWDD
|
63
|
+
ZktYBTcvAyJ7MB8GA1UdIwQYMBaAFIhLpkXERuyP1s+m9hrPJjyQzH8XMAwGA1Ud
|
64
|
+
EwQFMAMBAf8wCwYDVR0PBAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIBBjAgBgNVHREE
|
65
|
+
GTAXgRVjYS1zdXBwb3J0QHJlZGhhdC5jb20wDQYJKoZIhvcNAQEMBQADggIBAGKk
|
66
|
+
q5Ab0AC7SOCYq9up5z0twbe+gI72cm854+VhcxafnLP2/4nH6nQauKLKEFLI8+fV
|
67
|
+
RAwYxm1f5nuEiaTvjPE0umYdgMlpEJQeGdW/+/DotDaOon1G6bSMEKFvaKcBHKqa
|
68
|
+
kBxQ29trwMG2WN8qZ7/H3XzBvLZ+JrYr01vDSV0P4tcBFOytbMZeJr4xmfxiqWxp
|
69
|
+
VUM9eGf6z+ngXyth8lohxGd9MMXwsaPdvM+wptp3AQpq5wFPWyfJqCd6uBxu09k1
|
70
|
+
ns3Y/sya2GHqDK4bUW6gCHO13gkYviTCIBLAlX7PDeK5nYVcq8HvTLU9+H9BFGix
|
71
|
+
YGDdHphz7i5qO/gLLLcfKhENP6jtbe8i6nwqeDzj+DMy38iMWNYFVWn1OrBaQMtf
|
72
|
+
wlVfyRJij9SfyiUAVFld1RoPAN/haf1VmF/0dGrOigibYijqnHvDJffMUND/sbk8
|
73
|
+
df6O6VYjvLLlwry4W4dHiLLA7NAHGtkUv2g1+oH1lQIfRG+PvZhWz4pGT1AlzfwD
|
74
|
+
aXUfX2X+Bo9tYr9BGy5Li1pLGLvfw+an7cBAbBaw8+HhAHt+Vm4F03KX/bHlge0a
|
75
|
+
fMYK6FoA/xQSaZ6IPm4HfPSMvhboguVG+/AZQN4/UxjDleoEz8b0CWYafcJRRZch
|
76
|
+
BdxBjTy7JLf3j0HCbenZQF83wwtrSmiTOTK1tLsm
|
82
77
|
-----END CERTIFICATE-----
|
83
78
|
-----BEGIN CERTIFICATE-----
|
84
79
|
MIIHZDCCBUygAwIBAgIJAOb+QiglyeZeMA0GCSqGSIb3DQEBBQUAMIGwMQswCQYD
|