katello 4.2.1 → 4.3.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/assets/javascripts/katello/common/katello.common.js +0 -67
- data/app/assets/javascripts/katello/common/katello.js +0 -27
- data/app/assets/javascripts/katello/common/vendor.js +0 -1
- data/app/assets/stylesheets/katello/katello.scss +0 -1
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +10 -2
- data/app/controllers/katello/api/v2/api_controller.rb +35 -9
- data/app/controllers/katello/api/v2/capsule_content_controller.rb +16 -2
- data/app/controllers/katello/api/v2/content_view_components_controller.rb +22 -1
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +65 -1
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +5 -1
- data/app/controllers/katello/api/v2/content_views_controller.rb +13 -6
- data/app/controllers/katello/api/v2/debs_controller.rb +74 -1
- data/app/controllers/katello/api/v2/errata_controller.rb +13 -10
- data/app/controllers/katello/api/v2/file_units_controller.rb +1 -0
- data/app/controllers/katello/api/v2/generic_content_units_controller.rb +1 -1
- data/app/controllers/katello/api/v2/host_errata_controller.rb +46 -5
- data/app/controllers/katello/api/v2/host_tracer_controller.rb +2 -1
- data/app/controllers/katello/api/v2/module_streams_controller.rb +4 -0
- data/app/controllers/katello/api/v2/organizations_controller.rb +22 -7
- data/app/controllers/katello/api/v2/products_bulk_actions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repositories_controller.rb +36 -19
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +0 -8
- data/app/controllers/katello/api/v2/upstream_subscriptions_controller.rb +5 -1
- data/app/controllers/katello/concerns/api/v2/bulk_extensions.rb +40 -0
- data/app/controllers/katello/concerns/api/v2/host_errata_extensions.rb +4 -31
- data/app/controllers/katello/concerns/api/v2/registration_controller_extensions.rb +1 -1
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +1 -1
- data/app/helpers/katello/concerns/smart_proxy_helper_extensions.rb +2 -6
- data/app/helpers/katello/katello_url_helper.rb +1 -1
- data/app/lib/actions/candlepin/abstract_async_task.rb +6 -3
- data/app/lib/actions/candlepin/async_hypervisors.rb +12 -8
- data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +10 -1
- data/app/lib/actions/katello/capsule_content/sync_capsule.rb +3 -3
- data/app/lib/actions/katello/cdn_configuration/update.rb +38 -0
- data/app/lib/actions/katello/content_view/remove.rb +18 -7
- data/app/lib/actions/katello/content_view_version/destroy.rb +2 -2
- data/app/lib/actions/katello/content_view_version/republish_repositories.rb +1 -1
- data/app/lib/actions/katello/repository/clone_contents.rb +1 -2
- data/app/lib/actions/katello/repository/destroy.rb +21 -5
- data/app/lib/actions/katello/repository/fetch_pxe_files.rb +1 -1
- data/app/lib/actions/katello/repository/finish_upload.rb +1 -1
- data/app/lib/actions/katello/repository/import_upload.rb +1 -1
- data/app/lib/actions/katello/repository/index_content.rb +19 -6
- data/app/lib/actions/katello/repository/metadata_generate.rb +2 -0
- data/app/lib/actions/katello/repository/multi_clone_contents.rb +1 -1
- data/app/lib/actions/katello/repository/remove_content.rb +1 -1
- data/app/lib/actions/katello/repository/sync.rb +3 -7
- data/app/lib/actions/katello/repository_set/scan_cdn.rb +0 -4
- data/app/lib/actions/middleware/record_smart_proxy_sync_history.rb +1 -1
- data/app/lib/actions/pulp/orphan_cleanup/remove_unneeded_repos.rb +1 -1
- data/app/lib/actions/pulp/repository/clear.rb +1 -1
- data/app/lib/actions/pulp3/abstract_async_task.rb +10 -1
- data/app/lib/actions/pulp3/capsule_content/generate_metadata.rb +13 -18
- data/app/lib/actions/pulp3/capsule_content/refresh_distribution.rb +1 -11
- data/app/lib/actions/pulp3/content_view_version/create_export_history.rb +1 -1
- data/app/lib/actions/pulp3/orchestration/repository/generate_metadata.rb +3 -1
- data/app/lib/actions/pulp3/orchestration/repository/import_upload.rb +25 -42
- data/app/lib/actions/pulp3/orchestration/repository/sync.rb +8 -1
- data/app/lib/actions/pulp3/orchestration/repository/upload_content.rb +3 -3
- data/app/lib/actions/pulp3/repository/commit_upload.rb +1 -1
- data/app/lib/actions/pulp3/repository/import_upload.rb +8 -4
- data/app/lib/actions/pulp3/repository/multi_copy_content.rb +1 -1
- data/app/lib/actions/pulp3/repository/multi_copy_units.rb +1 -1
- data/app/lib/actions/pulp3/repository/presenters/abstract_sync_presenter.rb +18 -0
- data/app/lib/actions/pulp3/repository/presenters/content_unit_presenter.rb +7 -2
- data/app/lib/actions/pulp3/repository/presenters/repair_presenter.rb +6 -1
- data/app/lib/actions/pulp3/repository/save_artifact.rb +14 -4
- data/app/lib/katello/errors.rb +2 -0
- data/app/lib/katello/resources/candlepin/consumer.rb +0 -20
- data/app/lib/katello/resources/candlepin/proxy.rb +8 -2
- data/app/lib/katello/resources/candlepin/upstream_consumer.rb +2 -0
- data/app/lib/katello/resources/cdn/katello_cdn.rb +68 -0
- data/app/lib/katello/resources/cdn.rb +61 -29
- data/app/lib/katello/util/cdn_var_substitutor.rb +15 -9
- data/app/lib/katello/util/package.rb +22 -0
- data/app/lib/katello/util/path_with_substitutions.rb +12 -14
- data/app/models/katello/activation_key.rb +10 -0
- data/app/models/katello/ansible_collection.rb +1 -1
- data/app/models/katello/authorization/repository.rb +4 -4
- data/app/models/katello/candlepin/repository_mapper.rb +5 -1
- data/app/models/katello/cdn_configuration.rb +32 -0
- data/app/models/katello/concerns/content_facet_host_extensions.rb +40 -0
- data/app/models/katello/concerns/host_managed_extensions.rb +28 -2
- data/app/models/katello/concerns/hostgroup_extensions.rb +1 -1
- data/app/models/katello/concerns/organization_extensions.rb +3 -1
- data/app/models/katello/concerns/pulp_database_unit.rb +15 -5
- data/app/models/katello/concerns/remote_execution_provider_extensions.rb +9 -0
- data/app/models/katello/concerns/setting_extensions.rb +1 -1
- data/app/models/katello/concerns/smart_proxy_extensions.rb +4 -3
- data/app/models/katello/content_credential.rb +4 -0
- data/app/models/katello/content_facet_applicable_deb.rb +7 -0
- data/app/models/katello/content_view.rb +24 -1
- data/app/models/katello/content_view_component.rb +4 -0
- data/app/models/katello/content_view_erratum_filter.rb +2 -0
- data/app/models/katello/content_view_filter.rb +1 -1
- data/app/models/katello/content_view_package_filter_rule.rb +2 -1
- data/app/models/katello/content_view_version.rb +30 -1
- data/app/models/katello/deb.rb +71 -0
- data/app/models/katello/erratum.rb +13 -1
- data/app/models/katello/generic_content_unit.rb +3 -1
- data/app/models/katello/glue/pulp/repos.rb +2 -2
- data/app/models/katello/host/content_facet.rb +23 -2
- data/app/models/katello/host/subscription_facet.rb +1 -1
- data/app/models/katello/host_tracer.rb +21 -2
- data/app/models/katello/installed_deb.rb +1 -1
- data/app/models/katello/module_stream.rb +4 -0
- data/app/models/katello/ping.rb +20 -4
- data/app/models/katello/product.rb +7 -5
- data/app/models/katello/provider.rb +1 -24
- data/app/models/katello/repository.rb +37 -10
- data/app/models/katello/root_repository.rb +28 -14
- data/app/models/setting/content.rb +8 -13
- data/app/services/katello/applicability/applicable_content_helper.rb +20 -0
- data/app/services/katello/organization_creator.rb +8 -0
- data/app/services/katello/pulp3/api/ansible_collection.rb +0 -40
- data/app/services/katello/pulp3/api/apt.rb +0 -47
- data/app/services/katello/pulp3/api/content_guard.rb +1 -1
- data/app/services/katello/pulp3/api/core.rb +28 -23
- data/app/services/katello/pulp3/api/docker.rb +0 -50
- data/app/services/katello/pulp3/api/file.rb +0 -48
- data/app/services/katello/pulp3/api/generic.rb +1 -44
- data/app/services/katello/pulp3/api/yum.rb +4 -44
- data/app/services/katello/pulp3/generic_content_unit.rb +8 -4
- data/app/services/katello/pulp3/repository/ansible_collection.rb +4 -0
- data/app/services/katello/pulp3/repository/apt.rb +3 -3
- data/app/services/katello/pulp3/repository/generic.rb +10 -65
- data/app/services/katello/pulp3/repository/yum.rb +10 -0
- data/app/services/katello/pulp3/repository.rb +47 -21
- data/app/services/katello/pulp3/repository_mirror.rb +30 -11
- data/app/services/katello/pulp3/rpm.rb +2 -32
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +7 -8
- data/app/services/katello/pulp3/smart_proxy_repository.rb +1 -1
- data/app/services/katello/registration_manager.rb +2 -0
- data/app/services/katello/repository_type.rb +103 -15
- data/app/services/katello/repository_type_manager.rb +14 -8
- data/app/services/katello/ui_notifications/subscriptions/manifest_expired_warning.rb +1 -1
- data/app/services/katello/upstream_connection_checker.rb +1 -0
- data/app/views/foreman/job_templates/resolve_traces.erb +25 -0
- data/app/views/foreman/job_templates/resolve_traces_-_katello_ansible_default.erb +28 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +1 -1
- data/app/views/katello/api/v2/common/_metadata.json.rabl +1 -0
- data/app/views/katello/api/v2/content_facet/base.json.rabl +3 -1
- data/app/views/katello/api/v2/content_facet/show.json.rabl +2 -1
- data/app/views/katello/api/v2/content_view_components/show.json.rabl +4 -0
- data/app/views/katello/api/v2/content_view_versions/base.json.rabl +7 -0
- data/app/views/katello/api/v2/content_views/base.json.rabl +12 -8
- data/app/views/katello/api/v2/content_views/index.json.rabl +1 -0
- data/app/views/katello/api/v2/content_views/permissions.rabl +8 -0
- data/app/views/katello/api/v2/debs/base.json.rabl +5 -0
- data/app/views/katello/api/v2/errata/index.json.rabl +4 -0
- data/app/views/katello/api/v2/generic_content_units/base.json.rabl +2 -0
- data/app/views/katello/api/v2/generic_content_units/show.json.rabl +7 -0
- data/app/views/katello/api/v2/host_tracer/base.json.rabl +1 -0
- data/app/views/katello/api/v2/module_streams/index.json.rabl +4 -0
- data/app/views/katello/api/v2/organizations/cdn_configuration.rabl +1 -0
- data/app/views/katello/api/v2/organizations/show.json.rabl +7 -0
- data/app/views/katello/api/v2/repositories/base.json.rabl +10 -17
- data/app/views/overrides/activation_keys/_host_synced_content_select.html.erb +2 -6
- data/config/routes/api/v2.rb +13 -0
- data/config/routes/overrides.rb +2 -0
- data/config/routes.rb +14 -2
- data/db/migrate/20140110000001_update_environments_add_katello_id.rb +1 -3
- data/db/migrate/20140610154745_content_view_puppet_environment_id.rb +0 -35
- data/db/migrate/20190802112101_add_applicable_debs.rb +16 -0
- data/db/migrate/20210201163238_migrate_background_download_policy_to_migrate.rb +2 -2
- data/db/migrate/20210909140337_add_last_indexed_to_repos.rb +5 -0
- data/db/migrate/20210910190324_move_background_settings_to_immediate.rb +25 -0
- data/db/migrate/20211006161617_add_filename_to_katello_generic_content_units.rb +5 -0
- data/db/migrate/20211019192121_create_cdn_configuration.katello.rb +30 -0
- data/db/migrate/20211025181315_add_additional_metadata_to_katello_generic_content_units.rb +5 -0
- data/engines/bastion/README.md +15 -0
- data/engines/bastion/app/assets/javascripts/bastion/components/nutupane.factory.js +2 -2
- data/engines/bastion/config/routes.rb +2 -0
- data/engines/bastion/vendor/assets/javascripts/bastion/angular/angular.js +3 -3
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-sanitize/angular-sanitize.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/bastion_katello.js +3 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/common/views/registration.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-debs-applicable.controller.js +44 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-debs.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-debs-applicable.html +70 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-debs.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.routes.js +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-details.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +25 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/debs.controller.js +22 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/debs.routes.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/details/deb.controller.js +22 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/details/views/deb-content-views.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/details/views/deb-info.html +36 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/details/views/deb-repositories.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/details/views/deb.html +4 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/views/debs.html +31 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/generic-content/generic-content.factory.js +21 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/generic-content/generic-content.module.js +17 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/details/package.controller.js +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/details/views/package-info.html +3 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/product-repositories.controller.js +6 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +30 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.filter.js +1 -13
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-manage-content.controller.js +32 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details.controller.js +15 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-details.html +32 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +28 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-manage-generic-content.html +57 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/new-repository.controller.js +46 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +57 -27
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repositories.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repositories.routes.js +16 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repository-types.service.js +30 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repository.factory.js +2 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/views/product-repositories.html +8 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/details/sync-plan-details-info.controller.js +6 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/details/views/sync-plan-info.html +1 -1
- data/engines/bastion_katello/lib/bastion_katello/engine.rb +1 -1
- data/lib/katello/engine.rb +0 -1
- data/lib/katello/permission_creator.rb +4 -3
- data/lib/katello/permissions/host_permissions.rb +1 -0
- data/lib/katello/permissions/organization_permissions.rb +2 -1
- data/lib/katello/plugin.rb +15 -11
- data/lib/katello/repository_types/ansible_collection.rb +13 -1
- data/lib/katello/repository_types/deb.rb +13 -0
- data/lib/katello/repository_types/docker.rb +13 -1
- data/lib/katello/repository_types/file.rb +13 -0
- data/lib/katello/repository_types/ostree.rb +48 -4
- data/lib/katello/repository_types/python.rb +26 -12
- data/lib/katello/repository_types/yum.rb +16 -1
- data/lib/katello/tasks/repository.rake +3 -12
- data/lib/katello/tasks/reset.rake +4 -5
- data/lib/katello/version.rb +1 -1
- data/package.json +3 -2
- data/webpack/__mocks__/react-intl/index.js +4 -0
- data/webpack/components/ActionableDetail.js +23 -3
- data/webpack/components/AddedStatusLabel.js +1 -1
- data/webpack/components/Bookmark/AddBookmarkModal.js +96 -0
- data/webpack/components/Bookmark/Bookmark.scss +28 -0
- data/webpack/components/Bookmark/BookmarkActions.js +24 -0
- data/webpack/components/Bookmark/BookmarkConstants.js +3 -0
- data/webpack/components/Bookmark/BookmarkSelectors.js +15 -0
- data/webpack/components/Bookmark/index.js +94 -0
- data/webpack/components/EditableSwitch.js +6 -1
- data/webpack/components/EditableTextInput/EditableTextInput.js +41 -13
- data/webpack/components/Errata/index.js +69 -0
- data/webpack/components/ErratumTypeLabel.js +31 -0
- data/webpack/components/Loading.js +5 -2
- data/webpack/components/RoutedTabs/__tests__/RoutedTabs.test.js +5 -11
- data/webpack/components/RoutedTabs/index.js +77 -2
- data/webpack/components/Search/Search.js +67 -80
- data/webpack/components/Search/__tests__/search.test.js +8 -26
- data/webpack/components/SelectAllCheckbox/SelectAllCheckbox.scss +3 -0
- data/webpack/components/SelectAllCheckbox/index.js +126 -0
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +7 -2
- data/webpack/components/Table/EmptyStateMessage.js +38 -17
- data/webpack/components/Table/MainTable.js +49 -10
- data/webpack/components/Table/MainTable.scss +11 -0
- data/webpack/components/Table/PageControls.js +45 -0
- data/webpack/components/Table/TableHooks.js +230 -0
- data/webpack/components/Table/TableWrapper.js +221 -50
- data/webpack/components/Table/helpers.js +17 -0
- data/webpack/components/TypeAhead/TypeAhead.js +74 -58
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +25 -10
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.scss +9 -8
- data/webpack/components/TypeAhead/pf4Search/TypeAheadItems.js +2 -2
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +32 -22
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard.js +101 -0
- data/webpack/components/extensions/HostDetails/Cards/__tests__/contentViewDetailsCard.test.js +53 -0
- data/webpack/components/extensions/HostDetails/HostErrata/HostErrataActions.js +47 -0
- data/webpack/components/extensions/HostDetails/HostErrata/HostErrataConstants.js +32 -0
- data/webpack/components/extensions/HostDetails/HostErrata/HostErrataSelectors.js +16 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/EmptyPage.js +19 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/SecondaryTabsRoutes.js +17 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/constants.js +7 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/helpers.js +3 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/index.js +40 -0
- data/webpack/components/extensions/HostDetails/Tabs/EnableTracerEmptyState.js +42 -0
- data/webpack/components/extensions/HostDetails/Tabs/EnableTracerModal.js +118 -0
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab.js +347 -0
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab.scss +16 -0
- data/webpack/components/extensions/HostDetails/Tabs/ErratumExpansionContents.js +60 -0
- data/webpack/components/extensions/HostDetails/Tabs/ErratumExpansionDetail.js +69 -0
- data/webpack/components/extensions/HostDetails/Tabs/HostTracesActions.js +19 -0
- data/webpack/components/extensions/HostDetails/Tabs/HostTracesConstants.js +2 -0
- data/webpack/components/extensions/HostDetails/Tabs/HostTracesSelectors.js +19 -0
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionActions.js +56 -0
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionConstants.js +5 -0
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab.js +188 -0
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab.scss +12 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errata.fixtures.json +67 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +785 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/resolveTraces.fixtures.json +35 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracerEmptyTraceResults.fixtures.json +7 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracerEnableJobInvocation.fixtures.json +35 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/traces.fixtures.json +44 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +386 -0
- data/webpack/components/extensions/HostDetails/Tabs/customizedRexUrlHelpers.js +20 -0
- data/webpack/components/extensions/RegistrationCommands/fields/ActivationKeys.js +1 -1
- data/webpack/components/extensions/RegistrationCommands/index.js +1 -1
- data/webpack/components/pf3Table/components/Table.js +1 -1
- data/webpack/components/pf3Table/components/__snapshots__/Table.test.js.snap +3 -3
- data/webpack/containers/Application/Routes.js +3 -3
- data/webpack/containers/Application/config.js +21 -6
- data/webpack/containers/Application/overrides.scss +34 -3
- data/webpack/{fills_index.js → global_index.js} +11 -2
- data/webpack/global_test_setup.js +6 -1
- data/webpack/redux/actions/RedHatRepositories/helpers.js +4 -4
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTableSchema.js +1 -1
- data/webpack/scenes/Content/ContentActions.js +31 -0
- data/webpack/scenes/Content/ContentConfig.js +138 -0
- data/webpack/scenes/Content/ContentConstants.js +7 -0
- data/webpack/scenes/Content/ContentPage.js +89 -0
- data/webpack/scenes/Content/ContentSelectors.js +43 -0
- data/webpack/scenes/Content/Details/ContentCounts.js +42 -0
- data/webpack/scenes/Content/Details/ContentDetails.js +66 -0
- data/webpack/scenes/Content/Details/ContentInfo.js +60 -0
- data/webpack/scenes/Content/Details/ContentRepositories.js +78 -0
- data/webpack/scenes/Content/Details/__tests__/ansibleCollectionDetails.fixtures.json +20 -0
- data/webpack/scenes/Content/Details/__tests__/ansibleCollectionRepositoryDetails.fixtures.json +71 -0
- data/webpack/scenes/Content/Details/__tests__/contentDetail.test.js +152 -0
- data/webpack/scenes/Content/Details/__tests__/pythonPackageDetails.fixtures.json +20 -0
- data/webpack/scenes/Content/Details/__tests__/pythonPackageRepositoryDetails.fixtures.json +71 -0
- data/webpack/scenes/Content/Details/index.js +4 -0
- data/webpack/scenes/Content/Table/ContentTable.js +90 -0
- data/webpack/scenes/Content/Table/index.js +3 -0
- data/webpack/scenes/Content/__tests__/ansibleCollections.fixtures.json +50 -0
- data/webpack/scenes/Content/__tests__/contentTable.test.js +89 -0
- data/webpack/scenes/Content/__tests__/contentTypes.fixtures.json +66 -0
- data/webpack/scenes/Content/__tests__/pythonPackages.fixtures.json +30 -0
- data/webpack/scenes/Content/index.js +4 -0
- data/webpack/scenes/ContentViews/ContentViewSelectors.js +5 -6
- data/webpack/scenes/ContentViews/ContentViewsActions.js +13 -8
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +31 -4
- data/webpack/scenes/ContentViews/ContentViewsPage.js +4 -0
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +19 -7
- data/webpack/scenes/ContentViews/Copy/CopyContentViewModal.js +7 -5
- data/webpack/scenes/ContentViews/Copy/__tests__/copyContentView.test.js +1 -1
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +7 -3
- data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +1 -2
- data/webpack/scenes/ContentViews/Delete/CVDeleteContext.js +4 -0
- data/webpack/scenes/ContentViews/Delete/ContentViewDeleteWizard.js +170 -0
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeleteEnvironmentsSelection.js +108 -0
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionFinish.js +69 -0
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignActivationKeysForm.js +121 -0
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignHostsForm.js +120 -0
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReview.js +62 -0
- data/webpack/scenes/ContentViews/Delete/Steps/CVEnvironmentSelectionForm.scss +4 -0
- data/webpack/scenes/ContentViews/Delete/__tests__/CvData.fixtures.json +259 -0
- data/webpack/scenes/ContentViews/Delete/__tests__/affectedHosts.fixtures.json +155 -0
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +241 -0
- data/webpack/scenes/ContentViews/Delete/__tests__/cvDetails.fixtures.json +248 -0
- data/webpack/scenes/ContentViews/Delete/__tests__/cvVersionsData.fixtures.json +865 -0
- data/webpack/scenes/ContentViews/Delete/__tests__/envPathData.fixtures.json +424 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +15 -7
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +123 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentEnvironments.js +1 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentVersion.js +8 -5
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +109 -51
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.fixtures.json +21 -6
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +80 -16
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +248 -3
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +141 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +36 -54
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +20 -4
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +63 -38
- data/webpack/scenes/ContentViews/Details/Filters/Add/__tests__/cvFilterAdd.test.js +3 -4
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositorySelection.js +65 -0
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +260 -0
- data/webpack/scenes/ContentViews/Details/Filters/ArtifactsWithNoErrata.js +54 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +202 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +291 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +441 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVFilterDetailType.js +62 -3
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +302 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +186 -23
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +144 -19
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +2 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetails.js +44 -13
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetailsHeader.js +81 -17
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +43 -43
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVRpmMatchContentModal.js +96 -0
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContent.fixtures.json +166 -0
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentModal.test.js +90 -0
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentSearch.fixtures.json +33 -0
- data/webpack/scenes/ContentViews/Details/Filters/Rules/ContainerTag/AddEditContainerTagRuleModal.js +91 -0
- data/webpack/scenes/ContentViews/Details/Filters/Rules/Package/AddEditPackageRuleModal.js +237 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.fixtures.json +42 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +265 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +218 -11
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/ContentViewPackageGroupFilter.test.js +517 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/allFilterErrata.fixtures.json +122 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/allFilterModulesStreams.fixtures.json +60 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewErrataByDateDetails.fixtures.json +359 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetail.fixtures.json +88 -102
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +34 -9
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.fixtures.json +148 -132
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +25 -7
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvAllRepos.fixtures.json +150 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataDateFilterContent.test.js +74 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataIDFilter.test.js +404 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErratumFilterDetails.fixtures.json +89 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterDetailModuleAffectedRepos.fixtures.json +383 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterDetailWithAffectedRepos.fixtures.json +375 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterFixutre.fixture.json +282 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilter.test.js +392 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilterDetails.fixtures.json +97 -0
- data/webpack/scenes/ContentViews/Details/Filters/index.js +26 -0
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +68 -79
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +163 -0
- data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromoteSelectors.js +16 -0
- data/webpack/scenes/ContentViews/Details/Repositories/ContentCounts.js +9 -1
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +88 -74
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +8 -9
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.fixtures.json +3 -3
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionContent.js +30 -9
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionEnvironments.js +1 -1
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionErrata.js +9 -5
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionErrata.scss +2 -2
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +132 -14
- data/webpack/scenes/ContentViews/Details/Versions/Delete/DeleteContext.js +4 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveCVVersionWizard.js +176 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVEnvironmentSelectionForm.js +127 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignActivationKeysForm.js +131 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignHostsForm.js +128 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionDeleteFinish.js +94 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionRemoveReview.js +67 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvAffectedActivationKeys.fixture.json +53 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvAffectedHosts.fixture.json +153 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvDropDownOptionsResponse.fixture.json +192 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +313 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemoveResponse.fixture.json +74 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/versionRemoveEnvPaths.fixtures.json +352 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/versionsResponseData.fixtures.json +583 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedActivationKeys.js +96 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedHosts.js +97 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +332 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.js +128 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.scss +44 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +66 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +125 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionRepositoryCell.js +115 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionAnsibleCollections.fixtures.json +449 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionComponent.fixtures.json +753 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDebPackages.fixtures.json +58 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.fixtures.json +158 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +289 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsCounts.fixtures.json +73 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +44 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDockerTags.fixtures.json +3024 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionErrata.fixtures.json +201 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionFiles.fixtures.json +22 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionModuleStreams.fixtures.json +196 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionRepositories.fixtures.json +1000 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionRpmPackageGroups.fixtures.json +44 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionRpmPackages.fixtures.json +394 -0
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.fixtures.json +4 -4
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +95 -26
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersionsWithTask.fixtures.json +2 -2
- data/webpack/scenes/ContentViews/Details/Versions/index.js +25 -0
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +20 -16
- data/webpack/scenes/ContentViews/Publish/__tests__/publishContentView.test.js +3 -5
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +106 -64
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +25 -4
- data/webpack/scenes/ContentViews/__tests__/basicContentViews.fixtures.js +1 -1
- data/webpack/scenes/ContentViews/__tests__/contentViewList.fixtures.json +4 -1
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +29 -36
- data/webpack/scenes/ContentViews/__tests__/mockDetails.fixtures.json +10 -0
- data/webpack/scenes/ContentViews/components/CVBreadCrumb.js +117 -0
- data/webpack/scenes/ContentViews/components/ContentViewsCounter.js +59 -0
- data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +4 -3
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +30 -11
- data/webpack/scenes/ContentViews/components/TaskPresenter/TaskPresenter.js +1 -1
- data/webpack/scenes/ContentViews/expansions/DetailsExpansion.js +38 -1
- data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +79 -0
- data/webpack/scenes/ContentViews/expansions/RelatedContentViewComponentsModal.js +107 -0
- data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsModal.test.js +59 -0
- data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsResponse.fixtures.json +116 -0
- data/webpack/scenes/ContentViews/expansions/__tests__/relatedCompositeCvs.fixtures.json +4 -0
- data/webpack/scenes/ContentViews/helpers.js +1 -0
- data/webpack/scenes/RedHatRepositories/components/RepositorySetRepository/RepositorySetRepository.js +1 -1
- data/webpack/scenes/RedHatRepositories/components/SearchBar.js +4 -3
- data/webpack/scenes/SmartProxy/SmartProxyContentTable.js +1 -1
- data/webpack/scenes/Subscriptions/SubscriptionsPage.js +17 -9
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/__tests__/__snapshots__/SubscriptionsTable.test.js.snap +3 -3
- data/webpack/test-utils/nockWrapper.js +20 -3
- data/webpack/utils/helpers.js +16 -2
- data/webpack/utils/useDebounce.js +20 -0
- metadata +232 -54
- data/app/assets/javascripts/katello/widgets/tabs.js +0 -13
- data/app/assets/stylesheets/katello/widgets/tabs.scss +0 -69
- data/app/lib/actions/katello/provider/update.rb +0 -38
- data/webpack/components/RoutedTabs/RoutedTabs.js +0 -90
- data/webpack/components/Search/Search.test.js +0 -23
- data/webpack/components/Search/__snapshots__/Search.test.js.snap +0 -21
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab.js +0 -42
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.test.js +0 -145
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionPackages.js +0 -0
@@ -0,0 +1,38 @@
|
|
1
|
+
module Actions
|
2
|
+
module Katello
|
3
|
+
module CdnConfiguration
|
4
|
+
class Update < Actions::EntryAction
|
5
|
+
def plan(cdn_configuration, options)
|
6
|
+
cdn_configuration.update!(options)
|
7
|
+
|
8
|
+
if cdn_configuration.redhat?
|
9
|
+
cdn_configuration.ssl_cert = nil
|
10
|
+
cdn_configuration.ssl_key = nil
|
11
|
+
else
|
12
|
+
resource = ::Katello::Resources::CDN::CdnResource.create(cdn_configuration: cdn_configuration)
|
13
|
+
keypair = resource.debug_certificate
|
14
|
+
cdn_configuration.ssl_cert = OpenSSL::X509::Certificate.new(keypair)
|
15
|
+
cdn_configuration.ssl_key = OpenSSL::PKey::RSA.new(keypair)
|
16
|
+
end
|
17
|
+
|
18
|
+
cdn_configuration.save!
|
19
|
+
|
20
|
+
org = cdn_configuration.organization
|
21
|
+
roots = ::Katello::RootRepository.redhat.in_organization(org)
|
22
|
+
roots.each do |root|
|
23
|
+
full_path = if cdn_configuration.redhat?
|
24
|
+
root.product.repo_url(root.library_instance.generate_content_path)
|
25
|
+
else
|
26
|
+
resource.repository_url(content_label: root.content.label)
|
27
|
+
end
|
28
|
+
plan_action(::Actions::Katello::Repository::Update, root, url: full_path)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def humanized_name
|
33
|
+
_("Update CDN Configuration")
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -11,8 +11,10 @@ module Actions
|
|
11
11
|
# system_environment_id - environment to reassociate systems with
|
12
12
|
# key_content_view_id - content view to reassociate actvation keys with
|
13
13
|
# key_environment_id - environment to reassociate activation keys with'
|
14
|
+
# destroy_content_view - delete the CV completely along with all cv versions and environments
|
14
15
|
# organization_destroy
|
15
16
|
# rubocop:disable Metrics/MethodLength
|
17
|
+
# rubocop:disable Metrics/CyclomaticComplexity
|
16
18
|
def plan(content_view, options)
|
17
19
|
cv_envs = options.fetch(:content_view_environments, [])
|
18
20
|
versions = options.fetch(:content_view_versions, [])
|
@@ -58,8 +60,11 @@ module Actions
|
|
58
60
|
:skip_environment_check => true,
|
59
61
|
:skip_destroy_env_content => true)
|
60
62
|
end
|
61
|
-
|
63
|
+
if options[:destroy_content_view] && SmartProxy.pulp_primary&.pulp3_enabled?
|
64
|
+
plan_action(Actions::Pulp3::ContentView::DeleteRepositoryReferences, content_view, SmartProxy.pulp_primary)
|
65
|
+
end
|
62
66
|
plan_self(content_view_id: content_view.id,
|
67
|
+
destroy_content_view: options[:destroy_content_view],
|
63
68
|
environment_ids: cv_envs.map(&:environment_id),
|
64
69
|
environment_names: cv_envs.map { |cve| cve.environment.name },
|
65
70
|
version_ids: versions.map(&:id),
|
@@ -87,17 +92,23 @@ module Actions
|
|
87
92
|
end
|
88
93
|
|
89
94
|
def finalize
|
90
|
-
input[:
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
+
if input[:destroy_content_view]
|
96
|
+
content_view = ::Katello::ContentView.find(input[:content_view_id])
|
97
|
+
content_view.content_view_repositories.each(&:destroy)
|
98
|
+
content_view.destroy!
|
99
|
+
else
|
100
|
+
input[:content_view_history_ids].each do |history_id|
|
101
|
+
history = ::Katello::ContentViewHistory.find_by(:id => history_id)
|
102
|
+
if history
|
103
|
+
history.status = ::Katello::ContentViewHistory::SUCCESSFUL
|
104
|
+
history.save!
|
105
|
+
end
|
95
106
|
end
|
96
107
|
end
|
97
108
|
end
|
98
109
|
|
99
110
|
def validate_options(_content_view, cv_envs, versions, options)
|
100
|
-
if cv_envs.empty? && versions.empty?
|
111
|
+
if !options[:destroy_content_view] && cv_envs.empty? && versions.empty?
|
101
112
|
fail _("Either environments or versions must be specified.")
|
102
113
|
end
|
103
114
|
all_cv_envs = combined_cv_envs(cv_envs, versions)
|
@@ -5,7 +5,7 @@ module Actions
|
|
5
5
|
def plan(content_view_version)
|
6
6
|
action_subject(content_view_version.content_view)
|
7
7
|
plan_self(:version_id => content_view_version.id)
|
8
|
-
plan_action(::Actions::Katello::Repository::BulkMetadataGenerate, content_view_version.repositories
|
8
|
+
plan_action(::Actions::Katello::Repository::BulkMetadataGenerate, content_view_version.repositories)
|
9
9
|
end
|
10
10
|
|
11
11
|
def run
|
@@ -23,9 +23,8 @@ module Actions
|
|
23
23
|
matching_content = check_matching_content(new_repository, source_repositories)
|
24
24
|
metadata_generate(source_repositories, new_repository, filters, rpm_filenames, matching_content) if generate_metadata
|
25
25
|
|
26
|
-
index_options = {id: new_repository.id}
|
26
|
+
index_options = {id: new_repository.id, force_index: true}
|
27
27
|
index_options[:source_repository_id] = source_repositories.first.id if source_repositories.count == 1 && filters.empty? && rpm_filenames.nil?
|
28
|
-
index_options[:matching_content] = matching_content
|
29
28
|
plan_action(Katello::Repository::IndexContent, index_options)
|
30
29
|
end
|
31
30
|
end
|
@@ -8,12 +8,14 @@ module Actions
|
|
8
8
|
# skip_environment_update - defaults to false. skips updating the CP environment
|
9
9
|
# destroy_content - can be disabled to skip Candlepin remove_content
|
10
10
|
def plan(repository, options = {})
|
11
|
+
affected_cvv_ids = []
|
11
12
|
skip_environment_update = options.fetch(:skip_environment_update, false) ||
|
12
13
|
options.fetch(:organization_destroy, false)
|
13
14
|
destroy_content = options.fetch(:destroy_content, true)
|
15
|
+
remove_from_content_view_versions = options.fetch(:remove_from_content_view_versions, false)
|
14
16
|
action_subject(repository)
|
15
17
|
|
16
|
-
unless repository.destroyable?
|
18
|
+
unless repository.destroyable?(remove_from_content_view_versions)
|
17
19
|
# The repository is going to be deleted in finalize, but it cannot be deleted.
|
18
20
|
# Stop now and inform the user.
|
19
21
|
fail repository.errors.messages.values.join("\n")
|
@@ -23,7 +25,13 @@ module Actions
|
|
23
25
|
repository,
|
24
26
|
SmartProxy.pulp_primary)
|
25
27
|
|
26
|
-
|
28
|
+
if remove_from_content_view_versions
|
29
|
+
library_instances_inverse = repository.library_instances_inverse
|
30
|
+
affected_cvv_ids = library_instances_inverse.pluck(:content_view_version_id).uniq
|
31
|
+
plan_action(::Actions::BulkAction, ::Actions::Katello::Repository::Destroy, library_instances_inverse)
|
32
|
+
end
|
33
|
+
|
34
|
+
plan_self(:user_id => ::User.current.id, :affected_cvv_ids => affected_cvv_ids)
|
27
35
|
sequence do
|
28
36
|
if repository.redhat?
|
29
37
|
handle_redhat_content(repository) unless skip_environment_update
|
@@ -36,9 +44,17 @@ module Actions
|
|
36
44
|
end
|
37
45
|
|
38
46
|
def finalize
|
39
|
-
repository = ::Katello::Repository.
|
40
|
-
|
41
|
-
|
47
|
+
repository = ::Katello::Repository.find_by(id: input[:repository][:id])
|
48
|
+
if repository
|
49
|
+
docker_cleanup = repository.content_type == ::Katello::Repository::DOCKER_TYPE
|
50
|
+
delete_record(repository, {docker_cleanup: docker_cleanup})
|
51
|
+
|
52
|
+
if (affected_cvv_ids = input[:affected_cvv_ids]).any?
|
53
|
+
affected_cvv_ids.each do |cvv_id|
|
54
|
+
::Katello::ContentViewVersion.find(cvv_id).update_content_counts!
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
42
58
|
end
|
43
59
|
|
44
60
|
def handle_custom_content(repository)
|
@@ -25,7 +25,7 @@ module Actions
|
|
25
25
|
|
26
26
|
def needs_download?(repository)
|
27
27
|
repository.distribution_bootable? &&
|
28
|
-
repository.download_policy == ::
|
28
|
+
repository.download_policy == ::Katello::RootRepository::DOWNLOAD_ON_DEMAND
|
29
29
|
end
|
30
30
|
end
|
31
31
|
end
|
@@ -13,7 +13,7 @@ module Actions
|
|
13
13
|
unit_type_id = SmartProxy.pulp_primary.content_service(content_type)::CONTENT_TYPE
|
14
14
|
end
|
15
15
|
generate_metadata = options.fetch(:generate_metadata, true)
|
16
|
-
plan_action(Katello::Repository::MetadataGenerate, repository, :dependency => import_upload_task) if generate_metadata
|
16
|
+
plan_action(Katello::Repository::MetadataGenerate, repository, :dependency => import_upload_task, :force_publication => true) if generate_metadata
|
17
17
|
|
18
18
|
recent_range = 5.minutes.ago.utc.iso8601
|
19
19
|
plan_action(Katello::Repository::FilteredIndexContent,
|
@@ -41,7 +41,7 @@ module Actions
|
|
41
41
|
import_upload.output
|
42
42
|
end
|
43
43
|
end
|
44
|
-
plan_action(Katello::Repository::MetadataGenerate, repository) if generate_metadata
|
44
|
+
plan_action(Katello::Repository::MetadataGenerate, repository, force_publication: true) if generate_metadata
|
45
45
|
plan_action(Actions::Katello::Applicability::Repository::Regenerate, :repo_ids => [repository.id]) if generate_applicability
|
46
46
|
plan_self(repository_id: repository.id, sync_capsule: sync_capsule, upload_results: upload_results)
|
47
47
|
end
|
@@ -2,21 +2,34 @@ module Actions
|
|
2
2
|
module Katello
|
3
3
|
module Repository
|
4
4
|
class IndexContent < Actions::EntryAction
|
5
|
-
middleware.use Actions::Middleware::ExecuteIfContentsChanged
|
6
|
-
|
7
5
|
input_format do
|
8
6
|
param :id, Integer
|
9
|
-
param :dependency, Hash
|
10
|
-
param :contents_changed
|
11
|
-
param :matching_content
|
12
7
|
param :source_repository_id
|
13
8
|
param :full_index
|
9
|
+
param :force_index
|
14
10
|
end
|
15
11
|
|
16
12
|
def run
|
17
13
|
source_repository = ::Katello::Repository.find(input[:source_repository_id]) if input[:source_repository_id]
|
18
14
|
repo = ::Katello::Repository.find(input[:id])
|
19
|
-
|
15
|
+
|
16
|
+
initial_counts = {}
|
17
|
+
repo.repository_type.primary_content_types.each do |content_type|
|
18
|
+
initial_counts[content_type.label] = content_type.model_class.in_repositories(repo).count
|
19
|
+
end
|
20
|
+
|
21
|
+
if input[:force_index] || (repo.last_contents_changed >= repo.last_indexed)
|
22
|
+
repo.index_content(source_repository: source_repository, full_index: input[:full_index].present?)
|
23
|
+
repo.update(:last_indexed => DateTime.now)
|
24
|
+
else
|
25
|
+
output[:index_skipped] = true
|
26
|
+
end
|
27
|
+
|
28
|
+
output[:new_content] = {}
|
29
|
+
repo.repository_type.primary_content_types.each do |content_type|
|
30
|
+
new_count = content_type.model_class.in_repositories(repo).count
|
31
|
+
output[:new_content][content_type.label] = new_count - initial_counts[content_type.label]
|
32
|
+
end
|
20
33
|
end
|
21
34
|
end
|
22
35
|
end
|
@@ -7,9 +7,11 @@ module Actions
|
|
7
7
|
source_repository ||= repository.target_repository if repository.link?
|
8
8
|
smart_proxy = options.fetch(:smart_proxy, SmartProxy.pulp_primary)
|
9
9
|
matching_content = options.fetch(:matching_content, false)
|
10
|
+
force_publication = options.fetch(:force_publication, false)
|
10
11
|
|
11
12
|
plan_action(Pulp3::Orchestration::Repository::GenerateMetadata,
|
12
13
|
repository, smart_proxy,
|
14
|
+
:force_publication => force_publication,
|
13
15
|
:source_repository => source_repository,
|
14
16
|
:matching_content => matching_content)
|
15
17
|
end
|
@@ -27,7 +27,7 @@ module Actions
|
|
27
27
|
end
|
28
28
|
|
29
29
|
extended_repo_mapping.values.each do |dest_repo_map|
|
30
|
-
plan_action(Katello::Repository::IndexContent, id: dest_repo_map[:dest_repo].id
|
30
|
+
plan_action(Katello::Repository::IndexContent, id: dest_repo_map[:dest_repo].id)
|
31
31
|
end
|
32
32
|
end
|
33
33
|
end
|
@@ -42,7 +42,7 @@ module Actions
|
|
42
42
|
|
43
43
|
def create_sub_plans
|
44
44
|
trigger(Actions::Katello::Repository::MetadataGenerate,
|
45
|
-
::Katello::Repository.find(input[:repository][:id]))
|
45
|
+
::Katello::Repository.find(input[:repository][:id]), :force_publication => true)
|
46
46
|
end
|
47
47
|
|
48
48
|
def resource_locks
|
@@ -18,21 +18,20 @@ module Actions
|
|
18
18
|
# of Katello and we just need to finish the rest of the orchestration
|
19
19
|
# rubocop:disable Metrics/MethodLength
|
20
20
|
# rubocop:disable Metrics/CyclomaticComplexity
|
21
|
-
# rubocop:disable Metrics/PerceivedComplexity
|
22
21
|
def plan(repo, options = {})
|
23
22
|
action_subject(repo)
|
24
23
|
|
25
24
|
source_url = options.fetch(:source_url, nil)
|
26
25
|
validate_contents = options.fetch(:validate_contents, false)
|
27
26
|
skip_metadata_check = options.fetch(:skip_metadata_check, false) || (validate_contents && repo.yum?)
|
28
|
-
generate_applicability = options.fetch(:generate_applicability, repo.yum?)
|
27
|
+
generate_applicability = options.fetch(:generate_applicability, repo.yum? || repo.deb?)
|
29
28
|
|
30
29
|
fail ::Katello::Errors::InvalidActionOptionError, _("Unable to sync repo. This repository does not have a feed url.") if repo.url.blank? && source_url.blank?
|
31
30
|
fail ::Katello::Errors::InvalidActionOptionError, _("Cannot validate contents on non-yum/deb repositories.") if validate_contents && !repo.yum? && !repo.deb?
|
32
31
|
fail ::Katello::Errors::InvalidActionOptionError, _("Cannot skip metadata check on non-yum repositories.") if skip_metadata_check && !repo.yum?
|
33
32
|
|
34
33
|
pulp_sync_options = {}
|
35
|
-
pulp_sync_options[:download_policy] = ::
|
34
|
+
pulp_sync_options[:download_policy] = ::Katello::RootRepository::DOWNLOAD_ON_DEMAND if validate_contents && repo.yum?
|
36
35
|
|
37
36
|
#pulp3 options
|
38
37
|
pulp_sync_options[:optimize] = false if skip_metadata_check && repo.yum?
|
@@ -47,14 +46,11 @@ module Actions
|
|
47
46
|
pulp_sync_options)
|
48
47
|
output = sync_action.output
|
49
48
|
|
50
|
-
|
51
|
-
|
52
|
-
plan_action(Katello::Repository::IndexContent, :id => repo.id, :contents_changed => contents_changed)
|
49
|
+
plan_action(Katello::Repository::IndexContent, :id => repo.id, :force_index => skip_metadata_check)
|
53
50
|
plan_action(Katello::Foreman::ContentUpdate, repo.environment, repo.content_view, repo)
|
54
51
|
plan_action(Katello::Repository::FetchPxeFiles, :id => repo.id)
|
55
52
|
plan_action(Katello::Repository::CorrectChecksum, repo)
|
56
53
|
concurrence do
|
57
|
-
plan_action(Katello::Repository::MetadataGenerate, repo, :force => true) if skip_metadata_check && repo.yum?
|
58
54
|
plan_action(Katello::Repository::ErrataMail, repo, nil, contents_changed)
|
59
55
|
plan_action(Actions::Katello::Applicability::Repository::Regenerate, :repo_ids => [repo.id]) if generate_applicability
|
60
56
|
end
|
@@ -6,7 +6,7 @@ module Actions
|
|
6
6
|
repo_id = action.input[:repository_id]
|
7
7
|
repo = ::Katello::Repository.find_by(id: repo_id)
|
8
8
|
smart_proxy_id = action.input[:smart_proxy_id] || action.input[:capsule_id]
|
9
|
-
smart_proxy = ::SmartProxy.find_by(id: smart_proxy_id)
|
9
|
+
smart_proxy = ::SmartProxy.unscoped.find_by(id: smart_proxy_id)
|
10
10
|
|
11
11
|
if repo && smart_proxy
|
12
12
|
self.action.output[:smart_proxy_history_id] = repo.create_smart_proxy_sync_history(smart_proxy)
|
@@ -7,7 +7,7 @@ module Actions
|
|
7
7
|
end
|
8
8
|
|
9
9
|
def invoke_external_task
|
10
|
-
smart_proxy_service = ::Katello::Pulp::SmartProxyRepository.new(::SmartProxy.find(input[:smart_proxy_id]))
|
10
|
+
smart_proxy_service = ::Katello::Pulp::SmartProxyRepository.new(::SmartProxy.unscoped.find(input[:smart_proxy_id]))
|
11
11
|
smart_proxy_service.delete_orphaned_repos
|
12
12
|
end
|
13
13
|
end
|
@@ -9,7 +9,7 @@ module Actions
|
|
9
9
|
def invoke_external_task
|
10
10
|
repo = ::Katello::Repository.find(input[:repo_id])
|
11
11
|
::Katello::RepositoryTypeManager.find(repo.content_type).content_types.map do |type|
|
12
|
-
::SmartProxy.find(input[:smart_proxy_id]).content_service(type).remove(repo)
|
12
|
+
::SmartProxy.unscoped.find(input[:smart_proxy_id]).content_service(type).remove(repo)
|
13
13
|
end
|
14
14
|
end
|
15
15
|
end
|
@@ -105,11 +105,20 @@ module Actions
|
|
105
105
|
def check_for_errors
|
106
106
|
combined_tasks.each do |task|
|
107
107
|
if (message = task.error)
|
108
|
-
fail ::Katello::Errors::Pulp3Error, message
|
108
|
+
fail ::Katello::Errors::Pulp3Error, overwrite_pulp_error(message)
|
109
109
|
end
|
110
110
|
end
|
111
111
|
end
|
112
112
|
|
113
|
+
def overwrite_pulp_error(message)
|
114
|
+
case message
|
115
|
+
when 'This repository uses features which are incompatible with \'mirror\' sync. Please sync without mirroring enabled.'
|
116
|
+
'Please disable \'mirror on sync\' because the upstream repository refers to external resources.'
|
117
|
+
else
|
118
|
+
message
|
119
|
+
end
|
120
|
+
end
|
121
|
+
|
113
122
|
def external_task=(external_task_data)
|
114
123
|
#currently we assume everything coming from invoke_external_task_methods are tasks
|
115
124
|
tasks = transform_task_response(external_task_data)
|
@@ -6,30 +6,25 @@ module Actions
|
|
6
6
|
def plan(repository, smart_proxy, options = {})
|
7
7
|
options[:contents_changed] = (options && options.key?(:contents_changed)) ? options[:contents_changed] : true
|
8
8
|
sequence do
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
plan_action(RefreshDistribution, repository, smart_proxy,
|
13
|
-
:tasks => action_output,
|
14
|
-
:use_repository_version => false,
|
15
|
-
:contents_changed => options[:contents_changed])
|
16
|
-
else
|
17
|
-
plan_action(RefreshDistribution, repository, smart_proxy,
|
18
|
-
:use_repository_version => true,
|
19
|
-
:contents_changed => options[:contents_changed])
|
9
|
+
unless repository.repository_type.pulp3_skip_publication
|
10
|
+
plan_self(:repository_id => repository.id, :smart_proxy_id => smart_proxy.id,
|
11
|
+
:options => options).output
|
20
12
|
end
|
13
|
+
plan_action(RefreshDistribution, repository, smart_proxy,
|
14
|
+
:contents_changed => options[:contents_changed])
|
21
15
|
end
|
22
16
|
end
|
23
17
|
|
24
18
|
def invoke_external_task
|
25
|
-
if input[:options][:sync_task_output] &&
|
26
|
-
::Katello::Pulp3::Task.publication_href(input[:options][:sync_task_output]).present?
|
27
|
-
return input[:options][:sync_task_output]
|
28
|
-
end
|
29
|
-
|
30
19
|
repository = ::Katello::Repository.find(input[:repository_id])
|
31
|
-
|
32
|
-
|
20
|
+
#yum repositories use metadata mirroring always, so we should never
|
21
|
+
# regenerate metadata on proxies
|
22
|
+
if repository.yum?
|
23
|
+
[]
|
24
|
+
else
|
25
|
+
smart_proxy = ::SmartProxy.unscoped.find(input[:smart_proxy_id])
|
26
|
+
repository.backend_service(smart_proxy).with_mirror_adapter.create_publication
|
27
|
+
end
|
33
28
|
end
|
34
29
|
end
|
35
30
|
end
|
@@ -13,18 +13,8 @@ module Actions
|
|
13
13
|
|
14
14
|
def invoke_external_task
|
15
15
|
smart_proxy = ::SmartProxy.unscoped.find(input[:smart_proxy_id])
|
16
|
-
options = input[:options]
|
17
|
-
tasks = options[:tasks]
|
18
16
|
repo = ::Katello::Repository.find(input[:repository_id])
|
19
|
-
|
20
|
-
repo.backend_service(smart_proxy).with_mirror_adapter.refresh_distributions(:use_repository_version => true)
|
21
|
-
elsif tasks && tasks[:pulp_tasks] && tasks[:pulp_tasks].first
|
22
|
-
if (publication_href = ::Katello::Pulp3::Task.publication_href(tasks[:pulp_tasks]))
|
23
|
-
repo.backend_service(smart_proxy).with_mirror_adapter.refresh_distributions(:publication => publication_href)
|
24
|
-
else
|
25
|
-
fail "Unable to refresh distribution for repo #{repository.id}, could not find a publication_href"
|
26
|
-
end
|
27
|
-
end
|
17
|
+
repo.backend_service(smart_proxy).with_mirror_adapter.refresh_distributions
|
28
18
|
end
|
29
19
|
end
|
30
20
|
end
|
@@ -17,7 +17,7 @@ module Actions
|
|
17
17
|
end
|
18
18
|
|
19
19
|
def run
|
20
|
-
smart_proxy = ::SmartProxy.find(input[:smart_proxy_id])
|
20
|
+
smart_proxy = ::SmartProxy.unscoped.find(input[:smart_proxy_id])
|
21
21
|
api = ::Katello::Pulp3::Api::Core.new(smart_proxy)
|
22
22
|
export_data = api.export_api.list(input[:exporter_data][:pulp_href]).results.first
|
23
23
|
output[:exported_file_checksum] = export_data.output_file_info
|
@@ -4,13 +4,15 @@ module Actions
|
|
4
4
|
module Repository
|
5
5
|
class GenerateMetadata < Pulp3::Abstract
|
6
6
|
def plan(repository, smart_proxy, options = {})
|
7
|
+
force_publication = options.fetch(:force_publication, repository.publication_href.nil?)
|
8
|
+
|
7
9
|
options[:contents_changed] = (options && options.key?(:contents_changed)) ? options[:contents_changed] : true
|
8
10
|
publication_content_type = !::Katello::RepositoryTypeManager.find(repository.content_type).pulp3_skip_publication
|
9
11
|
|
10
12
|
sequence do
|
11
13
|
if options[:source_repository] && publication_content_type
|
12
14
|
plan_self(source_repository_id: options[:source_repository].id, target_repository_id: repository.id, smart_proxy_id: smart_proxy.id)
|
13
|
-
elsif publication_content_type
|
15
|
+
elsif publication_content_type && (force_publication || repository.publication_href.nil? || !repository.using_mirrored_metadata?)
|
14
16
|
plan_action(Actions::Pulp3::Repository::CreatePublication, repository, smart_proxy, options)
|
15
17
|
end
|
16
18
|
plan_action(Actions::Pulp3::ContentGuard::Refresh, smart_proxy) unless repository.unprotected
|
@@ -4,58 +4,41 @@ module Actions
|
|
4
4
|
module Orchestration
|
5
5
|
module Repository
|
6
6
|
class ImportUpload < Pulp3::Abstract
|
7
|
-
# rubocop:disable Metrics/AbcSize
|
8
7
|
def plan(repository, smart_proxy, args)
|
9
8
|
file = {:filename => args.dig(:unit_key, :name), :sha256 => args.dig(:unit_key, :checksum) }
|
10
9
|
content_unit_href = args.dig(:unit_key, :content_unit_id)
|
11
10
|
docker_tag = (args.dig(:unit_type_id) == "docker_tag")
|
12
|
-
sequence do
|
13
|
-
if content_unit_href
|
14
|
-
duplicate_sha_path_content_list = ::Katello::Pulp3::PulpContentUnit.find_duplicate_unit(repository, args.dig(:unit_type_id), file, file[:sha256])
|
15
|
-
duplicate_content_href = duplicate_sha_path_content_list&.results&.first&.pulp_href
|
16
11
|
|
17
|
-
|
18
|
-
|
19
|
-
action_output = plan_action(Pulp3::Repository::ImportUpload, duplicate_content_href, repository, smart_proxy).output
|
20
|
-
plan_action(Pulp3::Repository::SaveVersion, repository, tasks: action_output[:pulp_tasks]).output
|
21
|
-
else
|
22
|
-
duplicate_sha_artifact_list = ::Katello::Pulp3::Api::Core.new(smart_proxy).artifacts_api.list("sha256": file[:sha256])
|
23
|
-
duplicate_sha_artifact_href = duplicate_sha_artifact_list&.results&.first&.pulp_href
|
24
|
-
if duplicate_sha_artifact_href
|
25
|
-
artifact_output = plan_action(Pulp3::Repository::SaveArtifact,
|
26
|
-
file, repository, smart_proxy,
|
27
|
-
nil, args.dig(:unit_type_id),
|
28
|
-
artifact_href: duplicate_sha_artifact_href).output
|
29
|
-
content_unit_href = artifact_output[:pulp_tasks]
|
30
|
-
plan_self(:commit_output => nil, :artifact_output => artifact_output[:pulp_tasks])
|
31
|
-
action_output = plan_action(Pulp3::Repository::ImportUpload, content_unit_href, repository, smart_proxy).output
|
32
|
-
plan_action(Pulp3::Repository::SaveVersion, repository, tasks: action_output[:pulp_tasks]).output
|
33
|
-
end
|
34
|
-
end
|
35
|
-
elsif docker_tag
|
12
|
+
sequence do
|
13
|
+
if docker_tag
|
36
14
|
tag_manifest_output = plan_action(Pulp3::Repository::UploadTag,
|
37
|
-
|
38
|
-
|
39
|
-
|
15
|
+
repository,
|
16
|
+
smart_proxy,
|
17
|
+
args).output
|
40
18
|
plan_self(:commit_output => tag_manifest_output[:pulp_tasks])
|
41
19
|
plan_action(Pulp3::Repository::SaveVersion, repository, {force_fetch_version: true, tasks: tag_manifest_output[:pulp_tasks]})
|
42
20
|
else
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
artifact_output = plan_action(Pulp3::Repository::SaveArtifact,
|
50
|
-
file,
|
21
|
+
if content_unit_href
|
22
|
+
artifact_output = { :content_unit_href => content_unit_href }
|
23
|
+
commit_output = {}
|
24
|
+
else
|
25
|
+
commit_output = plan_action(Pulp3::Repository::CommitUpload,
|
51
26
|
repository,
|
52
27
|
smart_proxy,
|
53
|
-
|
54
|
-
args.dig(:
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
28
|
+
"/pulp/api/v3/uploads/" + args.dig(:upload_id) + "/",
|
29
|
+
args.dig(:unit_key, :checksum)).output
|
30
|
+
|
31
|
+
artifact_output = plan_action(Pulp3::Repository::SaveArtifact,
|
32
|
+
file,
|
33
|
+
repository,
|
34
|
+
smart_proxy,
|
35
|
+
commit_output[:pulp_tasks],
|
36
|
+
args.dig(:unit_type_id)).output
|
37
|
+
end
|
38
|
+
|
39
|
+
plan_self(:commit_output => commit_output[:pulp_tasks], :artifact_output => artifact_output)
|
40
|
+
import_output = plan_action(Pulp3::Repository::ImportUpload, artifact_output, repository, smart_proxy).output
|
41
|
+
plan_action(Pulp3::Repository::SaveVersion, repository, tasks: import_output[:pulp_tasks])
|
59
42
|
end
|
60
43
|
end
|
61
44
|
end
|
@@ -65,7 +48,7 @@ module Actions
|
|
65
48
|
if input[:content_unit_href]
|
66
49
|
output[:content_unit_href] = input[:content_unit_href]
|
67
50
|
elsif input[:artifact_output]
|
68
|
-
output[:content_unit_href] = input[:artifact_output].last[:created_resources].first
|
51
|
+
output[:content_unit_href] = input[:artifact_output][:content_unit_href] || input[:artifact_output][:pulp_tasks].last[:created_resources].first
|
69
52
|
else
|
70
53
|
output[:content_unit_href] = nil
|
71
54
|
end
|
@@ -11,7 +11,14 @@ module Actions
|
|
11
11
|
|
12
12
|
force_fetch_version = true if options[:optimize] == false
|
13
13
|
version_output = plan_action(Pulp3::Repository::SaveVersion, repository, tasks: action_output[:pulp_tasks], :force_fetch_version => force_fetch_version).output
|
14
|
-
|
14
|
+
|
15
|
+
#force contents_changed to true if we're doing a 'force' sync
|
16
|
+
if options[:optimize] == false
|
17
|
+
contents_changed = true
|
18
|
+
else
|
19
|
+
contents_changed = version_output[:contents_changed]
|
20
|
+
end
|
21
|
+
plan_action(Pulp3::Orchestration::Repository::GenerateMetadata, repository, smart_proxy, :contents_changed => contents_changed, :skip_publication_creation => version_output[:publication_provided])
|
15
22
|
plan_self(:subaction_output => version_output)
|
16
23
|
end
|
17
24
|
end
|
@@ -19,10 +19,10 @@ module Actions
|
|
19
19
|
upload_action_output = plan_action(Pulp3::Repository::UploadFile, repository, smart_proxy, file[:path]).output
|
20
20
|
artifact_action_output = plan_action(Pulp3::Repository::SaveArtifact, file, repository, smart_proxy, upload_action_output[:pulp_tasks], unit_type_id).output
|
21
21
|
end
|
22
|
-
|
22
|
+
|
23
23
|
end
|
24
|
-
|
25
|
-
action_output = plan_action(Pulp3::Repository::ImportUpload,
|
24
|
+
artifact_action_output ||= {:content_unit_href => duplicate_content_href}
|
25
|
+
action_output = plan_action(Pulp3::Repository::ImportUpload, artifact_action_output, repository, smart_proxy).output
|
26
26
|
plan_action(Pulp3::Repository::SaveVersion, repository, tasks: action_output[:pulp_tasks]).output
|
27
27
|
plan_self(:subaction_output => action_output)
|
28
28
|
end
|
@@ -13,7 +13,7 @@ module Actions
|
|
13
13
|
duplicate_sha_artifact_list = ::Katello::Pulp3::Api::Core.new(smart_proxy).artifacts_api.list("sha256": input[:sha256])
|
14
14
|
duplicate_sha_artifact_href = duplicate_sha_artifact_list&.results&.first&.pulp_href
|
15
15
|
if duplicate_sha_artifact_href
|
16
|
-
uploads_api.delete(upload_href)
|
16
|
+
uploads_api.delete(input[:upload_href])
|
17
17
|
output[:artifact_href] = duplicate_sha_artifact_href
|
18
18
|
output[:pulp_tasks] = nil
|
19
19
|
else
|