pulpcore 3.81.0__tar.gz → 3.82.1__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of pulpcore might be problematic. Click here for more details.
- {pulpcore-3.81.0 → pulpcore-3.82.1}/CHANGES.md +167 -1
- {pulpcore-3.81.0 → pulpcore-3.82.1}/PKG-INFO +4 -4
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/app/__init__.py +1 -1
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/__init__.py +1 -1
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/apps.py +1 -1
- pulpcore-3.82.1/pulpcore/app/migrations/0132_task_profile_options.py +19 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/fields.py +2 -2
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/task.py +1 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/replica.py +3 -9
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/domain.py +1 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/publication.py +4 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/settings.py +2 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/content/handler.py +14 -13
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/middleware.py +25 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/openapi/__init__.py +13 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tasking/_util.py +11 -6
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tasking/tasks.py +3 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_tasking.py +19 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_content_delivery.py +34 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore.egg-info/PKG-INFO +4 -4
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore.egg-info/SOURCES.txt +1 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore.egg-info/requires.txt +3 -3
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pyproject.toml +5 -5
- {pulpcore-3.81.0 → pulpcore-3.82.1}/CODE_OF_CONDUCT.md +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/COMMITMENT +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/CONTRIBUTING.md +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/COPYRIGHT +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/LICENSE +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/MANIFEST.in +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/README.md +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/ci_requirements.txt +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/functest_requirements.txt +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/manage.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/app/migrations/0002_alter_rhsmcertguard_contentguard_ptr_and_more.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/app/migrations/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/app/models.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/app/serializers.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/app/utils.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/app/viewsets.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/pytest_plugin.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/api/test_rhsm_certguard.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/api/test_x509_certguard.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/katello-default-ca.crt +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/katello-default-ca.key +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/trusted_but_expired.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/uber.cert +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/untrusted_cert-key.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/untrusted_cert.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/v1/1514454871848760713-key.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/v1/1514454871848760713.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/v1/159442575569388840-key.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/v1/159442575569388840.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/v3/4260035510644027985-key.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/v3/4260035510644027985.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/v3/5527980418107729172-key.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/rhsm/v3/5527980418107729172.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/certificates/ca.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/genca.sh +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/keys/ca.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/ca.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/client.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/server.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/un_urlencoded_cert.txt +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/untrusted_client.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/genall.sh +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/genca.sh +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/genclient.sh +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/gensrv.sh +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/keys/ca.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/keys/client.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/artifacts/x509/keys/server.pem +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/conftest.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/functional/constants.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/unit/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_certguard/tests/unit/test_models.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0001_initial_squashed_0016_add_domain.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0002_file_related_names.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0003_auto_20191014_1721.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0004_filefilesystemexporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0005_filerepository.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0006_delete_filefilesystemexporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0007_filefilesystemexporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0008_add_manifest_field.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0009_move_data_to_new_master_distribution_model.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0010_auto_publish.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0011_fix_auto_publish.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0012_delete_filefilesystemexporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0013_file_acs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0014_new_rbac_permissions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0015_allow_null_manifest.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0016_add_domain.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/0017_alter_filealternatecontentsource_alternatecontentsource_ptr_and_more.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/migrations/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/modelresource.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/models.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/replica.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/serializers.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/tasks/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/tasks/publishing.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/tasks/synchronizing.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/app/viewsets.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/manifest.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/pytest_plugin.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_acs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_auto_publish.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_bad_sync.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_content_labels.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_crud_content_unit.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_crud_remotes.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_domains.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_download_policies.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_generic_list.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_labels.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_mime_types.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_publish.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_pulp_export.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_rbac.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_remote_settings.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/functional/api/test_sync.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/unit/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/unit/test_safe_paths.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulp_file/tests/unit/test_serializers.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/access_policy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/authentication.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/checks.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/entrypoint.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/files.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/global_access_conditions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/importexport.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/loggers.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/manage.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/add-signing-service.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/analyze-publication.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/clean-up-progress-reports.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/datarepair-2327.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/dump-permissions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/dump-publications-to-fs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/handle-artifact-checksums.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/migrationstat.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/openapi.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/rebasemigrations.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/remove-plugin.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/remove-signing-service.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/repository-size.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/reset-admin-password.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/management/commands/rotate-db-key.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0001_squashed_0090_char_to_text_field.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0002_increase_artifact_size_field.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0003_remove_upload_completed.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0004_add_duplicated_reserved_resources.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0005_progressreport_code.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0006_repository_plugin_managed.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0007_delete_progress_proxies.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0008_published_metadata_as_content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0009_remove_task_non_fatal_errors.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0010_pulp_fields.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0011_relative_path.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0012_auto_20191104_2000.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0013_repository_pulp_type.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0014_remove_repository_plugin_managed.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0015_auto_20191112_1426.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0016_charfield_to_textfield.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0017_remove_task_parent.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0018_auto_20191127_2350.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0019_add_signing_service_model.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0020_change_publishedartifact_constraints.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0021_add_signing_service_foreign_key.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0022_rename_last_version.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0023_change_exporter_models.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0024_use_local_storage_for_uploads.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0025_task_parent_task.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0026_task_group.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0027_export_backend.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0028_import_importer_pulpimporter_pulpimporterrepository.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0029_export_delete.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0030_taskgroup_all_tasks_dispatched.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0031_import_export_validate_params.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0032_export_to_chunks.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0033_increase_remote_artifact_size_field.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0034_groupprogressreport.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0035_content_upstream_id.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0036_unprotect_last_export.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0037_pulptemporaryfile.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0038_repository_remote.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0039_change_download_concurrency.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0040_set_admin_is_staff.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0041_accesspolicy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0042_rbac_for_tasks.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0043_toc_attribute.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0044_temp_file_artifact_field.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0045_accesspolicy_permissions_allow_null.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0046_task__resource_job_id.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0047_improve_orphan_cleanup.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0048_fips_checksums.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0049_add_file_field_to_uploadchunk.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0050_namespace_access_policies.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0051_timeoutfields.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0052_tasking_logging_cid.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0053_remote_headers.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0054_add_public_key.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0055_label.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0056_remote_rate_limit.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0057_add_label_indexes.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0058_accesspolicy_customized.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0059_proxy_creds.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0060_data_migration_proxy_creds.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0061_call_handle_artifact_checksums_command.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0062_add_new_distribution_mastermodel.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0063_repository_retained_versions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0064_add_new_style_task_columns.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0064_repository_user_hidden.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0065_merge_20210615_1211.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0066_download_concurrency_and_retry_changes.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0067_add_protect_to_task_reservation.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0068_add_timestamp_of_interest.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0069_update_json_fields.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0070_rename_retained_versions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0071_filesystemexport_filesystemexporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0072_add_method_to_filesystem_exporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0073_encrypt_remote_fields.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0074_acs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0075_rbaccontentguard.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0076_remove_reserved_resource.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0077_move_remote_url_credentials.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0078_grouprole_role_userrole.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0079_rename_permissions_assignment_accesspolicy_creation_hooks.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0080_proxy_group_model.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0081_reapplabel_group_permissions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0082_add_manage_roles_permissions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0083_alter_group_options.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0084_alter_rbaccontentguard_options.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0085_contentredirectcontentguard.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0086_task_json_fields.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0087_taskschedule.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0088_accesspolicy_queryset_scoping.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0089_alter_contentredirectcontentguard_options.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0090_char_to_text_field.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0091_systemid.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0092_alter_upload_options.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0093_add_info_field_repositoryversion.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0094_protect_repository_content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0095_artifactdistribution.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0096_alter_task_logging_cid.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0097_remove_telemetry_task_schedule.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0098_pulp_labels.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0099_versions_field.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0100_upstreampulp.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0101_add_domain.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0102_add_domain_relations.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0103_alter_export_task.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0104_delete_label.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0105_abstract_uuid_gen.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0106_alter_artifactdistribution_distribution_ptr_and_more.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0107_distribution_hidden.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0108_task_versions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0109_contentartifact_relative_path_index.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0110_apiappstatus.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0111_task_enc_args_task_enc_kwargs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0112_alter_upstreampulp_options.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0113_headercontentguard.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0114_remove_task_args_remove_task_kwargs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0115_compositecontentguard.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0116_alter_remoteartifact_md5_alter_remoteartifact_sha1_and_more.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0117_task_unblocked_at.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0118_task_core_task_unblock_2276a4_idx_and_more.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0119_grouprole_core_groupr_object__250e22_idx_and_more.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0120_get_url_removal.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0121_add_profile_artifacts_table.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0122_record_last_replication_timestamp.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0123_upstreampulp_q_select.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0124_task_deferred_task_immediate.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0125_openpgpdistribution_openpgpkeyring_openpgppublickey_and_more.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0126_remoteartifact_failed_at.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0127_remove_upstreampulp_pulp_label_select.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0128_domain_pulp_labels.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0129_content_pulp_labels.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0130_upstreampulp_policy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0131_distribution_checkpoint_publication_checkpoint.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/0132_alter_content_options.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/migrations/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/mime_types.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/modelresource.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/access_policy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/acs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/analytics.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/domain.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/exporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/generic.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/importer.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/openpgp.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/progress.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/publication.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/replica.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/repository.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/role.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/status.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/storage.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/models/upload.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/netutil.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/openpgp.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/protobuf/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/protobuf/analytics_pb2.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/pulp_hashlib.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/pulpcore_gunicorn_application.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/redis_connection.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/response.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/role_util.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/access_policy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/acs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/exporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/fields.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/importer.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/openpgp.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/orphans.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/progress.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/purge.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/reclaim.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/repair.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/replica.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/repository.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/status.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/task.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/upload.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/serializers/user.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/analytics.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/export.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/importer.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/migrate.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/orphan.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/purge.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/reclaim_space.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/replica.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/repository.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/telemetry.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/test.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/tasks/upload.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/templates/rest_framework/api.html +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/templatetags/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/templatetags/pulp_urls.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/urls.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/util.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/views/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/views/importer.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/views/orphans.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/views/repair.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/views/status.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/access_policy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/acs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/custom_filters.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/domain.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/exporter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/importer.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/openpgp.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/orphans.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/publication.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/reclaim.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/replica.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/repository.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/task.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/upload.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/viewsets/user.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/app/wsgi.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/backends.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/cache/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/cache/cache.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/constants.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/content/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/content/authentication.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/content/entrypoint.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/content/instrumentation.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/download/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/download/base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/download/factory.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/download/file.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/download/http.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/exceptions/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/exceptions/base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/exceptions/plugin.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/exceptions/validation.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/filters.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/metrics.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/migrations.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/openapi/hooks.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/access_policy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/actions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/apps.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/authentication/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/cache/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/constants.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/download/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/exceptions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/files.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/importexport.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/migrations.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/modelresources.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/models/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/models/role.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/publication_utils.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/pulp_hashlib.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/replica.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/repo_version_utils.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/responses.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/serializers/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/serializers/content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/stages/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/stages/api.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/stages/artifact_stages.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/stages/content_stages.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/stages/declarative_version.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/stages/models.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/storage.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/sync.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/tasking.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/util.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/viewsets/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/plugin/viewsets/content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/pytest_plugin.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/responses.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tasking/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tasking/entrypoint.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tasking/kafka.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tasking/storage.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tasking/worker.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_access_policy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_api_docs.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_api_root_rewrite.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_artifact_distribution.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_auth.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_correlation_id.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_crd_artifacts.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_crud_domains.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_filter.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_login.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_openapi_schema.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_openpgp.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_replication.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_repos.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_role.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_root_endpoint.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_scoping.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_signing_service.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_status.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_task_purge.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_upload.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_users_groups.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/test_workers.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_checkpoint.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_content_access.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_content_cache.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_content_directory.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_content_path.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_content_promotion.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_contentguard.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_crud_repos.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_distributions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_filesystemexport.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_labels.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_migrate.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_orphans.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_pagination.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_prn.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_proxy.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_pulpimport.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_reclaim_disk_space.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_repair.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_repo_versions.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_tasks.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/api/using_plugin/test_unlinking_repo.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/assets/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/content_with_coverage.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/functional/utils.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/performance/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/performance/test_performance.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/conftest.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/content/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/content/test_handler.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/content/test_heartbeat.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/download/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/download/test_downloader_base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/download/test_downloader_factory.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/metrics/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/metrics/conftest.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/metrics/test_aiohttp_instrumentation.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/metrics/test_django_instrumentation.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/migration/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/migration/test_0077_move_remote_url_credentials.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/models/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/models/test_base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/models/test_content.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/models/test_remote.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/models/test_repository.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/models/test_task.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/roles/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/roles/test_roles.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/serializers/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/serializers/test_base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/serializers/test_domain.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/serializers/test_fields.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/serializers/test_orphans_cleanup.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/serializers/test_pulpexport.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/serializers/test_repository.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/serializers/test_user.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/stages/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/stages/test_artifactdownloader.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/stages/test_stages.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_cache.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_chunked_file.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_content_guard.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_files.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_import_checks.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_pulp_urls.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_settings.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_util.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/test_viewsets.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/viewsets/__init__.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore/tests/unit/viewsets/test_viewset_base.py +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore.egg-info/dependency_links.txt +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore.egg-info/entry_points.txt +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/pulpcore.egg-info/top_level.txt +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/setup.cfg +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/test_requirements.txt +0 -0
- {pulpcore-3.81.0 → pulpcore-3.82.1}/unittest_requirements.txt +0 -0
|
@@ -8,6 +8,62 @@
|
|
|
8
8
|
|
|
9
9
|
[//]: # (towncrier release notes start)
|
|
10
10
|
|
|
11
|
+
## 3.82.1 (2025-07-04) {: #3.82.1 }
|
|
12
|
+
|
|
13
|
+
### REST API {: #3.82.1-rest-api }
|
|
14
|
+
|
|
15
|
+
No significant changes.
|
|
16
|
+
|
|
17
|
+
### Plugin API {: #3.82.1-plugin-api }
|
|
18
|
+
|
|
19
|
+
No significant changes.
|
|
20
|
+
|
|
21
|
+
### Pulp File {: #3.82.1-pulp-file }
|
|
22
|
+
|
|
23
|
+
No significant changes.
|
|
24
|
+
|
|
25
|
+
### Pulp Cert Guard {: #3.82.1-pulp-cert-guard }
|
|
26
|
+
|
|
27
|
+
No significant changes.
|
|
28
|
+
|
|
29
|
+
---
|
|
30
|
+
|
|
31
|
+
## 3.82.0 (2025-07-02) {: #3.82.0 }
|
|
32
|
+
|
|
33
|
+
### REST API {: #3.82.0-rest-api }
|
|
34
|
+
|
|
35
|
+
#### Features {: #3.82.0-rest-api-feature }
|
|
36
|
+
|
|
37
|
+
- Added support for profiling individual tasks with X-TASK-DIAGNOSTICS header.
|
|
38
|
+
The TASK_DIAGNOSTICS setting now determines which profilers are available to users of the REST API.
|
|
39
|
+
[#6725](https://github.com/pulp/pulpcore/issues/6725)
|
|
40
|
+
|
|
41
|
+
#### Bugfixes {: #3.82.0-rest-api-bugfix }
|
|
42
|
+
|
|
43
|
+
- Fixed S3 Storage configuration.
|
|
44
|
+
[#6630](https://github.com/pulp/pulpcore/issues/6630)
|
|
45
|
+
- Fixed HEAD requests to large on-demand files (>1MB) leaving behind temporary files.
|
|
46
|
+
[#6647](https://github.com/pulp/pulpcore/issues/6647)
|
|
47
|
+
|
|
48
|
+
#### Improved Documentation {: #3.82.0-rest-api-doc }
|
|
49
|
+
|
|
50
|
+
- Updated "Protect Content" documentation regarding the `--guard` command-line option.
|
|
51
|
+
[#6731](https://github.com/pulp/pulpcore/issues/6731)
|
|
52
|
+
|
|
53
|
+
### Plugin API {: #3.82.0-plugin-api }
|
|
54
|
+
|
|
55
|
+
No significant changes.
|
|
56
|
+
|
|
57
|
+
### Pulp File {: #3.82.0-pulp-file }
|
|
58
|
+
|
|
59
|
+
No significant changes.
|
|
60
|
+
|
|
61
|
+
### Pulp Cert Guard {: #3.82.0-pulp-cert-guard }
|
|
62
|
+
|
|
63
|
+
No significant changes.
|
|
64
|
+
|
|
65
|
+
---
|
|
66
|
+
|
|
11
67
|
## 3.81.0 (2025-06-24) {: #3.81.0 }
|
|
12
68
|
|
|
13
69
|
### REST API {: #3.81.0-rest-api }
|
|
@@ -40,6 +96,26 @@ No significant changes.
|
|
|
40
96
|
|
|
41
97
|
---
|
|
42
98
|
|
|
99
|
+
## 3.80.2 (2025-06-24) {: #3.80.2 }
|
|
100
|
+
|
|
101
|
+
### REST API {: #3.80.2-rest-api }
|
|
102
|
+
|
|
103
|
+
No significant changes.
|
|
104
|
+
|
|
105
|
+
### Plugin API {: #3.80.2-plugin-api }
|
|
106
|
+
|
|
107
|
+
No significant changes.
|
|
108
|
+
|
|
109
|
+
### Pulp File {: #3.80.2-pulp-file }
|
|
110
|
+
|
|
111
|
+
No significant changes.
|
|
112
|
+
|
|
113
|
+
### Pulp Cert Guard {: #3.80.2-pulp-cert-guard }
|
|
114
|
+
|
|
115
|
+
No significant changes.
|
|
116
|
+
|
|
117
|
+
---
|
|
118
|
+
|
|
43
119
|
## 3.80.1 (2025-06-12) {: #3.80.1 }
|
|
44
120
|
|
|
45
121
|
### REST API {: #3.80.1-rest-api }
|
|
@@ -534,6 +610,51 @@ No significant changes.
|
|
|
534
610
|
|
|
535
611
|
---
|
|
536
612
|
|
|
613
|
+
## 3.73.14 (2025-06-25) {: #3.73.14 }
|
|
614
|
+
|
|
615
|
+
### REST API {: #3.73.14-rest-api }
|
|
616
|
+
|
|
617
|
+
No significant changes.
|
|
618
|
+
|
|
619
|
+
### Plugin API {: #3.73.14-plugin-api }
|
|
620
|
+
|
|
621
|
+
No significant changes.
|
|
622
|
+
|
|
623
|
+
### Pulp File {: #3.73.14-pulp-file }
|
|
624
|
+
|
|
625
|
+
No significant changes.
|
|
626
|
+
|
|
627
|
+
### Pulp Cert Guard {: #3.73.14-pulp-cert-guard }
|
|
628
|
+
|
|
629
|
+
No significant changes.
|
|
630
|
+
|
|
631
|
+
---
|
|
632
|
+
|
|
633
|
+
## 3.73.13 (2025-06-24) {: #3.73.13 }
|
|
634
|
+
|
|
635
|
+
### REST API {: #3.73.13-rest-api }
|
|
636
|
+
|
|
637
|
+
#### Bugfixes {: #3.73.13-rest-api-bugfix }
|
|
638
|
+
|
|
639
|
+
- Taught tasks to update the state of associated progress-reports when canceled/failed.
|
|
640
|
+
|
|
641
|
+
Added a management-task, `clean-up-progress-reports`, to clean up existing reports.
|
|
642
|
+
[#3609](https://github.com/pulp/pulpcore/issues/3609)
|
|
643
|
+
|
|
644
|
+
### Plugin API {: #3.73.13-plugin-api }
|
|
645
|
+
|
|
646
|
+
No significant changes.
|
|
647
|
+
|
|
648
|
+
### Pulp File {: #3.73.13-pulp-file }
|
|
649
|
+
|
|
650
|
+
No significant changes.
|
|
651
|
+
|
|
652
|
+
### Pulp Cert Guard {: #3.73.13-pulp-cert-guard }
|
|
653
|
+
|
|
654
|
+
No significant changes.
|
|
655
|
+
|
|
656
|
+
---
|
|
657
|
+
|
|
537
658
|
## 3.73.12 (2025-06-11) {: #3.73.12 }
|
|
538
659
|
|
|
539
660
|
### REST API {: #3.73.12-rest-api }
|
|
@@ -903,7 +1024,7 @@ No significant changes.
|
|
|
903
1024
|
|
|
904
1025
|
---
|
|
905
1026
|
|
|
906
|
-
## 3.72.0 (2025-02-25) {: #3.72.0 }
|
|
1027
|
+
## YANKED 3.72.0 (2025-02-25) {: #3.72.0 }
|
|
907
1028
|
|
|
908
1029
|
### REST API {: #3.72.0-rest-api }
|
|
909
1030
|
|
|
@@ -1507,6 +1628,31 @@ No significant changes.
|
|
|
1507
1628
|
|
|
1508
1629
|
---
|
|
1509
1630
|
|
|
1631
|
+
## 3.63.21 (2025-06-24) {: #3.63.21 }
|
|
1632
|
+
|
|
1633
|
+
### REST API {: #3.63.21-rest-api }
|
|
1634
|
+
|
|
1635
|
+
#### Bugfixes {: #3.63.21-rest-api-bugfix }
|
|
1636
|
+
|
|
1637
|
+
- Taught tasks to update the state of associated progress-reports when canceled/failed.
|
|
1638
|
+
|
|
1639
|
+
Added a management-task, `clean-up-progress-reports`, to clean up existing reports.
|
|
1640
|
+
[#3609](https://github.com/pulp/pulpcore/issues/3609)
|
|
1641
|
+
|
|
1642
|
+
### Plugin API {: #3.63.21-plugin-api }
|
|
1643
|
+
|
|
1644
|
+
No significant changes.
|
|
1645
|
+
|
|
1646
|
+
### Pulp File {: #3.63.21-pulp-file }
|
|
1647
|
+
|
|
1648
|
+
No significant changes.
|
|
1649
|
+
|
|
1650
|
+
### Pulp Cert Guard {: #3.63.21-pulp-cert-guard }
|
|
1651
|
+
|
|
1652
|
+
No significant changes.
|
|
1653
|
+
|
|
1654
|
+
---
|
|
1655
|
+
|
|
1510
1656
|
## 3.63.20 (2025-06-04) {: #3.63.20 }
|
|
1511
1657
|
|
|
1512
1658
|
### REST API {: #3.63.20-rest-api }
|
|
@@ -2813,6 +2959,26 @@ No significant changes.
|
|
|
2813
2959
|
|
|
2814
2960
|
---
|
|
2815
2961
|
|
|
2962
|
+
## 3.49.43 (2025-06-24) {: #3.49.43 }
|
|
2963
|
+
|
|
2964
|
+
### REST API {: #3.49.43-rest-api }
|
|
2965
|
+
|
|
2966
|
+
No significant changes.
|
|
2967
|
+
|
|
2968
|
+
### Plugin API {: #3.49.43-plugin-api }
|
|
2969
|
+
|
|
2970
|
+
No significant changes.
|
|
2971
|
+
|
|
2972
|
+
### Pulp File {: #3.49.43-pulp-file }
|
|
2973
|
+
|
|
2974
|
+
No significant changes.
|
|
2975
|
+
|
|
2976
|
+
### Pulp Cert Guard {: #3.49.43-pulp-cert-guard }
|
|
2977
|
+
|
|
2978
|
+
No significant changes.
|
|
2979
|
+
|
|
2980
|
+
---
|
|
2981
|
+
|
|
2816
2982
|
## 3.49.42 (2025-05-21) {: #3.49.42 }
|
|
2817
2983
|
|
|
2818
2984
|
### REST API {: #3.49.42-rest-api }
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: pulpcore
|
|
3
|
-
Version: 3.
|
|
3
|
+
Version: 3.82.1
|
|
4
4
|
Summary: Pulp Django Application and Related Modules
|
|
5
5
|
Author-email: Pulp Team <pulp-list@redhat.com>
|
|
6
6
|
Project-URL: Homepage, https://pulpproject.org
|
|
@@ -23,7 +23,7 @@ Description-Content-Type: text/markdown
|
|
|
23
23
|
License-File: LICENSE
|
|
24
24
|
Requires-Dist: aiodns<3.6,>=3.3.0
|
|
25
25
|
Requires-Dist: aiofiles<=24.1.0,>=22.1
|
|
26
|
-
Requires-Dist: aiohttp<3.13,>=3.8.
|
|
26
|
+
Requires-Dist: aiohttp<3.13,>=3.8.3
|
|
27
27
|
Requires-Dist: asyncio-throttle<=1.0.2,>=1.0
|
|
28
28
|
Requires-Dist: async-timeout<4.0.4,>=4.0.3; python_version < "3.11"
|
|
29
29
|
Requires-Dist: backoff<2.3,>=2.1.2
|
|
@@ -50,7 +50,7 @@ Requires-Dist: opentelemetry-api<1.35,>=1.27.0
|
|
|
50
50
|
Requires-Dist: opentelemetry-sdk<1.35,>=1.27.0
|
|
51
51
|
Requires-Dist: opentelemetry-exporter-otlp-proto-http<1.35,>=1.27.0
|
|
52
52
|
Requires-Dist: protobuf<6.0,>=4.21.1
|
|
53
|
-
Requires-Dist: pulp-glue<0.34,>=0.
|
|
53
|
+
Requires-Dist: pulp-glue<0.34,>=0.28.0
|
|
54
54
|
Requires-Dist: pygtrie<=2.5.0,>=2.5
|
|
55
55
|
Requires-Dist: psycopg[binary]<3.3,>=3.1.8
|
|
56
56
|
Requires-Dist: pyparsing<3.3,>=3.1.0
|
|
@@ -74,7 +74,7 @@ Provides-Extra: prometheus
|
|
|
74
74
|
Requires-Dist: django-prometheus; extra == "prometheus"
|
|
75
75
|
Provides-Extra: kafka
|
|
76
76
|
Requires-Dist: cloudevents==1.11.0; extra == "kafka"
|
|
77
|
-
Requires-Dist: confluent-kafka<2.
|
|
77
|
+
Requires-Dist: confluent-kafka<2.11.0,>=2.4.0; extra == "kafka"
|
|
78
78
|
Provides-Extra: diagnostics
|
|
79
79
|
Requires-Dist: pyinstrument~=5.0; extra == "diagnostics"
|
|
80
80
|
Requires-Dist: memray~=1.17; extra == "diagnostics"
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# Generated by Django 4.2.10 on 2025-06-26 19:44
|
|
2
|
+
|
|
3
|
+
import django.contrib.postgres.fields
|
|
4
|
+
from django.db import migrations, models
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
class Migration(migrations.Migration):
|
|
8
|
+
|
|
9
|
+
dependencies = [
|
|
10
|
+
('core', '0131_distribution_checkpoint_publication_checkpoint'),
|
|
11
|
+
]
|
|
12
|
+
|
|
13
|
+
operations = [
|
|
14
|
+
migrations.AddField(
|
|
15
|
+
model_name='task',
|
|
16
|
+
name='profile_options',
|
|
17
|
+
field=django.contrib.postgres.fields.ArrayField(base_field=models.TextField(), null=True, size=None),
|
|
18
|
+
),
|
|
19
|
+
]
|
|
@@ -90,7 +90,7 @@ class ArtifactFileField(FileField):
|
|
|
90
90
|
|
|
91
91
|
|
|
92
92
|
class EncryptedTextField(TextField):
|
|
93
|
-
"""A field
|
|
93
|
+
"""A field that encrypts text using settings.DB_ENCRYPTION_KEY."""
|
|
94
94
|
|
|
95
95
|
def __init__(self, *args, **kwargs):
|
|
96
96
|
if kwargs.get("primary_key"):
|
|
@@ -114,7 +114,7 @@ class EncryptedTextField(TextField):
|
|
|
114
114
|
|
|
115
115
|
|
|
116
116
|
class EncryptedJSONField(JSONField):
|
|
117
|
-
"""A Field
|
|
117
|
+
"""A Field that encrypts the JSON text using settings.DP_ENCRYPTION_KEY."""
|
|
118
118
|
|
|
119
119
|
def __init__(self, *args, **kwargs):
|
|
120
120
|
if kwargs.get("primary_key"):
|
|
@@ -147,6 +147,7 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
147
147
|
pulp_domain = models.ForeignKey("Domain", default=get_domain_pk, on_delete=models.CASCADE)
|
|
148
148
|
versions = HStoreField(default=dict)
|
|
149
149
|
|
|
150
|
+
profile_options = ArrayField(models.TextField(), null=True)
|
|
150
151
|
profile_artifacts = models.ManyToManyField("Artifact", through=ProfileArtifact)
|
|
151
152
|
|
|
152
153
|
immediate = models.BooleanField(default=False, null=True)
|
|
@@ -90,15 +90,9 @@ class Replicator:
|
|
|
90
90
|
params = {"q": q}
|
|
91
91
|
else:
|
|
92
92
|
params = {}
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
distributions = self.distribution_ctx_cls(self.pulp_ctx).list(list_size, offset, params)
|
|
97
|
-
for distro in distributions:
|
|
98
|
-
yield distro
|
|
99
|
-
if len(distributions) < list_size:
|
|
100
|
-
break
|
|
101
|
-
offset += list_size
|
|
93
|
+
yield from self.distribution_ctx_cls(self.pulp_ctx).list_iterator(
|
|
94
|
+
parameters=params, batch_size=100
|
|
95
|
+
)
|
|
102
96
|
|
|
103
97
|
def labels(self, upstream_object):
|
|
104
98
|
upstream_labels = getattr(upstream_object, "pulp_labels", {})
|
|
@@ -342,6 +342,7 @@ class StorageSettingsSerializer(serializers.Serializer):
|
|
|
342
342
|
STORAGE_MAPPING = {
|
|
343
343
|
"pulpcore.app.models.storage.FileSystem": FileSystemSettingsSerializer,
|
|
344
344
|
"pulpcore.app.models.storage.PulpSFTPStorage": SFTPSettingsSerializer,
|
|
345
|
+
"storages.backends.s3.S3Storage": AmazonS3SettingsSerializer,
|
|
345
346
|
"storages.backends.s3boto3.S3Boto3Storage": AmazonS3SettingsSerializer,
|
|
346
347
|
"storages.backends.azure_storage.AzureStorage": AzureSettingsSerializer,
|
|
347
348
|
"storages.backends.gcloud.GoogleCloudStorage": GoogleSettingsSerializer,
|
|
@@ -78,6 +78,10 @@ class PublicationSerializer(ModelSerializer):
|
|
|
78
78
|
|
|
79
79
|
|
|
80
80
|
class ContentGuardSerializer(ModelSerializer):
|
|
81
|
+
"""
|
|
82
|
+
Base class for content guard serializers.
|
|
83
|
+
"""
|
|
84
|
+
|
|
81
85
|
pulp_href = DetailIdentityField(view_name_pattern=r"contentguards(-.*/.*)-detail")
|
|
82
86
|
|
|
83
87
|
name = serializers.CharField(
|
|
@@ -173,6 +173,7 @@ MIDDLEWARE = [
|
|
|
173
173
|
"django.middleware.clickjacking.XFrameOptionsMiddleware",
|
|
174
174
|
"pulpcore.middleware.DomainMiddleware",
|
|
175
175
|
"pulpcore.middleware.APIRootRewriteMiddleware",
|
|
176
|
+
"pulpcore.middleware.TaskProfilerMiddleware",
|
|
176
177
|
]
|
|
177
178
|
|
|
178
179
|
AUTHENTICATION_BACKENDS = [
|
|
@@ -436,6 +437,7 @@ storage_validator = (
|
|
|
436
437
|
Validator("REDIRECT_TO_OBJECT_STORAGE", eq=False)
|
|
437
438
|
| Validator(*storage_keys, eq="pulpcore.app.models.storage.FileSystem")
|
|
438
439
|
| Validator(*storage_keys, eq="storages.backends.azure_storage.AzureStorage")
|
|
440
|
+
| Validator(*storage_keys, eq="storages.backends.s3.S3Storage")
|
|
439
441
|
| Validator(*storage_keys, eq="storages.backends.s3boto3.S3Boto3Storage")
|
|
440
442
|
| Validator(*storage_keys, eq="storages.backends.gcloud.GoogleCloudStorage")
|
|
441
443
|
)
|
|
@@ -1279,19 +1279,20 @@ class Handler:
|
|
|
1279
1279
|
# "backstop" the prepare() call here, so the write() will be allowed.
|
|
1280
1280
|
if not response.prepared:
|
|
1281
1281
|
await response.prepare(request)
|
|
1282
|
-
if
|
|
1283
|
-
|
|
1284
|
-
|
|
1285
|
-
|
|
1286
|
-
|
|
1287
|
-
|
|
1288
|
-
|
|
1289
|
-
|
|
1290
|
-
|
|
1291
|
-
|
|
1292
|
-
|
|
1293
|
-
|
|
1294
|
-
|
|
1282
|
+
if request.method == "GET":
|
|
1283
|
+
if range_start or range_stop:
|
|
1284
|
+
start_byte_pos = 0
|
|
1285
|
+
end_byte_pos = len(data)
|
|
1286
|
+
if range_start:
|
|
1287
|
+
start_byte_pos = max(0, range_start - data_size_handled)
|
|
1288
|
+
if range_stop:
|
|
1289
|
+
end_byte_pos = min(len(data), range_stop - data_size_handled)
|
|
1290
|
+
|
|
1291
|
+
data_for_client = data[start_byte_pos:end_byte_pos]
|
|
1292
|
+
await response.write(data_for_client)
|
|
1293
|
+
data_size_handled = data_size_handled + len(data)
|
|
1294
|
+
else:
|
|
1295
|
+
await response.write(data)
|
|
1295
1296
|
if remote.policy != Remote.STREAMED:
|
|
1296
1297
|
await original_handle_data(data)
|
|
1297
1298
|
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import time
|
|
2
|
+
from contextvars import ContextVar
|
|
2
3
|
|
|
3
4
|
from django.http.response import Http404
|
|
4
5
|
from django.conf import settings
|
|
@@ -13,6 +14,8 @@ from pulpcore.app.util import (
|
|
|
13
14
|
set_domain,
|
|
14
15
|
)
|
|
15
16
|
|
|
17
|
+
x_task_diagnostics_var = ContextVar("x_profile_task")
|
|
18
|
+
|
|
16
19
|
|
|
17
20
|
class DomainMiddleware:
|
|
18
21
|
"""
|
|
@@ -143,3 +146,25 @@ class DjangoMetricsMiddleware:
|
|
|
143
146
|
match = getattr(request, "resolver_match", "")
|
|
144
147
|
route = getattr(match, "route", "")
|
|
145
148
|
return route
|
|
149
|
+
|
|
150
|
+
|
|
151
|
+
class TaskProfilerMiddleware:
|
|
152
|
+
"""
|
|
153
|
+
Middleware that looks for the presence of X-TASK-DIAGNOSTICS header and provides its value
|
|
154
|
+
as a ContextVar to the dispatch() method in the tasking system. It enables generating
|
|
155
|
+
profiling data of tasks dispatched via API.
|
|
156
|
+
"""
|
|
157
|
+
|
|
158
|
+
def __init__(self, get_response):
|
|
159
|
+
self.get_response = get_response
|
|
160
|
+
|
|
161
|
+
def __call__(self, request):
|
|
162
|
+
if "HTTP_X_TASK_DIAGNOSTICS" in request.META:
|
|
163
|
+
task_diagnostics = request.META["HTTP_X_TASK_DIAGNOSTICS"]
|
|
164
|
+
ctx_token = x_task_diagnostics_var.set(task_diagnostics.split(","))
|
|
165
|
+
try:
|
|
166
|
+
return self.get_response(request)
|
|
167
|
+
finally:
|
|
168
|
+
x_task_diagnostics_var.reset(ctx_token)
|
|
169
|
+
else:
|
|
170
|
+
return self.get_response(request)
|
|
@@ -201,6 +201,19 @@ class PulpAutoSchema(AutoSchema):
|
|
|
201
201
|
name = name + "Response"
|
|
202
202
|
return name
|
|
203
203
|
|
|
204
|
+
def get_override_parameters(self):
|
|
205
|
+
parameters = super().get_override_parameters()
|
|
206
|
+
parameters.append(
|
|
207
|
+
OpenApiParameter(
|
|
208
|
+
name="X-Task-Diagnostics",
|
|
209
|
+
location=OpenApiParameter.HEADER,
|
|
210
|
+
required=False,
|
|
211
|
+
type={"type": "array", "items": {"type": "string"}},
|
|
212
|
+
description="List of profilers to use on tasks.",
|
|
213
|
+
)
|
|
214
|
+
)
|
|
215
|
+
return parameters
|
|
216
|
+
|
|
204
217
|
def map_parsers(self):
|
|
205
218
|
"""
|
|
206
219
|
Get request parsers.
|
|
@@ -127,21 +127,26 @@ def perform_task(task_pk, task_working_dir_rel_path):
|
|
|
127
127
|
set_domain(task.pulp_domain)
|
|
128
128
|
os.chdir(task_working_dir_rel_path)
|
|
129
129
|
|
|
130
|
-
if
|
|
131
|
-
|
|
130
|
+
if task.profile_options:
|
|
131
|
+
profilers = set(task.profile_options) & set(settings.TASK_DIAGNOSTICS)
|
|
132
|
+
if unavailable_profilers := set(task.profile_options) - set(settings.TASK_DIAGNOSTICS):
|
|
133
|
+
_logger.warning(
|
|
134
|
+
"Requested task diagnostic profilers are not available: %s", unavailable_profilers
|
|
135
|
+
)
|
|
136
|
+
_execute_task_and_profile(task, profilers)
|
|
132
137
|
else:
|
|
133
138
|
execute_task(task)
|
|
134
139
|
|
|
135
140
|
|
|
136
|
-
def _execute_task_and_profile(task):
|
|
141
|
+
def _execute_task_and_profile(task, profile_options):
|
|
137
142
|
with tempfile.TemporaryDirectory(dir=settings.WORKING_DIRECTORY) as temp_dir:
|
|
138
143
|
_execute_task = execute_task
|
|
139
144
|
|
|
140
|
-
if
|
|
145
|
+
if "memory" in profile_options:
|
|
141
146
|
_execute_task = _memory_diagnostic_decorator(temp_dir, _execute_task)
|
|
142
|
-
if
|
|
147
|
+
if "pyinstrument" in profile_options:
|
|
143
148
|
_execute_task = _pyinstrument_diagnostic_decorator(temp_dir, _execute_task)
|
|
144
|
-
if
|
|
149
|
+
if "memray" in profile_options:
|
|
145
150
|
_execute_task = _memray_diagnostic_decorator(temp_dir, _execute_task)
|
|
146
151
|
|
|
147
152
|
_execute_task(task)
|
|
@@ -26,6 +26,7 @@ from pulpcore.constants import (
|
|
|
26
26
|
TASK_DISPATCH_LOCK,
|
|
27
27
|
IMMEDIATE_TIMEOUT,
|
|
28
28
|
)
|
|
29
|
+
from pulpcore.middleware import x_task_diagnostics_var
|
|
29
30
|
from pulpcore.tasking.kafka import send_task_notification
|
|
30
31
|
|
|
31
32
|
_logger = logging.getLogger(__name__)
|
|
@@ -246,7 +247,9 @@ def dispatch(
|
|
|
246
247
|
versions=versions,
|
|
247
248
|
immediate=immediate,
|
|
248
249
|
deferred=deferred,
|
|
250
|
+
profile_options=x_task_diagnostics_var.get(None),
|
|
249
251
|
)
|
|
252
|
+
task.refresh_from_db() # The database may have assigned a timestamp for us.
|
|
250
253
|
if newest_created and task.pulp_created <= newest_created:
|
|
251
254
|
# Let this workaround not row forever into the future.
|
|
252
255
|
if newest_created - task.pulp_created > timedelta(seconds=1):
|
|
@@ -33,6 +33,25 @@ def test_retrieving_task_profile_artifacts(gen_user, pulpcore_bindings, task):
|
|
|
33
33
|
assert pulpcore_bindings.TasksApi.profile_artifacts(task.pulp_href).urls is not None
|
|
34
34
|
|
|
35
35
|
|
|
36
|
+
@pytest.mark.parallel
|
|
37
|
+
def test_profiling_task_using_header(gen_user, pulpcore_bindings, monitor_task, pulp_settings):
|
|
38
|
+
# Check that no profile artifacts are created by default
|
|
39
|
+
task_href = pulpcore_bindings.OrphansCleanupApi.cleanup({"orphan_protection_time": 10000}).task
|
|
40
|
+
task = monitor_task(task_href)
|
|
41
|
+
assert pulpcore_bindings.TasksApi.profile_artifacts(task.pulp_href).urls == {}
|
|
42
|
+
|
|
43
|
+
# Check that profile artifacts are created when X-TASK-DIAGNOSTICS headers is passed
|
|
44
|
+
task_href = pulpcore_bindings.OrphansCleanupApi.cleanup(
|
|
45
|
+
{"orphan_protection_time": 10000}, x_task_diagnostics=["memory"]
|
|
46
|
+
).task
|
|
47
|
+
task = monitor_task(task_href)
|
|
48
|
+
profile_artifacts_urls = pulpcore_bindings.TasksApi.profile_artifacts(task.pulp_href).urls
|
|
49
|
+
if "memory" in pulp_settings.TASK_DIAGNOSTICS:
|
|
50
|
+
assert "memory_profile" in profile_artifacts_urls
|
|
51
|
+
else:
|
|
52
|
+
assert "memory_profile" not in profile_artifacts_urls
|
|
53
|
+
|
|
54
|
+
|
|
36
55
|
@pytest.mark.parallel
|
|
37
56
|
def test_multi_resource_locking(dispatch_task, monitor_task):
|
|
38
57
|
task_href1 = dispatch_task(
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
"""Tests related to content delivery."""
|
|
2
2
|
|
|
3
3
|
import hashlib
|
|
4
|
+
import requests
|
|
4
5
|
import subprocess
|
|
5
6
|
import uuid
|
|
7
|
+
from random import sample
|
|
6
8
|
from urllib.parse import urljoin
|
|
7
9
|
|
|
8
10
|
import pytest
|
|
@@ -244,3 +246,35 @@ def test_handling_remote_artifact_on_demand_streaming_failure(
|
|
|
244
246
|
# WHEN/THEN (second request)
|
|
245
247
|
actual_checksum = download_from_distribution(content_name, distribution)
|
|
246
248
|
assert actual_checksum == expected_checksum
|
|
249
|
+
|
|
250
|
+
|
|
251
|
+
@pytest.mark.parallel
|
|
252
|
+
def test_head_request_large_on_demand_file(
|
|
253
|
+
file_repo_with_auto_publish,
|
|
254
|
+
file_remote_factory,
|
|
255
|
+
file_bindings,
|
|
256
|
+
range_header_manifest_path,
|
|
257
|
+
distribution_base_url,
|
|
258
|
+
file_distribution_factory,
|
|
259
|
+
monitor_task,
|
|
260
|
+
):
|
|
261
|
+
"""Test that a HEAD request to a large on-demand file properly saves the file."""
|
|
262
|
+
# range_header_manifest_path has 8 files, each 4MB
|
|
263
|
+
remote = file_remote_factory(manifest_path=range_header_manifest_path, policy="on_demand")
|
|
264
|
+
body = RepositorySyncURL(remote=remote.pulp_href)
|
|
265
|
+
monitor_task(
|
|
266
|
+
file_bindings.RepositoriesFileApi.sync(file_repo_with_auto_publish.pulp_href, body).task
|
|
267
|
+
)
|
|
268
|
+
repo = file_bindings.RepositoriesFileApi.read(file_repo_with_auto_publish.pulp_href)
|
|
269
|
+
content = file_bindings.ContentFilesApi.list(repository_version=repo.latest_version_href)
|
|
270
|
+
content_href_filenames = sample([(c.pulp_href, c.relative_path) for c in content.results], k=3)
|
|
271
|
+
|
|
272
|
+
distro = file_distribution_factory(repository=repo.pulp_href)
|
|
273
|
+
for _, content_filename in content_href_filenames:
|
|
274
|
+
url = urljoin(distribution_base_url(distro.base_url), content_filename)
|
|
275
|
+
response = requests.head(url)
|
|
276
|
+
assert response.status_code == 200
|
|
277
|
+
# Give some time for the file to be saved
|
|
278
|
+
for content_href, _ in content_href_filenames:
|
|
279
|
+
content = file_bindings.ContentFilesApi.read(content_href)
|
|
280
|
+
assert content.artifact is not None
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: pulpcore
|
|
3
|
-
Version: 3.
|
|
3
|
+
Version: 3.82.1
|
|
4
4
|
Summary: Pulp Django Application and Related Modules
|
|
5
5
|
Author-email: Pulp Team <pulp-list@redhat.com>
|
|
6
6
|
Project-URL: Homepage, https://pulpproject.org
|
|
@@ -23,7 +23,7 @@ Description-Content-Type: text/markdown
|
|
|
23
23
|
License-File: LICENSE
|
|
24
24
|
Requires-Dist: aiodns<3.6,>=3.3.0
|
|
25
25
|
Requires-Dist: aiofiles<=24.1.0,>=22.1
|
|
26
|
-
Requires-Dist: aiohttp<3.13,>=3.8.
|
|
26
|
+
Requires-Dist: aiohttp<3.13,>=3.8.3
|
|
27
27
|
Requires-Dist: asyncio-throttle<=1.0.2,>=1.0
|
|
28
28
|
Requires-Dist: async-timeout<4.0.4,>=4.0.3; python_version < "3.11"
|
|
29
29
|
Requires-Dist: backoff<2.3,>=2.1.2
|
|
@@ -50,7 +50,7 @@ Requires-Dist: opentelemetry-api<1.35,>=1.27.0
|
|
|
50
50
|
Requires-Dist: opentelemetry-sdk<1.35,>=1.27.0
|
|
51
51
|
Requires-Dist: opentelemetry-exporter-otlp-proto-http<1.35,>=1.27.0
|
|
52
52
|
Requires-Dist: protobuf<6.0,>=4.21.1
|
|
53
|
-
Requires-Dist: pulp-glue<0.34,>=0.
|
|
53
|
+
Requires-Dist: pulp-glue<0.34,>=0.28.0
|
|
54
54
|
Requires-Dist: pygtrie<=2.5.0,>=2.5
|
|
55
55
|
Requires-Dist: psycopg[binary]<3.3,>=3.1.8
|
|
56
56
|
Requires-Dist: pyparsing<3.3,>=3.1.0
|
|
@@ -74,7 +74,7 @@ Provides-Extra: prometheus
|
|
|
74
74
|
Requires-Dist: django-prometheus; extra == "prometheus"
|
|
75
75
|
Provides-Extra: kafka
|
|
76
76
|
Requires-Dist: cloudevents==1.11.0; extra == "kafka"
|
|
77
|
-
Requires-Dist: confluent-kafka<2.
|
|
77
|
+
Requires-Dist: confluent-kafka<2.11.0,>=2.4.0; extra == "kafka"
|
|
78
78
|
Provides-Extra: diagnostics
|
|
79
79
|
Requires-Dist: pyinstrument~=5.0; extra == "diagnostics"
|
|
80
80
|
Requires-Dist: memray~=1.17; extra == "diagnostics"
|
|
@@ -304,6 +304,7 @@ pulpcore/app/migrations/0129_content_pulp_labels.py
|
|
|
304
304
|
pulpcore/app/migrations/0130_upstreampulp_policy.py
|
|
305
305
|
pulpcore/app/migrations/0131_distribution_checkpoint_publication_checkpoint.py
|
|
306
306
|
pulpcore/app/migrations/0132_alter_content_options.py
|
|
307
|
+
pulpcore/app/migrations/0132_task_profile_options.py
|
|
307
308
|
pulpcore/app/migrations/__init__.py
|
|
308
309
|
pulpcore/app/models/__init__.py
|
|
309
310
|
pulpcore/app/models/access_policy.py
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
aiodns<3.6,>=3.3.0
|
|
2
2
|
aiofiles<=24.1.0,>=22.1
|
|
3
|
-
aiohttp<3.13,>=3.8.
|
|
3
|
+
aiohttp<3.13,>=3.8.3
|
|
4
4
|
asyncio-throttle<=1.0.2,>=1.0
|
|
5
5
|
backoff<2.3,>=2.1.2
|
|
6
6
|
click<8.2,>=8.1.0
|
|
@@ -26,7 +26,7 @@ opentelemetry-api<1.35,>=1.27.0
|
|
|
26
26
|
opentelemetry-sdk<1.35,>=1.27.0
|
|
27
27
|
opentelemetry-exporter-otlp-proto-http<1.35,>=1.27.0
|
|
28
28
|
protobuf<6.0,>=4.21.1
|
|
29
|
-
pulp-glue<0.34,>=0.
|
|
29
|
+
pulp-glue<0.34,>=0.28.0
|
|
30
30
|
pygtrie<=2.5.0,>=2.5
|
|
31
31
|
psycopg[binary]<3.3,>=3.1.8
|
|
32
32
|
pyparsing<3.3,>=3.1.0
|
|
@@ -54,7 +54,7 @@ django-storages[google]==1.14.6
|
|
|
54
54
|
|
|
55
55
|
[kafka]
|
|
56
56
|
cloudevents==1.11.0
|
|
57
|
-
confluent-kafka<2.
|
|
57
|
+
confluent-kafka<2.11.0,>=2.4.0
|
|
58
58
|
|
|
59
59
|
[prometheus]
|
|
60
60
|
django-prometheus
|