pulpcore 3.78.0__tar.gz → 3.79.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.78.0 → pulpcore-3.79.1}/CHANGES.md +91 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/PKG-INFO +4 -4
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/app/__init__.py +1 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/__init__.py +1 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/apps.py +1 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/entrypoint.py +1 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/dump-publications-to-fs.py +1 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/task.py +67 -74
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/openpgp.py +6 -6
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/replica.py +1 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/base.py +1 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/repository.py +3 -3
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tasking/tasks.py +12 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tasking/worker.py +1 -1
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore.egg-info/PKG-INFO +4 -4
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore.egg-info/requires.txt +3 -3
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pyproject.toml +5 -5
- {pulpcore-3.78.0 → pulpcore-3.79.1}/CODE_OF_CONDUCT.md +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/COMMITMENT +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/CONTRIBUTING.md +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/COPYRIGHT +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/LICENSE +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/MANIFEST.in +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/README.md +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/ci_requirements.txt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/functest_requirements.txt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/manage.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/app/migrations/0002_alter_rhsmcertguard_contentguard_ptr_and_more.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/app/migrations/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/app/models.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/app/serializers.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/app/utils.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/app/viewsets.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/pytest_plugin.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/api/test_rhsm_certguard.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/api/test_x509_certguard.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/katello-default-ca.crt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/katello-default-ca.key +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/trusted_but_expired.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/uber.cert +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/untrusted_cert-key.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/untrusted_cert.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/v1/1514454871848760713-key.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/v1/1514454871848760713.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/v1/159442575569388840-key.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/v1/159442575569388840.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/v3/4260035510644027985-key.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/v3/4260035510644027985.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/v3/5527980418107729172-key.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/rhsm/v3/5527980418107729172.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/certificates/ca.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/genca.sh +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/keys/ca.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/ca.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/client.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/server.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/un_urlencoded_cert.txt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/certificates/untrusted_client.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/genall.sh +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/genca.sh +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/genclient.sh +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/gensrv.sh +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/keys/ca.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/keys/client.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/artifacts/x509/keys/server.pem +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/conftest.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/functional/constants.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/unit/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_certguard/tests/unit/test_models.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0001_initial_squashed_0016_add_domain.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0002_file_related_names.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0003_auto_20191014_1721.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0004_filefilesystemexporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0005_filerepository.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0006_delete_filefilesystemexporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0007_filefilesystemexporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0008_add_manifest_field.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0009_move_data_to_new_master_distribution_model.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0010_auto_publish.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0011_fix_auto_publish.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0012_delete_filefilesystemexporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0013_file_acs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0014_new_rbac_permissions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0015_allow_null_manifest.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0016_add_domain.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/0017_alter_filealternatecontentsource_alternatecontentsource_ptr_and_more.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/migrations/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/modelresource.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/models.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/replica.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/serializers.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/tasks/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/tasks/publishing.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/tasks/synchronizing.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/app/viewsets.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/manifest.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/pytest_plugin.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_acs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_auto_publish.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_bad_sync.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_content_labels.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_crud_content_unit.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_crud_remotes.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_domains.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_download_policies.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_generic_list.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_labels.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_mime_types.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_publish.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_pulp_export.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_rbac.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_remote_settings.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/functional/api/test_sync.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/unit/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/unit/test_safe_paths.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulp_file/tests/unit/test_serializers.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/access_policy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/authentication.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/checks.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/files.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/global_access_conditions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/importexport.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/loggers.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/manage.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/add-signing-service.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/analyze-publication.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/clean-up-progress-reports.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/datarepair-2327.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/dump-permissions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/handle-artifact-checksums.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/migrationstat.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/openapi.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/rebasemigrations.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/remove-plugin.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/remove-signing-service.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/repository-size.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/reset-admin-password.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/rotate-db-key.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0001_squashed_0090_char_to_text_field.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0002_increase_artifact_size_field.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0003_remove_upload_completed.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0004_add_duplicated_reserved_resources.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0005_progressreport_code.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0006_repository_plugin_managed.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0007_delete_progress_proxies.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0008_published_metadata_as_content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0009_remove_task_non_fatal_errors.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0010_pulp_fields.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0011_relative_path.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0012_auto_20191104_2000.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0013_repository_pulp_type.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0014_remove_repository_plugin_managed.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0015_auto_20191112_1426.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0016_charfield_to_textfield.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0017_remove_task_parent.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0018_auto_20191127_2350.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0019_add_signing_service_model.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0020_change_publishedartifact_constraints.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0021_add_signing_service_foreign_key.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0022_rename_last_version.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0023_change_exporter_models.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0024_use_local_storage_for_uploads.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0025_task_parent_task.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0026_task_group.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0027_export_backend.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0028_import_importer_pulpimporter_pulpimporterrepository.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0029_export_delete.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0030_taskgroup_all_tasks_dispatched.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0031_import_export_validate_params.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0032_export_to_chunks.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0033_increase_remote_artifact_size_field.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0034_groupprogressreport.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0035_content_upstream_id.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0036_unprotect_last_export.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0037_pulptemporaryfile.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0038_repository_remote.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0039_change_download_concurrency.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0040_set_admin_is_staff.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0041_accesspolicy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0042_rbac_for_tasks.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0043_toc_attribute.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0044_temp_file_artifact_field.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0045_accesspolicy_permissions_allow_null.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0046_task__resource_job_id.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0047_improve_orphan_cleanup.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0048_fips_checksums.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0049_add_file_field_to_uploadchunk.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0050_namespace_access_policies.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0051_timeoutfields.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0052_tasking_logging_cid.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0053_remote_headers.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0054_add_public_key.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0055_label.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0056_remote_rate_limit.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0057_add_label_indexes.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0058_accesspolicy_customized.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0059_proxy_creds.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0060_data_migration_proxy_creds.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0061_call_handle_artifact_checksums_command.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0062_add_new_distribution_mastermodel.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0063_repository_retained_versions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0064_add_new_style_task_columns.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0064_repository_user_hidden.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0065_merge_20210615_1211.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0066_download_concurrency_and_retry_changes.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0067_add_protect_to_task_reservation.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0068_add_timestamp_of_interest.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0069_update_json_fields.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0070_rename_retained_versions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0071_filesystemexport_filesystemexporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0072_add_method_to_filesystem_exporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0073_encrypt_remote_fields.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0074_acs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0075_rbaccontentguard.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0076_remove_reserved_resource.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0077_move_remote_url_credentials.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0078_grouprole_role_userrole.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0079_rename_permissions_assignment_accesspolicy_creation_hooks.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0080_proxy_group_model.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0081_reapplabel_group_permissions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0082_add_manage_roles_permissions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0083_alter_group_options.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0084_alter_rbaccontentguard_options.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0085_contentredirectcontentguard.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0086_task_json_fields.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0087_taskschedule.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0088_accesspolicy_queryset_scoping.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0089_alter_contentredirectcontentguard_options.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0090_char_to_text_field.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0091_systemid.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0092_alter_upload_options.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0093_add_info_field_repositoryversion.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0094_protect_repository_content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0095_artifactdistribution.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0096_alter_task_logging_cid.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0097_remove_telemetry_task_schedule.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0098_pulp_labels.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0099_versions_field.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0100_upstreampulp.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0101_add_domain.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0102_add_domain_relations.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0103_alter_export_task.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0104_delete_label.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0105_abstract_uuid_gen.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0106_alter_artifactdistribution_distribution_ptr_and_more.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0107_distribution_hidden.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0108_task_versions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0109_contentartifact_relative_path_index.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0110_apiappstatus.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0111_task_enc_args_task_enc_kwargs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0112_alter_upstreampulp_options.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0113_headercontentguard.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0114_remove_task_args_remove_task_kwargs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0115_compositecontentguard.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0116_alter_remoteartifact_md5_alter_remoteartifact_sha1_and_more.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0117_task_unblocked_at.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0118_task_core_task_unblock_2276a4_idx_and_more.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0119_grouprole_core_groupr_object__250e22_idx_and_more.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0120_get_url_removal.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0121_add_profile_artifacts_table.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0122_record_last_replication_timestamp.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0123_upstreampulp_q_select.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0124_task_deferred_task_immediate.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0125_openpgpdistribution_openpgpkeyring_openpgppublickey_and_more.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0126_remoteartifact_failed_at.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0127_remove_upstreampulp_pulp_label_select.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0128_domain_pulp_labels.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0129_content_pulp_labels.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0130_upstreampulp_policy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0131_distribution_checkpoint_publication_checkpoint.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/0132_alter_content_options.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/migrations/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/mime_types.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/modelresource.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/access_policy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/acs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/analytics.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/domain.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/exporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/fields.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/generic.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/importer.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/openpgp.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/progress.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/publication.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/replica.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/repository.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/role.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/status.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/storage.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/models/upload.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/protobuf/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/protobuf/analytics_pb2.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/pulp_hashlib.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/pulpcore_gunicorn_application.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/redis_connection.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/response.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/role_util.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/access_policy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/acs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/domain.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/exporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/fields.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/importer.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/openpgp.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/orphans.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/progress.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/publication.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/purge.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/reclaim.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/repair.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/replica.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/repository.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/status.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/task.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/upload.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/serializers/user.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/settings.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/analytics.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/export.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/importer.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/migrate.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/orphan.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/purge.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/reclaim_space.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/replica.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/telemetry.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/test.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/tasks/upload.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/templates/rest_framework/api.html +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/templatetags/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/templatetags/pulp_urls.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/urls.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/util.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/views/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/views/importer.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/views/orphans.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/views/repair.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/views/status.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/access_policy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/acs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/custom_filters.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/domain.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/exporter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/importer.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/openpgp.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/orphans.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/publication.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/reclaim.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/replica.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/repository.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/task.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/upload.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/viewsets/user.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/wsgi.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/backends.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/cache/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/cache/cache.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/constants.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/content/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/content/authentication.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/content/entrypoint.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/content/handler.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/content/instrumentation.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/download/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/download/base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/download/factory.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/download/file.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/download/http.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/exceptions/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/exceptions/base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/exceptions/plugin.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/exceptions/validation.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/filters.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/metrics.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/middleware.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/migrations.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/openapi/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/openapi/hooks.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/access_policy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/actions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/apps.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/authentication/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/cache/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/constants.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/download/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/exceptions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/files.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/importexport.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/migrations.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/modelresources.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/models/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/models/role.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/publication_utils.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/pulp_hashlib.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/replica.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/repo_version_utils.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/responses.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/serializers/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/serializers/content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/stages/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/stages/api.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/stages/artifact_stages.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/stages/content_stages.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/stages/declarative_version.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/stages/models.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/storage.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/sync.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/tasking.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/util.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/viewsets/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/plugin/viewsets/content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/pytest_plugin.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/responses.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tasking/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tasking/_util.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tasking/entrypoint.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tasking/kafka.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tasking/storage.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_access_policy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_api_docs.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_api_root_rewrite.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_artifact_distribution.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_auth.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_correlation_id.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_crd_artifacts.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_crud_domains.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_filter.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_login.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_openapi_schema.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_openpgp.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_replication.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_repos.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_role.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_root_endpoint.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_scoping.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_signing_service.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_status.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_task_purge.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_tasking.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_upload.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_users_groups.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/test_workers.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_checkpoint.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_content_access.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_content_cache.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_content_delivery.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_content_directory.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_content_path.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_content_promotion.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_contentguard.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_crud_repos.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_distributions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_filesystemexport.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_labels.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_migrate.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_orphans.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_pagination.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_prn.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_proxy.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_pulpimport.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_reclaim_disk_space.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_repair.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_repo_versions.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_tasks.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/api/using_plugin/test_unlinking_repo.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/assets/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/content_with_coverage.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/functional/utils.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/performance/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/performance/test_performance.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/conftest.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/content/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/content/test_handler.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/content/test_heartbeat.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/download/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/download/test_downloader_base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/download/test_downloader_factory.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/metrics/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/metrics/conftest.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/metrics/test_aiohttp_instrumentation.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/metrics/test_django_instrumentation.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/migration/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/migration/test_0077_move_remote_url_credentials.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/models/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/models/test_base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/models/test_content.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/models/test_remote.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/models/test_repository.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/models/test_task.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/roles/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/roles/test_roles.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/serializers/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/serializers/test_base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/serializers/test_domain.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/serializers/test_fields.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/serializers/test_orphans_cleanup.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/serializers/test_pulpexport.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/serializers/test_repository.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/serializers/test_user.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/stages/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/stages/test_artifactdownloader.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/stages/test_stages.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_cache.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_chunked_file.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_content_guard.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_files.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_import_checks.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_pulp_urls.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_settings.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_util.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/test_viewsets.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/viewsets/__init__.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/tests/unit/viewsets/test_viewset_base.py +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore.egg-info/SOURCES.txt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore.egg-info/dependency_links.txt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore.egg-info/entry_points.txt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore.egg-info/top_level.txt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/setup.cfg +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/test_requirements.txt +0 -0
- {pulpcore-3.78.0 → pulpcore-3.79.1}/unittest_requirements.txt +0 -0
|
@@ -8,6 +8,49 @@
|
|
|
8
8
|
|
|
9
9
|
[//]: # (towncrier release notes start)
|
|
10
10
|
|
|
11
|
+
## 3.79.1 (2025-05-27) {: #3.79.1 }
|
|
12
|
+
|
|
13
|
+
### REST API {: #3.79.1-rest-api }
|
|
14
|
+
|
|
15
|
+
No significant changes.
|
|
16
|
+
|
|
17
|
+
### Plugin API {: #3.79.1-plugin-api }
|
|
18
|
+
|
|
19
|
+
No significant changes.
|
|
20
|
+
|
|
21
|
+
### Pulp File {: #3.79.1-pulp-file }
|
|
22
|
+
|
|
23
|
+
No significant changes.
|
|
24
|
+
|
|
25
|
+
### Pulp Cert Guard {: #3.79.1-pulp-cert-guard }
|
|
26
|
+
|
|
27
|
+
No significant changes.
|
|
28
|
+
|
|
29
|
+
---
|
|
30
|
+
|
|
31
|
+
## 3.79.0 (2025-05-20) {: #3.79.0 }
|
|
32
|
+
|
|
33
|
+
### REST API {: #3.79.0-rest-api }
|
|
34
|
+
|
|
35
|
+
#### Features {: #3.79.0-rest-api-feature }
|
|
36
|
+
|
|
37
|
+
- Added the `execution_time` as microseconds and other task related information on the finished task log entry.
|
|
38
|
+
[#6569](https://github.com/pulp/pulpcore/issues/6569)
|
|
39
|
+
|
|
40
|
+
### Plugin API {: #3.79.0-plugin-api }
|
|
41
|
+
|
|
42
|
+
No significant changes.
|
|
43
|
+
|
|
44
|
+
### Pulp File {: #3.79.0-pulp-file }
|
|
45
|
+
|
|
46
|
+
No significant changes.
|
|
47
|
+
|
|
48
|
+
### Pulp Cert Guard {: #3.79.0-pulp-cert-guard }
|
|
49
|
+
|
|
50
|
+
No significant changes.
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
11
54
|
## 3.78.0 (2025-05-13) {: #3.78.0 }
|
|
12
55
|
|
|
13
56
|
### REST API {: #3.78.0-rest-api }
|
|
@@ -1320,6 +1363,30 @@ No significant changes.
|
|
|
1320
1363
|
|
|
1321
1364
|
---
|
|
1322
1365
|
|
|
1366
|
+
## 3.63.18 (2025-05-13) {: #3.63.18 }
|
|
1367
|
+
|
|
1368
|
+
### REST API {: #3.63.18-rest-api }
|
|
1369
|
+
|
|
1370
|
+
#### Bugfixes {: #3.63.18-rest-api-bugfix }
|
|
1371
|
+
|
|
1372
|
+
- Disable retry logic on the context of content-app on-demand streaming, as we can't recover
|
|
1373
|
+
from any errors after starting the streaming process (chunked transfer).
|
|
1374
|
+
[#5937](https://github.com/pulp/pulpcore/issues/5937)
|
|
1375
|
+
|
|
1376
|
+
### Plugin API {: #3.63.18-plugin-api }
|
|
1377
|
+
|
|
1378
|
+
No significant changes.
|
|
1379
|
+
|
|
1380
|
+
### Pulp File {: #3.63.18-pulp-file }
|
|
1381
|
+
|
|
1382
|
+
No significant changes.
|
|
1383
|
+
|
|
1384
|
+
### Pulp Cert Guard {: #3.63.18-pulp-cert-guard }
|
|
1385
|
+
|
|
1386
|
+
No significant changes.
|
|
1387
|
+
|
|
1388
|
+
---
|
|
1389
|
+
|
|
1323
1390
|
## 3.63.17 (2025-04-24) {: #3.63.17 }
|
|
1324
1391
|
|
|
1325
1392
|
### REST API {: #3.63.17-rest-api }
|
|
@@ -2560,6 +2627,30 @@ No significant changes.
|
|
|
2560
2627
|
|
|
2561
2628
|
---
|
|
2562
2629
|
|
|
2630
|
+
## 3.49.41 (2025-05-13) {: #3.49.41 }
|
|
2631
|
+
|
|
2632
|
+
### REST API {: #3.49.41-rest-api }
|
|
2633
|
+
|
|
2634
|
+
#### Bugfixes {: #3.49.41-rest-api-bugfix }
|
|
2635
|
+
|
|
2636
|
+
- Disable retry logic on the context of content-app on-demand streaming, as we can't recover
|
|
2637
|
+
from any errors after starting the streaming process (chunked transfer).
|
|
2638
|
+
[#5937](https://github.com/pulp/pulpcore/issues/5937)
|
|
2639
|
+
|
|
2640
|
+
### Plugin API {: #3.49.41-plugin-api }
|
|
2641
|
+
|
|
2642
|
+
No significant changes.
|
|
2643
|
+
|
|
2644
|
+
### Pulp File {: #3.49.41-pulp-file }
|
|
2645
|
+
|
|
2646
|
+
No significant changes.
|
|
2647
|
+
|
|
2648
|
+
### Pulp Cert Guard {: #3.49.41-pulp-cert-guard }
|
|
2649
|
+
|
|
2650
|
+
No significant changes.
|
|
2651
|
+
|
|
2652
|
+
---
|
|
2653
|
+
|
|
2563
2654
|
## 3.49.40 (2025-05-06) {: #3.49.40 }
|
|
2564
2655
|
|
|
2565
2656
|
### REST API {: #3.49.40-rest-api }
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: pulpcore
|
|
3
|
-
Version: 3.
|
|
3
|
+
Version: 3.79.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
|
|
@@ -28,7 +28,7 @@ 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.2.2,>=2.1.2
|
|
30
30
|
Requires-Dist: click<=8.1.8,>=8.1.0
|
|
31
|
-
Requires-Dist: cryptography<
|
|
31
|
+
Requires-Dist: cryptography<45.0.3,>=38.0.1
|
|
32
32
|
Requires-Dist: Django~=4.2.0
|
|
33
33
|
Requires-Dist: django-filter<=25.1,>=23.1
|
|
34
34
|
Requires-Dist: django-guid<=3.5.1,>=3.3
|
|
@@ -37,7 +37,7 @@ Requires-Dist: django-lifecycle<=1.2.4,>=1.0
|
|
|
37
37
|
Requires-Dist: djangorestframework<=3.16.0,>=3.14.0
|
|
38
38
|
Requires-Dist: djangorestframework-queryfields<=1.1.0,>=1.0
|
|
39
39
|
Requires-Dist: drf-access-policy<1.5.1,>=1.1.2
|
|
40
|
-
Requires-Dist: drf-nested-routers<=0.94.
|
|
40
|
+
Requires-Dist: drf-nested-routers<=0.94.2,>=0.93.4
|
|
41
41
|
Requires-Dist: drf-spectacular==0.27.2
|
|
42
42
|
Requires-Dist: dynaconf<3.3.0,>=3.2.5
|
|
43
43
|
Requires-Dist: gunicorn<23.1.0,>=20.1
|
|
@@ -52,7 +52,7 @@ Requires-Dist: opentelemetry-exporter-otlp-proto-http<1.34,>=1.27.0
|
|
|
52
52
|
Requires-Dist: protobuf<6.0,>=4.21.1
|
|
53
53
|
Requires-Dist: pulp-glue<0.33,>=0.18.0
|
|
54
54
|
Requires-Dist: pygtrie<=2.5.0,>=2.5
|
|
55
|
-
Requires-Dist: psycopg[binary]
|
|
55
|
+
Requires-Dist: psycopg[binary]<3.3,>=3.1.8
|
|
56
56
|
Requires-Dist: pyparsing<=3.2.3,>=3.1.0
|
|
57
57
|
Requires-Dist: python-gnupg<=0.5.4,>=0.5
|
|
58
58
|
Requires-Dist: PyYAML<=6.0.2,>=5.1.1
|
|
@@ -48,7 +48,7 @@ class PulpApiWorker(SyncWorker):
|
|
|
48
48
|
from pulpcore.app.models import ApiAppStatus
|
|
49
49
|
|
|
50
50
|
if settings.API_APP_TTL < 2 * self.timeout:
|
|
51
|
-
logger.
|
|
51
|
+
logger.warning(
|
|
52
52
|
"API_APP_TTL (%s) is smaller than double the gunicorn timeout (%s). "
|
|
53
53
|
"You may experience workers wrongly reporting as missing",
|
|
54
54
|
settings.API_APP_TTL,
|
{pulpcore-3.78.0 → pulpcore-3.79.1}/pulpcore/app/management/commands/dump-publications-to-fs.py
RENAMED
|
@@ -109,7 +109,7 @@ class Command(BaseCommand):
|
|
|
109
109
|
repo_path = os.path.join(options["dest"], distribution.base_path)
|
|
110
110
|
to_export.append((repo_path, publication))
|
|
111
111
|
except ObjectDoesNotExist:
|
|
112
|
-
logging.
|
|
112
|
+
logging.warning(
|
|
113
113
|
"No publication found for the repo published at '{}': skipping".format(
|
|
114
114
|
distribution.base_path
|
|
115
115
|
)
|
|
@@ -4,7 +4,6 @@ Django models related to the Tasking system
|
|
|
4
4
|
|
|
5
5
|
import logging
|
|
6
6
|
import traceback
|
|
7
|
-
from contextlib import suppress
|
|
8
7
|
from datetime import timedelta
|
|
9
8
|
from gettext import gettext as _
|
|
10
9
|
|
|
@@ -76,6 +75,21 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
76
75
|
"""
|
|
77
76
|
Represents a task
|
|
78
77
|
|
|
78
|
+
The Tasks state machine works like a finite automaton without loops:
|
|
79
|
+
The initial state is WAITING.
|
|
80
|
+
Final states are COMPLETED, FAILED and CANCELED.
|
|
81
|
+
The possible transitions are:
|
|
82
|
+
WAITING -> RUNNING
|
|
83
|
+
WAITING ->* CANCELING
|
|
84
|
+
RUNNING -> COMPLETED
|
|
85
|
+
RUNNING -> FAILED
|
|
86
|
+
RUNNING ->* CANCELING
|
|
87
|
+
CANCELING -> CANCELED
|
|
88
|
+
|
|
89
|
+
The transitions to CANCELING (marked with *) are the only ones allowed to happen without
|
|
90
|
+
holding the tasks advisory lock. Canceling is meant to be initiated asyncronously by a sparate
|
|
91
|
+
process before signalling the worker via Postgres LISTEN.
|
|
92
|
+
|
|
79
93
|
Fields:
|
|
80
94
|
|
|
81
95
|
state (models.TextField): The state of the task
|
|
@@ -180,34 +194,32 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
180
194
|
"""Set the "core.task_user_dispatcher" role for the current user after creation."""
|
|
181
195
|
self.add_roles_for_object_creator("core.task_user_dispatcher")
|
|
182
196
|
|
|
197
|
+
def _cleanup_progress_reports(self, state):
|
|
198
|
+
"""Find any running progress-reports and set their states to the specified end-state."""
|
|
199
|
+
self.progress_reports.filter(state=TASK_STATES.RUNNING).update(state=state)
|
|
200
|
+
|
|
183
201
|
def set_running(self):
|
|
184
202
|
"""
|
|
185
203
|
Set this Task to the running state, save it, and log output in warning cases.
|
|
186
204
|
|
|
187
205
|
This updates the :attr:`started_at` and sets the :attr:`state` to :attr:`RUNNING`.
|
|
188
206
|
"""
|
|
207
|
+
started_at = timezone.now()
|
|
189
208
|
rows = Task.objects.filter(pk=self.pk, state=TASK_STATES.WAITING).update(
|
|
190
|
-
state=TASK_STATES.RUNNING,
|
|
209
|
+
state=TASK_STATES.RUNNING,
|
|
210
|
+
started_at=started_at,
|
|
191
211
|
)
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
del self.finished_at
|
|
198
|
-
with suppress(AttributeError):
|
|
199
|
-
del self.error
|
|
200
|
-
if rows != 1:
|
|
212
|
+
if rows == 1:
|
|
213
|
+
self.state = TASK_STATES.RUNNING
|
|
214
|
+
self.started_at = started_at
|
|
215
|
+
else:
|
|
216
|
+
self.refresh_from_db()
|
|
201
217
|
raise RuntimeError(
|
|
202
218
|
_("Attempt to set not waiting task {} to running from '{}'.").format(
|
|
203
219
|
self.pk, self.state
|
|
204
220
|
)
|
|
205
221
|
)
|
|
206
222
|
|
|
207
|
-
def _cleanup_progress_reports(self, state):
|
|
208
|
-
"""Find any running progress-reports and set their states to the specified end-state."""
|
|
209
|
-
self.progress_reports.filter(state=TASK_STATES.RUNNING).update(state=state)
|
|
210
|
-
|
|
211
223
|
def set_completed(self):
|
|
212
224
|
"""
|
|
213
225
|
Set this Task to the completed state, save it, and log output in warning cases.
|
|
@@ -216,18 +228,16 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
216
228
|
"""
|
|
217
229
|
# Only set the state to finished if it's running. This is important for when the task has
|
|
218
230
|
# been canceled, so we don't move the task from canceled to finished.
|
|
231
|
+
finished_at = timezone.now()
|
|
219
232
|
rows = Task.objects.filter(pk=self.pk, state=TASK_STATES.RUNNING).update(
|
|
220
|
-
state=TASK_STATES.COMPLETED,
|
|
233
|
+
state=TASK_STATES.COMPLETED,
|
|
234
|
+
finished_at=finished_at,
|
|
221
235
|
)
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
del self.finished_at
|
|
228
|
-
with suppress(AttributeError):
|
|
229
|
-
del self.error
|
|
230
|
-
if rows != 1:
|
|
236
|
+
if rows == 1:
|
|
237
|
+
self.state = TASK_STATES.COMPLETED
|
|
238
|
+
self.finished_at = finished_at
|
|
239
|
+
else:
|
|
240
|
+
self.refresh_from_db()
|
|
231
241
|
# If the user requested to cancel this task while the worker finished it, we leave it
|
|
232
242
|
# as it is, but accept this is not an error condition.
|
|
233
243
|
if self.state != TASK_STATES.CANCELING:
|
|
@@ -249,21 +259,20 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
249
259
|
exc (Exception): The exception raised by the task.
|
|
250
260
|
tb (traceback): Traceback instance for the current exception.
|
|
251
261
|
"""
|
|
262
|
+
finished_at = timezone.now()
|
|
252
263
|
tb_str = "".join(traceback.format_tb(tb))
|
|
264
|
+
error = exception_to_dict(exc, tb_str)
|
|
253
265
|
rows = Task.objects.filter(pk=self.pk, state=TASK_STATES.RUNNING).update(
|
|
254
266
|
state=TASK_STATES.FAILED,
|
|
255
|
-
finished_at=
|
|
256
|
-
error=
|
|
267
|
+
finished_at=finished_at,
|
|
268
|
+
error=error,
|
|
257
269
|
)
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
with suppress(AttributeError):
|
|
265
|
-
del self.error
|
|
266
|
-
if rows != 1:
|
|
270
|
+
if rows == 1:
|
|
271
|
+
self.state = TASK_STATES.FAILED
|
|
272
|
+
self.finished_at = finished_at
|
|
273
|
+
self.error = error
|
|
274
|
+
else:
|
|
275
|
+
self.refresh_from_db()
|
|
267
276
|
raise RuntimeError(
|
|
268
277
|
_("Attempt to set not running task {} to failed from '{}'.").format(
|
|
269
278
|
self.pk, self.state
|
|
@@ -280,15 +289,10 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
280
289
|
rows = Task.objects.filter(pk=self.pk, state__in=TASK_INCOMPLETE_STATES).update(
|
|
281
290
|
state=TASK_STATES.CANCELING,
|
|
282
291
|
)
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
with suppress(AttributeError):
|
|
288
|
-
del self.finished_at
|
|
289
|
-
with suppress(AttributeError):
|
|
290
|
-
del self.error
|
|
291
|
-
if rows != 1:
|
|
292
|
+
if rows == 1:
|
|
293
|
+
self.state = TASK_STATES.CANCELING
|
|
294
|
+
else:
|
|
295
|
+
self.refresh_from_db()
|
|
292
296
|
raise RuntimeError(
|
|
293
297
|
_("Attempt to set not incomplete task {} to canceling from '{}'.").format(
|
|
294
298
|
self.pk, self.state
|
|
@@ -301,23 +305,22 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
301
305
|
"""
|
|
302
306
|
# Make sure this function was called with a proper final state
|
|
303
307
|
assert final_state in [TASK_STATES.CANCELED, TASK_STATES.FAILED]
|
|
308
|
+
finished_at = timezone.now()
|
|
304
309
|
task_data = {}
|
|
305
310
|
if reason:
|
|
306
311
|
task_data["error"] = {"reason": reason}
|
|
307
312
|
rows = Task.objects.filter(pk=self.pk, state=TASK_STATES.CANCELING).update(
|
|
308
313
|
state=final_state,
|
|
309
|
-
finished_at=
|
|
314
|
+
finished_at=finished_at,
|
|
310
315
|
**task_data,
|
|
311
316
|
)
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
del self.error
|
|
320
|
-
if rows != 1:
|
|
317
|
+
if rows == 1:
|
|
318
|
+
self.state = final_state
|
|
319
|
+
self.finished_at = finished_at
|
|
320
|
+
if reason:
|
|
321
|
+
self.error = task_data["error"]
|
|
322
|
+
else:
|
|
323
|
+
self.refresh_from_db()
|
|
321
324
|
raise RuntimeError(
|
|
322
325
|
_("Attempt to set not canceling task {} to canceled from '{}'.").format(
|
|
323
326
|
self.pk, self.state
|
|
@@ -327,25 +330,15 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
327
330
|
|
|
328
331
|
def unblock(self):
|
|
329
332
|
# This should be safe to be called without holding the lock.
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
if fields is not None:
|
|
340
|
-
fields = set(fields)
|
|
341
|
-
deferred_fields = {
|
|
342
|
-
field for field in self.get_deferred_fields() if not field.startswith("enc_")
|
|
343
|
-
}
|
|
344
|
-
# If any state related deferred field is going to be loaded
|
|
345
|
-
if fields.intersection(deferred_fields):
|
|
346
|
-
# then load all of them
|
|
347
|
-
fields = fields.union(deferred_fields)
|
|
348
|
-
super().refresh_from_db(using, fields, **kwargs)
|
|
333
|
+
unblocked_at = timezone.now()
|
|
334
|
+
rows = Task.objects.filter(pk=self.pk).update(unblocked_at=unblocked_at)
|
|
335
|
+
if rows == 1:
|
|
336
|
+
self.unblocked_at = unblocked_at
|
|
337
|
+
else:
|
|
338
|
+
self.refresh_from_db()
|
|
339
|
+
raise RuntimeError(
|
|
340
|
+
_("Falied to set task {} unblocked in state '{}'.").format(self.pk, self.state)
|
|
341
|
+
)
|
|
349
342
|
|
|
350
343
|
class Meta:
|
|
351
344
|
indexes = [
|
|
@@ -289,15 +289,15 @@ def analyze_signature(data, pubkey, signed_packet_type, signed_packet):
|
|
|
289
289
|
if version == 4:
|
|
290
290
|
hash_payload = b"\x99" + len(signed_packet).to_bytes(2, "big") + signed_packet
|
|
291
291
|
else: # version == 5
|
|
292
|
-
hash_payload = b"\
|
|
292
|
+
hash_payload = b"\x9a" + len(signed_packet).to_bytes(4, "big") + signed_packet
|
|
293
293
|
elif signature_type in [0x10, 0x11, 0x12, 0x13, 0x16, 0x30]:
|
|
294
294
|
# 0x10 - 0x13 Certification of a user id or attribute
|
|
295
295
|
# 0x16 Attested Key Signature
|
|
296
296
|
# 0x30 Certification Revocation Signature
|
|
297
297
|
if signed_packet_type == 13:
|
|
298
|
-
hash_payload = b"\
|
|
298
|
+
hash_payload = b"\xb4" + len(signed_packet).to_bytes(4, "big") + signed_packet
|
|
299
299
|
elif signed_packet_type == 17:
|
|
300
|
-
hash_payload = b"\
|
|
300
|
+
hash_payload = b"\xd1" + len(signed_packet).to_bytes(4, "big") + signed_packet
|
|
301
301
|
else:
|
|
302
302
|
raise ValueError("Out of band user ID or attribute signature.")
|
|
303
303
|
elif signature_type in [0x1F, 0x20, 0x30]:
|
|
@@ -318,18 +318,18 @@ def analyze_signature(data, pubkey, signed_packet_type, signed_packet):
|
|
|
318
318
|
if version == 4:
|
|
319
319
|
h.update(b"\x99" + len(pubkey).to_bytes(2, "big") + pubkey)
|
|
320
320
|
else: # version == 5
|
|
321
|
-
h.update(b"\
|
|
321
|
+
h.update(b"\x9a" + len(pubkey).to_bytes(4, "big") + pubkey)
|
|
322
322
|
h.update(hash_payload)
|
|
323
323
|
if version == 4:
|
|
324
324
|
h.update(
|
|
325
325
|
data[: 6 + hashed_size]
|
|
326
|
-
+ b"\x04\
|
|
326
|
+
+ b"\x04\xff"
|
|
327
327
|
+ ((6 + hashed_size) % (1 << 32)).to_bytes(4, "big")
|
|
328
328
|
)
|
|
329
329
|
else: # version == 5
|
|
330
330
|
h.update(
|
|
331
331
|
data[: 6 + hashed_size]
|
|
332
|
-
+ b"\x05\
|
|
332
|
+
+ b"\x05\xff"
|
|
333
333
|
+ ((6 + hashed_size) % (1 << 64)).to_bytes(8, "big")
|
|
334
334
|
)
|
|
335
335
|
if not h.digest().startswith(canary):
|
|
@@ -112,7 +112,7 @@ class _DetailFieldMixin(HrefPrnFieldMixin):
|
|
|
112
112
|
if view_name_pattern:
|
|
113
113
|
view_name = _MatchingRegexViewName(view_name_pattern)
|
|
114
114
|
else:
|
|
115
|
-
log.
|
|
115
|
+
log.warning(
|
|
116
116
|
_(
|
|
117
117
|
"Please provide either 'view_name' or 'view_name_pattern' for {} on {}."
|
|
118
118
|
).format(self.__class__.__name__, traceback.extract_stack()[-4][2])
|
|
@@ -79,7 +79,7 @@ async def _repair_ca(content_artifact, repaired=None):
|
|
|
79
79
|
try:
|
|
80
80
|
dl_result = await downloader.run()
|
|
81
81
|
except Exception as e:
|
|
82
|
-
log.
|
|
82
|
+
log.warning(_("Redownload failed from '{}': {}.").format(remote_artifact.url, str(e)))
|
|
83
83
|
else:
|
|
84
84
|
if dl_result.artifact_attributes["sha256"] == content_artifact.artifact.sha256:
|
|
85
85
|
with open(dl_result.path, "rb") as src:
|
|
@@ -138,7 +138,7 @@ async def _repair_artifacts_for_content(subset=None, verify_checksums=True):
|
|
|
138
138
|
valid = await loop.run_in_executor(None, storage.exists, artifact.file.name)
|
|
139
139
|
if not valid:
|
|
140
140
|
await missing.aincrement()
|
|
141
|
-
log.
|
|
141
|
+
log.warning(_("Missing file for {}").format(artifact))
|
|
142
142
|
elif verify_checksums:
|
|
143
143
|
# default ThreadPoolExecutor uses num cores x 5 threads. Since we're doing
|
|
144
144
|
# such long and sequential reads, using too many threads might hurt more
|
|
@@ -151,7 +151,7 @@ async def _repair_artifacts_for_content(subset=None, verify_checksums=True):
|
|
|
151
151
|
)
|
|
152
152
|
if not valid:
|
|
153
153
|
await corrupted.aincrement()
|
|
154
|
-
log.
|
|
154
|
+
log.warning(_("Digest mismatch for {}").format(artifact))
|
|
155
155
|
|
|
156
156
|
if not valid:
|
|
157
157
|
if len(pending) >= 5: # Limit the number of concurrent repair tasks
|
|
@@ -127,7 +127,18 @@ def _execute_task(task):
|
|
|
127
127
|
send_task_notification(task)
|
|
128
128
|
else:
|
|
129
129
|
task.set_completed()
|
|
130
|
-
|
|
130
|
+
execution_time = task.finished_at - task.started_at
|
|
131
|
+
execution_time_us = int(execution_time.total_seconds() * 1_000_000) # μs
|
|
132
|
+
_logger.info(
|
|
133
|
+
"Task completed %s in domain:"
|
|
134
|
+
" %s, task_type: %s, immediate: %s, deferred: %s, execution_time: %s μs",
|
|
135
|
+
task.pk,
|
|
136
|
+
domain.name,
|
|
137
|
+
task.name,
|
|
138
|
+
str(task.immediate),
|
|
139
|
+
str(task.deferred),
|
|
140
|
+
execution_time_us,
|
|
141
|
+
)
|
|
131
142
|
send_task_notification(task)
|
|
132
143
|
|
|
133
144
|
|
|
@@ -309,7 +309,7 @@ class PulpcoreWorker:
|
|
|
309
309
|
# But during at least one specific upgrade this situation can emerge.
|
|
310
310
|
# In this case, we can assume that the old algorithm was employed to identify the
|
|
311
311
|
# task as unblocked, and we just rectify the situation here.
|
|
312
|
-
_logger.
|
|
312
|
+
_logger.warning(
|
|
313
313
|
"Running task %s was not previously marked unblocked. Fixing.", task.pk
|
|
314
314
|
)
|
|
315
315
|
task.unblock()
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: pulpcore
|
|
3
|
-
Version: 3.
|
|
3
|
+
Version: 3.79.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
|
|
@@ -28,7 +28,7 @@ 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.2.2,>=2.1.2
|
|
30
30
|
Requires-Dist: click<=8.1.8,>=8.1.0
|
|
31
|
-
Requires-Dist: cryptography<
|
|
31
|
+
Requires-Dist: cryptography<45.0.3,>=38.0.1
|
|
32
32
|
Requires-Dist: Django~=4.2.0
|
|
33
33
|
Requires-Dist: django-filter<=25.1,>=23.1
|
|
34
34
|
Requires-Dist: django-guid<=3.5.1,>=3.3
|
|
@@ -37,7 +37,7 @@ Requires-Dist: django-lifecycle<=1.2.4,>=1.0
|
|
|
37
37
|
Requires-Dist: djangorestframework<=3.16.0,>=3.14.0
|
|
38
38
|
Requires-Dist: djangorestframework-queryfields<=1.1.0,>=1.0
|
|
39
39
|
Requires-Dist: drf-access-policy<1.5.1,>=1.1.2
|
|
40
|
-
Requires-Dist: drf-nested-routers<=0.94.
|
|
40
|
+
Requires-Dist: drf-nested-routers<=0.94.2,>=0.93.4
|
|
41
41
|
Requires-Dist: drf-spectacular==0.27.2
|
|
42
42
|
Requires-Dist: dynaconf<3.3.0,>=3.2.5
|
|
43
43
|
Requires-Dist: gunicorn<23.1.0,>=20.1
|
|
@@ -52,7 +52,7 @@ Requires-Dist: opentelemetry-exporter-otlp-proto-http<1.34,>=1.27.0
|
|
|
52
52
|
Requires-Dist: protobuf<6.0,>=4.21.1
|
|
53
53
|
Requires-Dist: pulp-glue<0.33,>=0.18.0
|
|
54
54
|
Requires-Dist: pygtrie<=2.5.0,>=2.5
|
|
55
|
-
Requires-Dist: psycopg[binary]
|
|
55
|
+
Requires-Dist: psycopg[binary]<3.3,>=3.1.8
|
|
56
56
|
Requires-Dist: pyparsing<=3.2.3,>=3.1.0
|
|
57
57
|
Requires-Dist: python-gnupg<=0.5.4,>=0.5
|
|
58
58
|
Requires-Dist: PyYAML<=6.0.2,>=5.1.1
|
|
@@ -4,7 +4,7 @@ aiohttp<3.12,>=3.8.1
|
|
|
4
4
|
asyncio-throttle<=1.0.2,>=1.0
|
|
5
5
|
backoff<2.2.2,>=2.1.2
|
|
6
6
|
click<=8.1.8,>=8.1.0
|
|
7
|
-
cryptography<
|
|
7
|
+
cryptography<45.0.3,>=38.0.1
|
|
8
8
|
Django~=4.2.0
|
|
9
9
|
django-filter<=25.1,>=23.1
|
|
10
10
|
django-guid<=3.5.1,>=3.3
|
|
@@ -13,7 +13,7 @@ django-lifecycle<=1.2.4,>=1.0
|
|
|
13
13
|
djangorestframework<=3.16.0,>=3.14.0
|
|
14
14
|
djangorestframework-queryfields<=1.1.0,>=1.0
|
|
15
15
|
drf-access-policy<1.5.1,>=1.1.2
|
|
16
|
-
drf-nested-routers<=0.94.
|
|
16
|
+
drf-nested-routers<=0.94.2,>=0.93.4
|
|
17
17
|
drf-spectacular==0.27.2
|
|
18
18
|
dynaconf<3.3.0,>=3.2.5
|
|
19
19
|
gunicorn<23.1.0,>=20.1
|
|
@@ -28,7 +28,7 @@ opentelemetry-exporter-otlp-proto-http<1.34,>=1.27.0
|
|
|
28
28
|
protobuf<6.0,>=4.21.1
|
|
29
29
|
pulp-glue<0.33,>=0.18.0
|
|
30
30
|
pygtrie<=2.5.0,>=2.5
|
|
31
|
-
psycopg[binary]
|
|
31
|
+
psycopg[binary]<3.3,>=3.1.8
|
|
32
32
|
pyparsing<=3.2.3,>=3.1.0
|
|
33
33
|
python-gnupg<=0.5.4,>=0.5
|
|
34
34
|
PyYAML<=6.0.2,>=5.1.1
|
|
@@ -7,7 +7,7 @@ build-backend = 'setuptools.build_meta'
|
|
|
7
7
|
|
|
8
8
|
[project]
|
|
9
9
|
name = "pulpcore"
|
|
10
|
-
version = "3.
|
|
10
|
+
version = "3.79.1"
|
|
11
11
|
description = "Pulp Django Application and Related Modules"
|
|
12
12
|
readme = "README.md"
|
|
13
13
|
authors = [
|
|
@@ -34,7 +34,7 @@ dependencies = [
|
|
|
34
34
|
"async-timeout>=4.0.3,<4.0.4;python_version<'3.11'",
|
|
35
35
|
"backoff>=2.1.2,<2.2.2",
|
|
36
36
|
"click>=8.1.0,<=8.1.8",
|
|
37
|
-
"cryptography>=38.0.1,<
|
|
37
|
+
"cryptography>=38.0.1,<45.0.3",
|
|
38
38
|
"Django~=4.2.0", # LTS version, switch only if we have a compelling reason to",
|
|
39
39
|
"django-filter>=23.1,<=25.1",
|
|
40
40
|
"django-guid>=3.3,<=3.5.1",
|
|
@@ -43,7 +43,7 @@ dependencies = [
|
|
|
43
43
|
"djangorestframework>=3.14.0,<=3.16.0",
|
|
44
44
|
"djangorestframework-queryfields>=1.0,<=1.1.0",
|
|
45
45
|
"drf-access-policy>=1.1.2,<1.5.1",
|
|
46
|
-
"drf-nested-routers>=0.93.4,<=0.94.
|
|
46
|
+
"drf-nested-routers>=0.93.4,<=0.94.2",
|
|
47
47
|
"drf-spectacular==0.27.2", # We monkeypatch this so we need a very narrow requirement string
|
|
48
48
|
"dynaconf>=3.2.5,<3.3.0",
|
|
49
49
|
"gunicorn>=20.1,<23.1.0",
|
|
@@ -58,7 +58,7 @@ dependencies = [
|
|
|
58
58
|
"protobuf>=4.21.1,<6.0",
|
|
59
59
|
"pulp-glue>=0.18.0,<0.33",
|
|
60
60
|
"pygtrie>=2.5,<=2.5.0",
|
|
61
|
-
"psycopg[binary]>=3.1.8
|
|
61
|
+
"psycopg[binary]>=3.1.8,<3.3", # semver, not explicitely stated, but mentioned on multiple changes
|
|
62
62
|
"pyparsing>=3.1.0,<=3.2.3",
|
|
63
63
|
"python-gnupg>=0.5,<=0.5.4",
|
|
64
64
|
"PyYAML>=5.1.1,<=6.0.2",
|
|
@@ -208,7 +208,7 @@ ignore = [
|
|
|
208
208
|
[tool.bumpversion]
|
|
209
209
|
# This section is managed by the plugin template. Do not edit manually.
|
|
210
210
|
|
|
211
|
-
current_version = "3.
|
|
211
|
+
current_version = "3.79.1"
|
|
212
212
|
commit = false
|
|
213
213
|
tag = false
|
|
214
214
|
parse = "(?P<major>\\d+)\\.(?P<minor>\\d+)\\.(?P<alpha>0a)?(?P<patch>\\d+)(\\.(?P<release>[a-z]+))?"
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|