pulpcore 3.83.1__tar.gz → 3.84.0__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.83.1 → pulpcore-3.84.0}/CHANGES.md +55 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/PKG-INFO +6 -5
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/app/__init__.py +1 -1
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/__init__.py +1 -1
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/apps.py +1 -1
- pulpcore-3.84.0/pulpcore/app/migrations/0134_task_insert_trigger.py +81 -0
- pulpcore-3.84.0/pulpcore/app/migrations/0135_task_pulp_task_resources_index.py +25 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/repository.py +39 -37
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/task.py +7 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/settings.py +10 -2
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/purge.py +8 -5
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/constants.py +4 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tasking/entrypoint.py +12 -2
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tasking/tasks.py +5 -30
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tasking/worker.py +77 -39
- pulpcore-3.84.0/pulpcore/tests/functional/api/test_login.py +139 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore.egg-info/PKG-INFO +6 -5
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore.egg-info/SOURCES.txt +2 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore.egg-info/requires.txt +5 -4
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pyproject.toml +11 -7
- pulpcore-3.83.1/pulpcore/tests/functional/api/test_login.py +0 -109
- {pulpcore-3.83.1 → pulpcore-3.84.0}/CODE_OF_CONDUCT.md +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/COMMITMENT +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/CONTRIBUTING.md +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/COPYRIGHT +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/LICENSE +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/MANIFEST.in +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/README.md +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/ci_requirements.txt +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/functest_requirements.txt +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/manage.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/app/migrations/0002_alter_rhsmcertguard_contentguard_ptr_and_more.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/app/migrations/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/app/models.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/app/serializers.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/app/utils.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/app/viewsets.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/pytest_plugin.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/api/test_rhsm_certguard.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/api/test_x509_certguard.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/katello-default-ca.crt +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/katello-default-ca.key +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/trusted_but_expired.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/uber.cert +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/untrusted_cert-key.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/untrusted_cert.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/v1/1514454871848760713-key.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/v1/1514454871848760713.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/v1/159442575569388840-key.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/v1/159442575569388840.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/v3/4260035510644027985-key.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/v3/4260035510644027985.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/v3/5527980418107729172-key.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/rhsm/v3/5527980418107729172.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/certificates/ca.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/genca.sh +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/thirdparty_ca/keys/ca.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/certificates/ca.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/certificates/client.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/certificates/server.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/certificates/un_urlencoded_cert.txt +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/certificates/untrusted_client.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/genall.sh +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/genca.sh +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/genclient.sh +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/gensrv.sh +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/keys/ca.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/keys/client.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/artifacts/x509/keys/server.pem +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/conftest.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/functional/constants.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/unit/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_certguard/tests/unit/test_models.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0001_initial_squashed_0016_add_domain.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0002_file_related_names.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0003_auto_20191014_1721.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0004_filefilesystemexporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0005_filerepository.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0006_delete_filefilesystemexporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0007_filefilesystemexporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0008_add_manifest_field.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0009_move_data_to_new_master_distribution_model.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0010_auto_publish.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0011_fix_auto_publish.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0012_delete_filefilesystemexporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0013_file_acs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0014_new_rbac_permissions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0015_allow_null_manifest.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0016_add_domain.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/0017_alter_filealternatecontentsource_alternatecontentsource_ptr_and_more.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/migrations/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/modelresource.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/models.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/replica.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/serializers.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/tasks/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/tasks/publishing.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/tasks/synchronizing.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/app/viewsets.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/manifest.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/pytest_plugin.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_acs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_auto_publish.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_bad_sync.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_content_labels.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_crud_content_unit.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_crud_remotes.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_domains.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_download_policies.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_generic_list.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_labels.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_mime_types.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_publish.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_pulp_export.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_rbac.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_remote_settings.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/functional/api/test_sync.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/unit/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/unit/test_safe_paths.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulp_file/tests/unit/test_serializers.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/access_policy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/authentication.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/checks.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/entrypoint.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/files.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/global_access_conditions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/importexport.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/loggers.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/manage.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/add-signing-service.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/analyze-publication.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/clean-up-progress-reports.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/datarepair-2327.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/dump-permissions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/dump-publications-to-fs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/handle-artifact-checksums.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/migrationstat.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/openapi.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/rebasemigrations.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/remove-plugin.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/remove-signing-service.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/repository-size.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/reset-admin-password.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/management/commands/rotate-db-key.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0001_initial.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0001_squashed_0090_char_to_text_field.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0002_increase_artifact_size_field.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0003_remove_upload_completed.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0004_add_duplicated_reserved_resources.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0005_progressreport_code.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0006_repository_plugin_managed.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0007_delete_progress_proxies.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0008_published_metadata_as_content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0009_remove_task_non_fatal_errors.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0010_pulp_fields.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0011_relative_path.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0012_auto_20191104_2000.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0013_repository_pulp_type.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0014_remove_repository_plugin_managed.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0015_auto_20191112_1426.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0016_charfield_to_textfield.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0017_remove_task_parent.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0018_auto_20191127_2350.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0019_add_signing_service_model.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0020_change_publishedartifact_constraints.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0021_add_signing_service_foreign_key.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0022_rename_last_version.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0023_change_exporter_models.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0024_use_local_storage_for_uploads.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0025_task_parent_task.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0026_task_group.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0027_export_backend.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0028_import_importer_pulpimporter_pulpimporterrepository.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0029_export_delete.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0030_taskgroup_all_tasks_dispatched.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0031_import_export_validate_params.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0032_export_to_chunks.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0033_increase_remote_artifact_size_field.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0034_groupprogressreport.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0035_content_upstream_id.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0036_unprotect_last_export.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0037_pulptemporaryfile.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0038_repository_remote.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0039_change_download_concurrency.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0040_set_admin_is_staff.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0041_accesspolicy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0042_rbac_for_tasks.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0043_toc_attribute.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0044_temp_file_artifact_field.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0045_accesspolicy_permissions_allow_null.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0046_task__resource_job_id.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0047_improve_orphan_cleanup.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0048_fips_checksums.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0049_add_file_field_to_uploadchunk.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0050_namespace_access_policies.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0051_timeoutfields.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0052_tasking_logging_cid.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0053_remote_headers.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0054_add_public_key.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0055_label.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0056_remote_rate_limit.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0057_add_label_indexes.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0058_accesspolicy_customized.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0059_proxy_creds.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0060_data_migration_proxy_creds.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0061_call_handle_artifact_checksums_command.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0062_add_new_distribution_mastermodel.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0063_repository_retained_versions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0064_add_new_style_task_columns.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0064_repository_user_hidden.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0065_merge_20210615_1211.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0066_download_concurrency_and_retry_changes.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0067_add_protect_to_task_reservation.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0068_add_timestamp_of_interest.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0069_update_json_fields.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0070_rename_retained_versions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0071_filesystemexport_filesystemexporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0072_add_method_to_filesystem_exporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0073_encrypt_remote_fields.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0074_acs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0075_rbaccontentguard.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0076_remove_reserved_resource.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0077_move_remote_url_credentials.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0078_grouprole_role_userrole.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0079_rename_permissions_assignment_accesspolicy_creation_hooks.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0080_proxy_group_model.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0081_reapplabel_group_permissions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0082_add_manage_roles_permissions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0083_alter_group_options.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0084_alter_rbaccontentguard_options.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0085_contentredirectcontentguard.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0086_task_json_fields.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0087_taskschedule.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0088_accesspolicy_queryset_scoping.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0089_alter_contentredirectcontentguard_options.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0090_char_to_text_field.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0091_systemid.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0092_alter_upload_options.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0093_add_info_field_repositoryversion.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0094_protect_repository_content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0095_artifactdistribution.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0096_alter_task_logging_cid.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0097_remove_telemetry_task_schedule.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0098_pulp_labels.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0099_versions_field.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0100_upstreampulp.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0101_add_domain.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0102_add_domain_relations.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0103_alter_export_task.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0104_delete_label.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0105_abstract_uuid_gen.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0106_alter_artifactdistribution_distribution_ptr_and_more.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0107_distribution_hidden.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0108_task_versions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0109_contentartifact_relative_path_index.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0110_apiappstatus.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0111_task_enc_args_task_enc_kwargs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0112_alter_upstreampulp_options.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0113_headercontentguard.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0114_remove_task_args_remove_task_kwargs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0115_compositecontentguard.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0116_alter_remoteartifact_md5_alter_remoteartifact_sha1_and_more.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0117_task_unblocked_at.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0118_task_core_task_unblock_2276a4_idx_and_more.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0119_grouprole_core_groupr_object__250e22_idx_and_more.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0120_get_url_removal.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0121_add_profile_artifacts_table.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0122_record_last_replication_timestamp.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0123_upstreampulp_q_select.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0124_task_deferred_task_immediate.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0125_openpgpdistribution_openpgpkeyring_openpgppublickey_and_more.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0126_remoteartifact_failed_at.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0127_remove_upstreampulp_pulp_label_select.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0128_domain_pulp_labels.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0129_content_pulp_labels.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0130_upstreampulp_policy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0131_distribution_checkpoint_publication_checkpoint.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0132_alter_content_options.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0132_task_profile_options.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/0133_repositoryversion_content_ids.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/migrations/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/mime_types.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/modelresource.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/access_policy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/acs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/analytics.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/domain.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/exporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/fields.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/generic.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/importer.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/openpgp.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/progress.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/publication.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/replica.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/role.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/status.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/storage.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/models/upload.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/netutil.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/openpgp.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/protobuf/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/protobuf/analytics_pb2.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/pulp_hashlib.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/pulpcore_gunicorn_application.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/redis_connection.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/replica.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/response.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/role_util.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/access_policy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/acs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/domain.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/exporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/fields.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/importer.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/openpgp.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/orphans.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/progress.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/publication.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/purge.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/reclaim.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/repair.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/replica.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/repository.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/status.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/task.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/upload.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/serializers/user.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/analytics.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/export.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/importer.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/migrate.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/orphan.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/reclaim_space.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/replica.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/repository.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/telemetry.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/test.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/tasks/upload.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/templates/rest_framework/api.html +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/templatetags/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/templatetags/pulp_urls.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/urls.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/util.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/views/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/views/importer.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/views/orphans.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/views/repair.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/views/status.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/access_policy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/acs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/custom_filters.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/domain.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/exporter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/importer.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/openpgp.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/orphans.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/publication.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/reclaim.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/replica.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/repository.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/task.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/upload.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/viewsets/user.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/app/wsgi.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/backends.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/cache/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/cache/cache.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/content/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/content/authentication.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/content/entrypoint.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/content/handler.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/content/instrumentation.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/download/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/download/base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/download/factory.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/download/file.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/download/http.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/exceptions/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/exceptions/base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/exceptions/plugin.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/exceptions/validation.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/filters.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/metrics.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/middleware.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/migrations.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/openapi/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/openapi/hooks.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/access_policy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/actions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/apps.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/authentication/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/cache/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/constants.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/download/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/exceptions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/files.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/importexport.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/migrations.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/modelresources.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/models/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/models/role.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/publication_utils.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/pulp_hashlib.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/replica.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/repo_version_utils.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/responses.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/serializers/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/serializers/content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/stages/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/stages/api.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/stages/artifact_stages.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/stages/content_stages.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/stages/declarative_version.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/stages/models.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/storage.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/sync.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/tasking.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/util.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/viewsets/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/plugin/viewsets/content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/pytest_plugin.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/responses.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tasking/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tasking/_util.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tasking/kafka.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tasking/storage.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_access_policy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_api_docs.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_api_root_rewrite.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_artifact_distribution.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_auth.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_correlation_id.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_crd_artifacts.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_crud_domains.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_filter.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_openapi_schema.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_openpgp.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_replication.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_repos.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_role.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_root_endpoint.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_scoping.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_signing_service.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_status.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_task_purge.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_tasking.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_upload.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_users_groups.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/test_workers.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_checkpoint.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_content_access.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_content_cache.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_content_delivery.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_content_directory.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_content_path.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_content_promotion.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_contentguard.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_crud_repos.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_distributions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_filesystemexport.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_labels.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_migrate.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_orphans.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_pagination.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_prn.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_proxy.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_pulpimport.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_reclaim_disk_space.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_repair.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_repo_versions.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_tasks.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/api/using_plugin/test_unlinking_repo.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/assets/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/content_with_coverage.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/functional/utils.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/performance/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/performance/test_performance.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/conftest.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/content/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/content/test_handler.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/content/test_heartbeat.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/download/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/download/test_downloader_base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/download/test_downloader_factory.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/metrics/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/metrics/conftest.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/metrics/test_aiohttp_instrumentation.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/metrics/test_django_instrumentation.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/migration/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/migration/test_0077_move_remote_url_credentials.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/models/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/models/test_base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/models/test_content.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/models/test_remote.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/models/test_repository.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/models/test_task.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/roles/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/roles/test_roles.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/serializers/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/serializers/test_base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/serializers/test_domain.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/serializers/test_fields.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/serializers/test_orphans_cleanup.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/serializers/test_pulpexport.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/serializers/test_repository.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/serializers/test_user.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/stages/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/stages/test_artifactdownloader.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/stages/test_stages.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_cache.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_chunked_file.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_content_guard.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_files.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_import_checks.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_pulp_urls.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_settings.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_util.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/test_viewsets.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/viewsets/__init__.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore/tests/unit/viewsets/test_viewset_base.py +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore.egg-info/dependency_links.txt +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore.egg-info/entry_points.txt +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/pulpcore.egg-info/top_level.txt +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/setup.cfg +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/test_requirements.txt +0 -0
- {pulpcore-3.83.1 → pulpcore-3.84.0}/unittest_requirements.txt +0 -0
|
@@ -8,6 +8,61 @@
|
|
|
8
8
|
|
|
9
9
|
[//]: # (towncrier release notes start)
|
|
10
10
|
|
|
11
|
+
## 3.84.0 (2025-07-30) {: #3.84.0 }
|
|
12
|
+
|
|
13
|
+
### REST API {: #3.84.0-rest-api }
|
|
14
|
+
|
|
15
|
+
#### Features {: #3.84.0-rest-api-feature }
|
|
16
|
+
|
|
17
|
+
- Added the `--auxiliary` flag to the workers entrypoint to allow adding workers to an installation that will only handle unblocked tasks.
|
|
18
|
+
- Moved timestamping of new tasks from application code into the database.
|
|
19
|
+
|
|
20
|
+
#### Bugfixes {: #3.84.0-rest-api-bugfix }
|
|
21
|
+
|
|
22
|
+
- Fixed the new content set optimization failing when the RepositoryVersion grew larger than 65K content units.
|
|
23
|
+
[#6772](https://github.com/pulp/pulpcore/issues/6772)
|
|
24
|
+
- Add some randomness to the task pickup code to relieve some pressure from the queue.
|
|
25
|
+
[#6799](https://github.com/pulp/pulpcore/issues/6799)
|
|
26
|
+
- When running as a recurring scheduled task, purge will now clean stale task records accross all domains.
|
|
27
|
+
[#6815](https://github.com/pulp/pulpcore/issues/6815)
|
|
28
|
+
- Added some Postgresql transactions in places where they are appropriate.
|
|
29
|
+
|
|
30
|
+
### Plugin API {: #3.84.0-plugin-api }
|
|
31
|
+
|
|
32
|
+
No significant changes.
|
|
33
|
+
|
|
34
|
+
### Pulp File {: #3.84.0-pulp-file }
|
|
35
|
+
|
|
36
|
+
No significant changes.
|
|
37
|
+
|
|
38
|
+
### Pulp Cert Guard {: #3.84.0-pulp-cert-guard }
|
|
39
|
+
|
|
40
|
+
No significant changes.
|
|
41
|
+
|
|
42
|
+
---
|
|
43
|
+
|
|
44
|
+
## 3.83.2 (2025-07-17) {: #3.83.2 }
|
|
45
|
+
|
|
46
|
+
### REST API {: #3.83.2-rest-api }
|
|
47
|
+
|
|
48
|
+
#### Bugfixes {: #3.83.2-rest-api-bugfix }
|
|
49
|
+
|
|
50
|
+
- Added some Postgresql transactions in places where they are appropriate.
|
|
51
|
+
|
|
52
|
+
### Plugin API {: #3.83.2-plugin-api }
|
|
53
|
+
|
|
54
|
+
No significant changes.
|
|
55
|
+
|
|
56
|
+
### Pulp File {: #3.83.2-pulp-file }
|
|
57
|
+
|
|
58
|
+
No significant changes.
|
|
59
|
+
|
|
60
|
+
### Pulp Cert Guard {: #3.83.2-pulp-cert-guard }
|
|
61
|
+
|
|
62
|
+
No significant changes.
|
|
63
|
+
|
|
64
|
+
---
|
|
65
|
+
|
|
11
66
|
## 3.83.1 (2025-07-15) {: #3.83.1 }
|
|
12
67
|
|
|
13
68
|
### REST API {: #3.83.1-rest-api }
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: pulpcore
|
|
3
|
-
Version: 3.
|
|
3
|
+
Version: 3.84.0
|
|
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
|
|
@@ -44,11 +44,11 @@ Requires-Dist: gunicorn<23.1.0,>=22.0
|
|
|
44
44
|
Requires-Dist: importlib-metadata<=6.0.1,>=6.0.1
|
|
45
45
|
Requires-Dist: jinja2<=3.1.6,>=3.1
|
|
46
46
|
Requires-Dist: json_stream<2.4,>=2.3.2
|
|
47
|
-
Requires-Dist: jq<1.
|
|
47
|
+
Requires-Dist: jq<1.11.0,>=1.6.0
|
|
48
48
|
Requires-Dist: PyOpenSSL<26.0
|
|
49
|
-
Requires-Dist: opentelemetry-api<1.
|
|
50
|
-
Requires-Dist: opentelemetry-sdk<1.
|
|
51
|
-
Requires-Dist: opentelemetry-exporter-otlp-proto-http<1.
|
|
49
|
+
Requires-Dist: opentelemetry-api<1.36,>=1.27.0
|
|
50
|
+
Requires-Dist: opentelemetry-sdk<1.36,>=1.27.0
|
|
51
|
+
Requires-Dist: opentelemetry-exporter-otlp-proto-http<1.36,>=1.27.0
|
|
52
52
|
Requires-Dist: protobuf<6.0,>=4.21.1
|
|
53
53
|
Requires-Dist: pulp-glue<0.35,>=0.28.0
|
|
54
54
|
Requires-Dist: pygtrie<=2.5.0,>=2.5
|
|
@@ -70,6 +70,7 @@ Provides-Extra: google
|
|
|
70
70
|
Requires-Dist: django-storages[google]==1.14.6; extra == "google"
|
|
71
71
|
Provides-Extra: azure
|
|
72
72
|
Requires-Dist: django-storages[azure]==1.14.6; extra == "azure"
|
|
73
|
+
Requires-Dist: azure-storage-blob<12.26.0; extra == "azure"
|
|
73
74
|
Provides-Extra: prometheus
|
|
74
75
|
Requires-Dist: django-prometheus; extra == "prometheus"
|
|
75
76
|
Provides-Extra: kafka
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
# Generated by Django 4.2.22 on 2025-06-06 14:32
|
|
2
|
+
|
|
3
|
+
from django.db import migrations
|
|
4
|
+
from pulpcore.migrations import RequireVersion
|
|
5
|
+
|
|
6
|
+
# This migration is supposed to be zero downtime upgrade safe.
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
TASK_INSERT_TRIGGER_UP = """
|
|
10
|
+
CREATE FUNCTION on_insert_timestamp_task()
|
|
11
|
+
RETURNS TRIGGER
|
|
12
|
+
LANGUAGE plpgsql
|
|
13
|
+
AS $$
|
|
14
|
+
DECLARE
|
|
15
|
+
res_list text[];
|
|
16
|
+
res_list_shared text[];
|
|
17
|
+
BEGIN
|
|
18
|
+
res_list := array_agg(q.res) FROM (SELECT regexp_replace(unnest(NEW.reserved_resources_record), '^shared:', '') res) AS q;
|
|
19
|
+
res_list_shared := array_agg(q.res) FROM (SELECT 'shared:' || unnest(res_list) AS res) AS q;
|
|
20
|
+
PERFORM pg_advisory_xact_lock(4711, q.id) FROM (SELECT hashtext(res) AS id FROM unnest(res_list) AS res ORDER BY id) AS q;
|
|
21
|
+
NEW.pulp_created = clock_timestamp();
|
|
22
|
+
IF NEW.pulp_created <= (
|
|
23
|
+
SELECT max(pulp_created) FROM core_task
|
|
24
|
+
WHERE
|
|
25
|
+
state NOT IN ('completed', 'failed', 'canceled', 'skipped')
|
|
26
|
+
AND
|
|
27
|
+
reserved_resources_record && (res_list || res_list_shared)
|
|
28
|
+
)
|
|
29
|
+
THEN
|
|
30
|
+
RAISE EXCEPTION 'Clock screw detected.';
|
|
31
|
+
END IF;
|
|
32
|
+
RETURN NEW;
|
|
33
|
+
END;
|
|
34
|
+
$$
|
|
35
|
+
;
|
|
36
|
+
|
|
37
|
+
CREATE FUNCTION on_update_timestamp_task()
|
|
38
|
+
RETURNS TRIGGER
|
|
39
|
+
LANGUAGE plpgsql
|
|
40
|
+
AS $$
|
|
41
|
+
BEGIN
|
|
42
|
+
-- This is mainly a safeguard to prevent old code from messing with the timestamp, now that the database is in charge.
|
|
43
|
+
RAISE EXCEPTION 'Updating pulp_created is not allowed.';
|
|
44
|
+
END;
|
|
45
|
+
$$
|
|
46
|
+
;
|
|
47
|
+
|
|
48
|
+
CREATE TRIGGER on_insert_timestamp_task_trigger
|
|
49
|
+
BEFORE INSERT
|
|
50
|
+
ON core_task
|
|
51
|
+
FOR EACH ROW
|
|
52
|
+
EXECUTE FUNCTION on_insert_timestamp_task()
|
|
53
|
+
;
|
|
54
|
+
|
|
55
|
+
CREATE TRIGGER on_update_timestamp_task_trigger
|
|
56
|
+
BEFORE UPDATE
|
|
57
|
+
ON core_task
|
|
58
|
+
FOR EACH ROW
|
|
59
|
+
WHEN (OLD.pulp_created <> NEW.pulp_created)
|
|
60
|
+
EXECUTE FUNCTION on_update_timestamp_task()
|
|
61
|
+
;
|
|
62
|
+
"""
|
|
63
|
+
|
|
64
|
+
TASK_INSERT_TRIGGER_DOWN = """
|
|
65
|
+
DROP TRIGGER on_update_timestamp_task_trigger on core_task;
|
|
66
|
+
DROP TRIGGER on_insert_timestamp_task_trigger on core_task;
|
|
67
|
+
DROP FUNCTION on_update_timestamp_task;
|
|
68
|
+
DROP FUNCTION on_insert_timestamp_task;
|
|
69
|
+
"""
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
class Migration(migrations.Migration):
|
|
73
|
+
|
|
74
|
+
dependencies = [
|
|
75
|
+
("core", "0133_repositoryversion_content_ids"),
|
|
76
|
+
]
|
|
77
|
+
|
|
78
|
+
operations = [
|
|
79
|
+
RequireVersion("core", "3.82.1"),
|
|
80
|
+
migrations.RunSQL(sql=TASK_INSERT_TRIGGER_UP, reverse_sql=TASK_INSERT_TRIGGER_DOWN),
|
|
81
|
+
]
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
# Generated by Django 4.2.22 on 2025-07-07 11:07
|
|
2
|
+
|
|
3
|
+
import django.contrib.postgres.indexes
|
|
4
|
+
from django.db import migrations, models
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
class Migration(migrations.Migration):
|
|
8
|
+
|
|
9
|
+
dependencies = [
|
|
10
|
+
("core", "0134_task_insert_trigger"),
|
|
11
|
+
]
|
|
12
|
+
|
|
13
|
+
operations = [
|
|
14
|
+
migrations.AddIndex(
|
|
15
|
+
model_name="task",
|
|
16
|
+
index=django.contrib.postgres.indexes.GinIndex(
|
|
17
|
+
condition=models.Q(
|
|
18
|
+
("state__in", ["completed", "failed", "canceled", "skipped"]), _negated=True
|
|
19
|
+
),
|
|
20
|
+
fields=["reserved_resources_record"],
|
|
21
|
+
name="pulp_task_resources_index",
|
|
22
|
+
opclasses=["array_ops"],
|
|
23
|
+
),
|
|
24
|
+
),
|
|
25
|
+
]
|
|
@@ -1064,28 +1064,29 @@ class RepositoryVersion(BaseModel):
|
|
|
1064
1064
|
)
|
|
1065
1065
|
repo_content = []
|
|
1066
1066
|
to_add = set(content.values_list("pk", flat=True)) - set(self._get_content_ids())
|
|
1067
|
-
|
|
1068
|
-
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
|
|
1080
|
-
|
|
1081
|
-
|
|
1082
|
-
|
|
1083
|
-
|
|
1084
|
-
|
|
1067
|
+
with transaction.atomic():
|
|
1068
|
+
if to_add:
|
|
1069
|
+
self.content_ids += list(to_add)
|
|
1070
|
+
self.save()
|
|
1071
|
+
|
|
1072
|
+
# Normalize representation if content has already been removed in this version and
|
|
1073
|
+
# is re-added: Undo removal by setting version_removed to None.
|
|
1074
|
+
for removed in batch_qs(self.removed().order_by("pk").values_list("pk", flat=True)):
|
|
1075
|
+
to_readd = to_add.intersection(set(removed))
|
|
1076
|
+
if to_readd:
|
|
1077
|
+
RepositoryContent.objects.filter(
|
|
1078
|
+
content__in=to_readd, repository=self.repository, version_removed=self
|
|
1079
|
+
).update(version_removed=None)
|
|
1080
|
+
to_add = to_add - to_readd
|
|
1081
|
+
|
|
1082
|
+
for content_pk in to_add:
|
|
1083
|
+
repo_content.append(
|
|
1084
|
+
RepositoryContent(
|
|
1085
|
+
repository=self.repository, content_id=content_pk, version_added=self
|
|
1086
|
+
)
|
|
1085
1087
|
)
|
|
1086
|
-
)
|
|
1087
1088
|
|
|
1088
|
-
|
|
1089
|
+
RepositoryContent.objects.bulk_create(repo_content)
|
|
1089
1090
|
|
|
1090
1091
|
def remove_content(self, content):
|
|
1091
1092
|
"""
|
|
@@ -1111,23 +1112,24 @@ class RepositoryVersion(BaseModel):
|
|
|
1111
1112
|
)
|
|
1112
1113
|
content_ids = set(self._get_content_ids())
|
|
1113
1114
|
to_remove = set(content.values_list("pk", flat=True))
|
|
1114
|
-
|
|
1115
|
-
|
|
1116
|
-
|
|
1117
|
-
|
|
1118
|
-
|
|
1119
|
-
|
|
1120
|
-
|
|
1121
|
-
|
|
1122
|
-
|
|
1123
|
-
|
|
1124
|
-
|
|
1125
|
-
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
|
|
1130
|
-
|
|
1115
|
+
with transaction.atomic():
|
|
1116
|
+
if to_remove:
|
|
1117
|
+
self.content_ids = list(content_ids - to_remove)
|
|
1118
|
+
self.save()
|
|
1119
|
+
|
|
1120
|
+
# Normalize representation if content has already been added in this version.
|
|
1121
|
+
# Undo addition by deleting the RepositoryContent.
|
|
1122
|
+
RepositoryContent.objects.filter(
|
|
1123
|
+
repository=self.repository,
|
|
1124
|
+
content_id__in=content,
|
|
1125
|
+
version_added=self,
|
|
1126
|
+
version_removed=None,
|
|
1127
|
+
).delete()
|
|
1128
|
+
|
|
1129
|
+
q_set = RepositoryContent.objects.filter(
|
|
1130
|
+
repository=self.repository, content_id__in=content, version_removed=None
|
|
1131
|
+
)
|
|
1132
|
+
q_set.update(version_removed=self)
|
|
1131
1133
|
|
|
1132
1134
|
def set_content(self, content):
|
|
1133
1135
|
"""
|
|
@@ -9,6 +9,7 @@ from gettext import gettext as _
|
|
|
9
9
|
|
|
10
10
|
from django.conf import settings
|
|
11
11
|
from django.contrib.postgres.fields import ArrayField, HStoreField
|
|
12
|
+
from django.contrib.postgres.indexes import GinIndex
|
|
12
13
|
from django.core.serializers.json import DjangoJSONEncoder
|
|
13
14
|
from django.db import connection, models
|
|
14
15
|
from django.utils import timezone
|
|
@@ -348,6 +349,12 @@ class Task(BaseModel, AutoAddObjPermsMixin):
|
|
|
348
349
|
models.Index(fields=["unblocked_at"]),
|
|
349
350
|
models.Index(fields=["state"]),
|
|
350
351
|
models.Index(fields=["state", "pulp_created"]),
|
|
352
|
+
GinIndex(
|
|
353
|
+
name="pulp_task_resources_index",
|
|
354
|
+
fields=["reserved_resources_record"],
|
|
355
|
+
condition=~models.Q(state__in=["completed", "failed", "canceled", "skipped"]),
|
|
356
|
+
opclasses=["array_ops"],
|
|
357
|
+
),
|
|
351
358
|
]
|
|
352
359
|
permissions = [
|
|
353
360
|
("manage_roles_task", "Can manage role assignments on task"),
|
|
@@ -20,7 +20,8 @@ from django.core.files.storage import storages
|
|
|
20
20
|
from django.conf import global_settings
|
|
21
21
|
from django.core.exceptions import ImproperlyConfigured
|
|
22
22
|
from django.db import connection
|
|
23
|
-
from
|
|
23
|
+
from pulpcore.app.loggers import deprecation_logger
|
|
24
|
+
from dynaconf import DjangoDynaconf, Dynaconf, Validator, get_history
|
|
24
25
|
|
|
25
26
|
from pulpcore import constants
|
|
26
27
|
|
|
@@ -553,7 +554,14 @@ settings = DjangoDynaconf(
|
|
|
553
554
|
|
|
554
555
|
# begin compatibility layer for DEFAULT_FILE_STORAGE
|
|
555
556
|
# Remove on pulpcore=3.85 or pulpcore=4.0
|
|
556
|
-
|
|
557
|
+
using_deprecated_storage_settings = len(get_history(settings, key="DEFAULT_FILE_STORAGE")) > 1
|
|
558
|
+
if using_deprecated_storage_settings:
|
|
559
|
+
deprecation_logger.warning(
|
|
560
|
+
"[deprecation] DEFAULT_FILE_STORAGE will be removed in pulpcore 3.85. "
|
|
561
|
+
"Learn how to upgrade to STORAGES:\n"
|
|
562
|
+
"https://discourse.pulpproject.org/t/"
|
|
563
|
+
"action-required-upgrade-your-storage-settings-before-pulpcore-3-85/2072/2"
|
|
564
|
+
)
|
|
557
565
|
# Ensures the cached property storage.backends uses the the right value
|
|
558
566
|
storages._backends = settings.STORAGES.copy()
|
|
559
567
|
storages.backends
|
|
@@ -82,17 +82,20 @@ def purge(finished_before=None, states=None, **kwargs):
|
|
|
82
82
|
states (Optional[List[str]]): List of task-states we want to purge.
|
|
83
83
|
|
|
84
84
|
"""
|
|
85
|
+
scheduled = current_task.get().taskschedule_set.exists()
|
|
86
|
+
|
|
85
87
|
if finished_before is None:
|
|
86
88
|
assert settings.TASK_PROTECTION_TIME > 0
|
|
87
89
|
finished_before = timezone.now() - timezone.timedelta(minutes=settings.TASK_PROTECTION_TIME)
|
|
88
90
|
if states is None:
|
|
89
91
|
states = TASK_FINAL_STATES
|
|
90
|
-
|
|
92
|
+
|
|
91
93
|
# Tasks, prior to the specified date, in the specified state, owned by the current-user, in the
|
|
92
94
|
# current domain
|
|
93
|
-
candidate_qs = Task.objects.filter(
|
|
94
|
-
|
|
95
|
-
|
|
95
|
+
candidate_qs = Task.objects.filter(finished_at__lt=finished_before, state__in=states)
|
|
96
|
+
|
|
97
|
+
if not scheduled:
|
|
98
|
+
candidate_qs = candidate_qs.filter(pulp_domain=get_domain())
|
|
96
99
|
if "user_pk" in kwargs:
|
|
97
100
|
if (user_pk := kwargs["user_pk"]) is not None:
|
|
98
101
|
current_user = User.objects.get(pk=user_pk)
|
|
@@ -101,7 +104,7 @@ def purge(finished_before=None, states=None, **kwargs):
|
|
|
101
104
|
# This is the old task signature (<= 3.74) without "user_pk".
|
|
102
105
|
# Has this task not been dispatched from a task schedule? Then we assume there was a user
|
|
103
106
|
# doing that.
|
|
104
|
-
if not
|
|
107
|
+
if not scheduled:
|
|
105
108
|
current_user = get_current_authenticated_user()
|
|
106
109
|
if current_user is None:
|
|
107
110
|
raise RuntimeError(
|
|
@@ -12,6 +12,10 @@ TASK_UNBLOCKING_LOCK = 84
|
|
|
12
12
|
TASK_METRICS_HEARTBEAT_LOCK = 74
|
|
13
13
|
STORAGE_METRICS_LOCK = 72
|
|
14
14
|
|
|
15
|
+
# Reasons to send along a task worker wakeup call.
|
|
16
|
+
TASK_WAKEUP_UNBLOCK = "unblock"
|
|
17
|
+
TASK_WAKEUP_HANDLE = "handle"
|
|
18
|
+
|
|
15
19
|
#: All valid task states.
|
|
16
20
|
TASK_STATES = SimpleNamespace(
|
|
17
21
|
WAITING="waiting",
|
|
@@ -21,8 +21,18 @@ _logger = logging.getLogger(__name__)
|
|
|
21
21
|
@click.option(
|
|
22
22
|
"--reload/--no-reload", help="Reload worker on code changes. [requires hupper to be installed.]"
|
|
23
23
|
)
|
|
24
|
+
@click.option(
|
|
25
|
+
"--auxiliary/--no-auxiliary",
|
|
26
|
+
default=False,
|
|
27
|
+
help="Auxiliary workers do not perform housekeeping duties.",
|
|
28
|
+
)
|
|
24
29
|
@click.command()
|
|
25
|
-
def worker(
|
|
30
|
+
def worker(
|
|
31
|
+
pid,
|
|
32
|
+
burst,
|
|
33
|
+
reload,
|
|
34
|
+
auxiliary,
|
|
35
|
+
):
|
|
26
36
|
"""A Pulp worker."""
|
|
27
37
|
|
|
28
38
|
if reload:
|
|
@@ -40,4 +50,4 @@ def worker(pid, burst, reload):
|
|
|
40
50
|
|
|
41
51
|
_logger.info("Starting distributed type worker")
|
|
42
52
|
|
|
43
|
-
PulpcoreWorker().run(burst=burst)
|
|
53
|
+
PulpcoreWorker(auxiliary=auxiliary).run(burst=burst)
|
|
@@ -9,12 +9,11 @@ import traceback
|
|
|
9
9
|
import tempfile
|
|
10
10
|
import threading
|
|
11
11
|
from asgiref.sync import sync_to_async
|
|
12
|
-
from datetime import timedelta
|
|
13
12
|
from gettext import gettext as _
|
|
14
13
|
|
|
15
14
|
from django.conf import settings
|
|
16
15
|
from django.db import connection, transaction
|
|
17
|
-
from django.db.models import Model
|
|
16
|
+
from django.db.models import Model
|
|
18
17
|
from django_guid import get_guid
|
|
19
18
|
from pulpcore.app.apps import MODULE_PLUGIN_VERSIONS
|
|
20
19
|
from pulpcore.app.models import Task, TaskGroup
|
|
@@ -23,8 +22,8 @@ from pulpcore.constants import (
|
|
|
23
22
|
TASK_FINAL_STATES,
|
|
24
23
|
TASK_INCOMPLETE_STATES,
|
|
25
24
|
TASK_STATES,
|
|
26
|
-
TASK_DISPATCH_LOCK,
|
|
27
25
|
IMMEDIATE_TIMEOUT,
|
|
26
|
+
TASK_WAKEUP_UNBLOCK,
|
|
28
27
|
)
|
|
29
28
|
from pulpcore.middleware import x_task_diagnostics_var
|
|
30
29
|
from pulpcore.tasking.kafka import send_task_notification
|
|
@@ -47,10 +46,10 @@ def _validate_and_get_resources(resources):
|
|
|
47
46
|
return list(resource_set)
|
|
48
47
|
|
|
49
48
|
|
|
50
|
-
def wakeup_worker():
|
|
49
|
+
def wakeup_worker(reason="unknown"):
|
|
51
50
|
# Notify workers
|
|
52
51
|
with connection.connection.cursor() as cursor:
|
|
53
|
-
cursor.execute("
|
|
52
|
+
cursor.execute("SELECT pg_notify('pulp_worker_wakeup', %s)", (reason,))
|
|
54
53
|
|
|
55
54
|
|
|
56
55
|
def execute_task(task):
|
|
@@ -228,13 +227,6 @@ def dispatch(
|
|
|
228
227
|
notify_workers = False
|
|
229
228
|
with contextlib.ExitStack() as stack:
|
|
230
229
|
with transaction.atomic():
|
|
231
|
-
# Task creation need to be serialized so that pulp_created will provide a stable order
|
|
232
|
-
# at every time. We specifically need to ensure that each task, when committed to the
|
|
233
|
-
# task table will be the newest with respect to `pulp_created`.
|
|
234
|
-
with connection.cursor() as cursor:
|
|
235
|
-
# Wait for exclusive access and release automatically after transaction.
|
|
236
|
-
cursor.execute("SELECT pg_advisory_xact_lock(%s, %s)", [0, TASK_DISPATCH_LOCK])
|
|
237
|
-
newest_created = Task.objects.aggregate(Max("pulp_created"))["pulp_created__max"]
|
|
238
230
|
task = Task.objects.create(
|
|
239
231
|
state=TASK_STATES.WAITING,
|
|
240
232
|
logging_cid=(get_guid()),
|
|
@@ -250,23 +242,6 @@ def dispatch(
|
|
|
250
242
|
profile_options=x_task_diagnostics_var.get(None),
|
|
251
243
|
)
|
|
252
244
|
task.refresh_from_db() # The database may have assigned a timestamp for us.
|
|
253
|
-
if newest_created and task.pulp_created <= newest_created:
|
|
254
|
-
# Let this workaround not row forever into the future.
|
|
255
|
-
if newest_created - task.pulp_created > timedelta(seconds=1):
|
|
256
|
-
# Do not commit the transaction if this condition is not met.
|
|
257
|
-
# If we ever hit this, think about delegating the timestamping to PostgresQL.
|
|
258
|
-
raise RuntimeError("Clockscrew detected. Task dispatching would be dangerous.")
|
|
259
|
-
# Try to work around the smaller glitch
|
|
260
|
-
task.pulp_created = newest_created + timedelta(milliseconds=1)
|
|
261
|
-
task.save()
|
|
262
|
-
if task_group:
|
|
263
|
-
task_group.refresh_from_db()
|
|
264
|
-
if task_group.all_tasks_dispatched:
|
|
265
|
-
task.set_canceling()
|
|
266
|
-
task.set_canceled(
|
|
267
|
-
TASK_STATES.CANCELED, "All tasks in group have been dispatched/canceled."
|
|
268
|
-
)
|
|
269
|
-
return task
|
|
270
245
|
if immediate:
|
|
271
246
|
# Grab the advisory lock before the task hits the db.
|
|
272
247
|
stack.enter_context(task)
|
|
@@ -308,7 +283,7 @@ def dispatch(
|
|
|
308
283
|
task.set_canceling()
|
|
309
284
|
task.set_canceled(TASK_STATES.CANCELED, "Resources temporarily unavailable.")
|
|
310
285
|
if notify_workers:
|
|
311
|
-
wakeup_worker()
|
|
286
|
+
wakeup_worker(TASK_WAKEUP_UNBLOCK)
|
|
312
287
|
return task
|
|
313
288
|
|
|
314
289
|
|