rucio 38.3.0__tar.gz → 38.4.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 rucio might be problematic. Click here for more details.
- {rucio-38.3.0 → rucio-38.4.0}/PKG-INFO +1 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/did.py +1 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/opendata.py +19 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/accountclient.py +20 -19
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/accountlimitclient.py +5 -4
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/baseclient.py +25 -25
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/configclient.py +7 -6
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/credentialclient.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/didclient.py +33 -32
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/diracclient.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/exportclient.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/importclient.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/lifetimeclient.py +3 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/lockclient.py +4 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/metaconventionsclient.py +5 -4
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/opendataclient.py +8 -7
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/pingclient.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/replicaclient.py +27 -26
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/requestclient.py +8 -8
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/rseclient.py +31 -28
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/ruleclient.py +13 -12
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/scopeclient.py +4 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/subscriptionclient.py +6 -5
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/constants.py +18 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/exception.py +20 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/plugins.py +9 -7
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/credential.py +19 -26
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did.py +1 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/opendata.py +150 -8
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/rule_grouping.py +3 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/account.py +8 -7
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/opendata.py +2 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/request.py +2 -117
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/webdav.py +5 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/fts3.py +0 -19
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/vcsversion.py +3 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/accountlimits.py +4 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/accounts.py +26 -25
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/archives.py +2 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/auth.py +15 -14
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/common.py +4 -4
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/config.py +6 -4
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/credentials.py +3 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/dids.py +25 -24
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/dirac.py +3 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/export.py +4 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/heartbeats.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/identities.py +5 -4
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/import.py +3 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/lifetime_exceptions.py +3 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/locks.py +4 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/meta_conventions.py +4 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/metrics.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/nongrid_traces.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/opendata.py +7 -6
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/opendata_public.py +6 -5
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/ping.py +3 -2
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/redirect.py +4 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/replicas.py +31 -31
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/requests.py +7 -7
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/rses.py +23 -16
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/rules.py +9 -8
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/scopes.py +4 -3
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/subscriptions.py +9 -8
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/traces.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/vos.py +4 -3
- {rucio-38.3.0 → rucio-38.4.0}/pyproject.toml +1 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_account.py +15 -1
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_clients.py +2 -1
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_did.py +7 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_gateway_external_representation.py +8 -11
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_judge_evaluator.py +1 -1
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_opendata.py +89 -4
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_policy_package.py +1 -1
- {rucio-38.3.0 → rucio-38.4.0}/AUTHORS.rst +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/ChangeLog +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/LICENSE +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/MANIFEST.in +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/README.md +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-abacus-account +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-abacus-collection-replica +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-abacus-rse +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-admin +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-atropos +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-auditor +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-automatix +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-bb8 +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-cache-client +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-cache-consumer +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-conveyor-finisher +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-conveyor-poller +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-conveyor-preparer +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-conveyor-receiver +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-conveyor-stager +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-conveyor-submitter +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-conveyor-throttler +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-dark-reaper +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-dumper +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-follower +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-hermes +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-judge-cleaner +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-judge-evaluator +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-judge-injector +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-judge-repairer +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-kronos +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-minos +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-minos-temporary-expiration +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-necromancer +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-oauth-manager +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-reaper +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-replica-recoverer +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-rse-decommissioner +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-storage-consistency-actions +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-transmogrifier +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/bin/rucio-undertaker +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/alembic.ini.template +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/alembic_offline.ini.template +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/globus-config.yml.template +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/ldap.cfg.template +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/mail_templates/rule_approval_request.tmpl +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/mail_templates/rule_approved_admin.tmpl +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/mail_templates/rule_approved_user.tmpl +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/mail_templates/rule_denied_admin.tmpl +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/mail_templates/rule_denied_user.tmpl +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/mail_templates/rule_ok_notification.tmpl +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/rse-accounts.cfg.template +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/rucio.cfg.atlas.client.template +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/rucio.cfg.template +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/etc/rucio_multi_vo.cfg.template +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/alembicrevision.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/account.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/bin_legacy/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/bin_legacy/rucio.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/bin_legacy/rucio_admin.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/command.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/config.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/download.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/lifetime_exception.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/rule.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/scope.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/subscription.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/upload.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/cli/utils.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/client.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/downloadclient.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/richclient.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/touchclient.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/client/uploadclient.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/bittorrent.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/cache.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/checksum.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/client.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/config.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/constraints.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/didtype.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/dumper/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/dumper/consistency.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/dumper/data_models.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/dumper/path_parsing.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/extra.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/logging.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/pcache.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/policy.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/schema/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/schema/generic.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/schema/generic_multi_vo.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/stomp_utils.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/stopwatch.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/test_rucio_server.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/types.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/common/utils.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/account.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/account_counter.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/account_limit.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/authentication.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/config.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did_meta_plugins/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did_meta_plugins/did_column_meta.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did_meta_plugins/did_meta_plugin_interface.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did_meta_plugins/elasticsearch_meta.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did_meta_plugins/filter_engine.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did_meta_plugins/json_meta.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did_meta_plugins/mongo_meta.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/did_meta_plugins/postgres_meta.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/dirac.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/distance.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/exporter.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/heartbeat.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/identity.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/importer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/lifetime_exception.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/lock.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/message.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/meta_conventions.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/monitor.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/naming_convention.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/nongrid_trace.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/oidc.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/permission/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/permission/generic.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/permission/generic_multi_vo.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/quarantined_replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/replica_sorter.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/request.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/rse_counter.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/rse_expression_parser.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/rse_selector.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/rule.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/scope.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/subscription.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/topology.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/trace.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/transfer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/vo.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/core/volatile_replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/abacus/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/abacus/account.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/abacus/collection_replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/abacus/rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/atropos/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/atropos/atropos.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/auditor/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/auditor/hdfs.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/auditor/srmdumps.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/automatix/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/automatix/automatix.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/badreplicas/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/badreplicas/minos.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/badreplicas/minos_temporary_expiration.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/badreplicas/necromancer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/bb8/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/bb8/bb8.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/bb8/common.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/bb8/nuclei_background_rebalance.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/bb8/t2_background_rebalance.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/cache/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/cache/consumer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/common.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/common.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/finisher.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/poller.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/preparer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/receiver.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/stager.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/submitter.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/conveyor/throttler.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/follower/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/follower/follower.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/hermes/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/hermes/hermes.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/judge/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/judge/cleaner.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/judge/evaluator.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/judge/injector.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/judge/repairer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/oauthmanager/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/oauthmanager/oauthmanager.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/reaper/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/reaper/dark_reaper.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/reaper/reaper.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/replicarecoverer/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/replicarecoverer/suspicious_replica_recoverer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/rsedecommissioner/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/rsedecommissioner/config.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/rsedecommissioner/profiles/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/rsedecommissioner/profiles/atlas.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/rsedecommissioner/profiles/generic.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/rsedecommissioner/profiles/types.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/rsedecommissioner/rse_decommissioner.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/storage/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/storage/consistency/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/storage/consistency/actions.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/tracer/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/tracer/kronos.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/transmogrifier/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/transmogrifier/transmogrifier.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/undertaker/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/daemons/undertaker/undertaker.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/constants.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/env.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/01eaf73ab656_add_new_rule_notification_state_progress.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/0437a40dbfd1_add_eol_at_in_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/0f1adb7a599a_create_transfer_hops_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/102efcf145f4_added_stuck_at_column_to_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/13d4f70c66a9_introduce_transfer_limits.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/140fef722e91_cleanup_distances_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/14ec5aeb64cf_add_request_external_host.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/156fb5b5a14_add_request_type_to_requests_idx.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1677d4d803c8_split_rse_availability_into_multiple.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/16a0aca82e12_create_index_on_table_replicas_path.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1803333ac20f_adding_provenance_and_phys_group.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1a29d6a9504c_add_didtype_chck_to_requests.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1a80adff031a_create_index_on_rules_hist_recent.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1c45d9730ca6_increase_identity_length.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1d1215494e95_add_quarantined_replicas_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1d96f484df21_asynchronous_rules_and_rule_approval.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1f46c5f240ac_add_bytes_column_to_bad_replicas.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/1fc15ab60d43_add_message_history_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2190e703eb6e_move_rse_settings_to_rse_attributes.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/21d6b9dc9961_add_mismatch_scheme_state_to_requests.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/22cf51430c78_add_availability_column_to_table_rses.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/22d887e4ec0a_create_sources_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/25821a8a45a3_remove_unique_constraint_on_requests.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/25fc855625cf_added_unique_constraint_to_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/269fee20dee9_add_repair_cnt_to_locks.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/271a46ea6244_add_ignore_availability_column_to_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/277b5fbb41d3_switch_heartbeats_executable.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/27e3a68927fb_remove_replicas_tombstone_and_replicas_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2854cd9e168_added_rule_id_column.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/295289b5a800_processed_by_and__at_in_requests.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2962ece31cf4_add_nbaccesses_column_in_the_did_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2af3291ec4c_added_replicas_history_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2b69addda658_add_columns_for_third_party_copy_read_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2b8e7bcb4783_add_config_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2ba5229cb54c_add_submitted_at_to_requests_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2cbee484dcf9_added_column_volume_to_rse_transfer_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2edee4a83846_add_source_to_requests_and_requests_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2eef46be23d4_change_tokens_pk.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/2f648fc909f3_index_in_rule_history_on_scope_name.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/3082b8cef557_add_naming_convention_table_and_closed_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/30d5206e9cad_increase_oauthrequest_redirect_msg_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/30fa38b6434e_add_index_on_service_column_in_the_message_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/3152492b110b_added_staging_area_column.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/32c7d2783f7e_create_bad_replicas_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/3345511706b8_replicas_table_pk_definition_is_in_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/35ef10d1e11b_change_index_on_table_requests.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/379a19b5332d_create_rse_limits_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/384b96aa0f60_created_rule_history_tables.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/3ac1660a1a72_extend_distance_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/3ad36e2268b0_create_collection_replicas_updates_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/3c9df354071b_extend_waiting_request_state.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/3d9813fab443_add_a_new_state_lost_in_badfilesstatus.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/40ad39ce3160_add_transferred_at_to_requests_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/4207be2fd914_add_notification_column_to_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/42db2617c364_create_index_on_requests_external_id.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/436827b13f82_added_column_activity_to_table_requests.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/44278720f774_update_requests_typ_sta_upd_idx_index.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/45378a1e76a8_create_collection_replica_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/469d262be19_removing_created_at_index.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/4783c1f49cb4_create_distance_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/49a21b4d4357_create_index_on_table_tokens.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/4a2cbedda8b9_add_source_replica_expression_column_to_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/4a7182d9578b_added_bytes_length_accessed_at_columns.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/4bab9edd01fc_create_index_on_requests_rule_id.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/4c3a4acfe006_new_attr_account_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/4cf0a2e127d4_adding_transient_metadata.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/4df2c5ddabc0_remove_temporary_dids.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/50280c53117c_add_qos_class_to_rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/52153819589c_add_rse_id_to_replicas_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/52fd9f4916fa_added_activity_to_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/53b479c3cb0f_fix_did_meta_table_missing_updated_at_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/5673b4b6e843_add_wfms_metadata_to_rule_tables.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/575767d9f89_added_source_history_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/58bff7008037_add_started_at_to_requests.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/58c8b78301ab_rename_callback_to_message.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/5f139f77382a_added_child_rule_id_column.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/688ef1840840_adding_did_meta_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/6e572a9bfbf3_add_new_split_container_column_to_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/70587619328_add_comment_column_for_subscriptions.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/739064d31565_remove_history_table_pks.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/7541902bf173_add_didsfollowed_and_followevents_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/7ec22226cdbf_new_replica_state_for_temporary_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/810a41685bc1_added_columns_rse_transfer_limits.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/83f991c63a93_correct_rse_expression_length.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/8523998e2e76_increase_size_of_extended_attributes_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/8ea9122275b1_adding_missing_function_based_indices.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/90f47792bb76_add_clob_payload_to_messages.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/914b8f02df38_new_table_for_lifetime_model_exceptions.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/94a5961ddbf2_add_estimator_columns.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/9a1b149a2044_add_saml_identity_type.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/9a45bc4ea66d_add_vp_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/9eb936a81eb1_true_is_true.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a08fa8de1545_transfer_stats_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a118956323f8_added_vo_table_and_vo_col_to_rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a193a275255c_add_status_column_in_messages.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a5f6f6e928a7_1_7_0.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a616581ee47_added_columns_to_table_requests.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a62db546a1f1_opendata_initial_model.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a6eb23955c28_state_idx_non_functional.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a74275a1ad30_added_global_quota_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/a93e4e47bda_heartbeats.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/ae2a56fcc89_added_comment_column_to_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/b0070f3695c8_add_deletedidmeta_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/b4293a99f344_added_column_identity_to_table_tokens.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/b5493606bbf5_fix_primary_key_for_subscription_history.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/b7d287de34fd_removal_of_replicastate_source.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/b818052fa670_add_index_to_quarantined_replicas.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/b8caac94d7f0_add_comments_column_for_subscriptions_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/b96a1c7e1cc4_new_bad_pfns_table_and_bad_replicas_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/bb695f45c04_extend_request_state.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/bc68e9946deb_add_staging_timestamps_to_request.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/bf3baa1c1474_correct_pk_and_idx_for_history_tables.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/c0937668555f_add_qos_policy_map_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/c129ccdb2d5_add_lumiblocknr_to_dids.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/ccdbcd48206e_add_did_type_column_index_on_did_meta_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/cebad904c4dd_new_payload_column_for_heartbeats.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/d1189a09c6e0_oauth2_0_and_jwt_feature_support_adding_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/d23453595260_extend_request_state_for_preparer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/d6dceb1de2d_added_purge_column_to_rules.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/d6e2c3b2cf26_remove_third_party_copy_column_from_rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/d91002c5841_new_account_limits_table.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/e138c364ebd0_extending_columns_for_filter_and_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/e59300c8b179_support_for_archive.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/f1b14a8c2ac1_postgres_use_check_constraints.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/f41ffe206f37_oracle_global_temporary_tables.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/f85a2962b021_adding_transfertool_column_to_requests_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/fa7a7d78b602_increase_refresh_token_size.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/fb28a95fe288_add_replicas_rse_id_tombstone_idx.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/fe1a65b176c9_set_third_party_copy_read_and_write_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/migrate_repo/versions/fe8ea2fa9788_added_third_party_copy_column_to_rse_.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/models.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/sautils.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/session.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/types.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/db/sqla/util.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/account_limit.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/authentication.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/config.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/credential.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/did.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/dirac.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/exporter.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/heartbeat.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/identity.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/importer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/lifetime_exception.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/lock.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/meta_conventions.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/permission.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/quarantined_replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/rule.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/scope.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/subscription.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/trace.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/gateway/vo.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/bittorrent.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/cache.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/dummy.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/gfal.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/globus.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/http_cache.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/mock.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/ngarc.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/posix.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/protocol.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/rclone.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/rfio.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/srm.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/ssh.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/storm.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/protocols/xrootd.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/rsemanager.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/rse/translation.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/tests/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/tests/common.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/tests/common_server.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/bittorrent.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/bittorrent_driver.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/bittorrent_driver_qbittorrent.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/fts3_plugins.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/globus.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/globus_library.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/mock.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/transfertool/transfertool.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/version.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/authenticated_bp.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/__init__.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/main.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/templates/auth_crash.html +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/templates/auth_granted.html +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/flaskapi/v1/types.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/main.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/metrics.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio/web/rest/ping.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/lib/rucio.egg-info/SOURCES.txt +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/requirements/requirements.server.txt +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/setup.cfg +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/setup.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/setuputil.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_abacus_account.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_abacus_collection_replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_abacus_rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_account_limits.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_archive.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_auditor.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_auditor_hdfs.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_auditor_srmdumps.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_authentication.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_automatix.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_bad_replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_bb8.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_belleii.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_bin_rucio.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_boolean.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_cli_client_structure.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_config.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_conveyor.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_conveyor_submitter.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_counter.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_credential.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_curl.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_daemons.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_dataset_replicas.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_db.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_did_meta_plugins.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_download.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_dumper.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_filter_engine.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_heartbeat.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_hermes.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_identity.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_impl_upload_download.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_import_export.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_judge_cleaner.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_judge_injector.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_judge_repairer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_lifetime.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_message.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_meta_conventions.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_meta_did.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_module_import.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_monitor.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_multi_vo.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_naming_convention.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_oauthmanager.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_oidc.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_permission.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_pfns.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_ping.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_preparer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_qos.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_quarantined_replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_reaper.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_redirect.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_replica.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_replica_recoverer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_replica_sorting.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_request.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_root_proxy.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_expression_parser.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_lfn2path.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_gfal2.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_gfal2_impl.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_posix.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_rclone.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_rsync.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_srm.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_ssh.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_webdav.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_protocol_xrootd.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rse_selector.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rucio_server.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_rule.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_scope.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_subscription.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_throttler.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_tpc.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_trace.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_transfer.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_transfer_plugins.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_undertaker.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_upload.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tests/test_utils.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tools/bootstrap.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tools/merge_rucio_configs.py +0 -0
- {rucio-38.3.0 → rucio-38.4.0}/tools/reset_database.py +0 -0
|
@@ -35,7 +35,7 @@ def did():
|
|
|
35
35
|
""",
|
|
36
36
|
) # TODO Shorten this help and make supplying this easier
|
|
37
37
|
@click.option("--short", is_flag=True, default=False, help="Just dump the list of DIDs.")
|
|
38
|
-
@click.argument("did-pattern", nargs=-1)
|
|
38
|
+
@click.argument("did-pattern", nargs=-1, required=True)
|
|
39
39
|
@click.option("--parent", default=False, is_flag=True, help="List the parents of the DID - must use a full DID scope and name")
|
|
40
40
|
@click.pass_context
|
|
41
41
|
def list_(ctx, did_pattern, recursive, filter_, short, parent):
|
|
@@ -175,9 +175,26 @@ def update_opendata_did(ctx: "Context", did: str, meta: Optional[str],
|
|
|
175
175
|
Update an existing Opendata DID in the Opendata catalog.
|
|
176
176
|
"""
|
|
177
177
|
|
|
178
|
-
client = ctx.obj.client
|
|
179
178
|
if not any([meta, state, doi]):
|
|
180
179
|
raise ValueError("At least one of --meta, --state, or --doi must be provided.")
|
|
181
180
|
|
|
181
|
+
client = ctx.obj.client
|
|
182
|
+
spinner = ctx.obj.spinner
|
|
183
|
+
console = ctx.obj.console
|
|
184
|
+
|
|
182
185
|
scope, name = extract_scope(did)
|
|
183
|
-
client.update_opendata_did(scope=scope, name=name, meta=meta, state=state, doi=doi)
|
|
186
|
+
info = client.update_opendata_did(scope=scope, name=name, meta=meta, state=state, doi=doi)
|
|
187
|
+
|
|
188
|
+
if cli_config == 'rich':
|
|
189
|
+
spinner.update(status='Fetching Opendata DID stats')
|
|
190
|
+
spinner.start()
|
|
191
|
+
keyword_styles = {**CLITheme.BOOLEAN, **CLITheme.OPENDATA_DID_STATE}
|
|
192
|
+
|
|
193
|
+
table_data = [(k, Text(str(v), style=keyword_styles.get(str(v), 'default'))) for (k, v) in
|
|
194
|
+
sorted(info.items())]
|
|
195
|
+
table = generate_table(table_data, row_styles=['none'], col_alignments=['left', 'left'])
|
|
196
|
+
spinner.stop()
|
|
197
|
+
print_output(table, console=console, no_pager=ctx.obj.no_pager)
|
|
198
|
+
else:
|
|
199
|
+
table = [(k + ':', str(v)) for (k, v) in sorted(info.items())]
|
|
200
|
+
print(tabulate(table, tablefmt='plain', disable_numparse=True))
|
|
@@ -19,6 +19,7 @@ from urllib.parse import quote_plus
|
|
|
19
19
|
from requests.status_codes import codes
|
|
20
20
|
|
|
21
21
|
from rucio.client.baseclient import BaseClient, choice
|
|
22
|
+
from rucio.common.constants import HTTPMethod
|
|
22
23
|
from rucio.common.utils import build_url
|
|
23
24
|
|
|
24
25
|
if TYPE_CHECKING:
|
|
@@ -59,7 +60,7 @@ class AccountClient(BaseClient):
|
|
|
59
60
|
path = '/'.join([self.ACCOUNTS_BASEURL, account])
|
|
60
61
|
url = build_url(choice(self.list_hosts), path=path)
|
|
61
62
|
|
|
62
|
-
res = self._send_request(url,
|
|
63
|
+
res = self._send_request(url, method=HTTPMethod.POST, data=data)
|
|
63
64
|
if res.status_code == codes.created:
|
|
64
65
|
return True
|
|
65
66
|
exc_cls, exc_msg = self._get_exception(headers=res.headers, status_code=res.status_code, data=res.content)
|
|
@@ -88,7 +89,7 @@ class AccountClient(BaseClient):
|
|
|
88
89
|
path = '/'.join([self.ACCOUNTS_BASEURL, account])
|
|
89
90
|
url = build_url(choice(self.list_hosts), path=path)
|
|
90
91
|
|
|
91
|
-
res = self._send_request(url,
|
|
92
|
+
res = self._send_request(url, method=HTTPMethod.DELETE)
|
|
92
93
|
|
|
93
94
|
if res.status_code == codes.ok:
|
|
94
95
|
return True
|
|
@@ -118,7 +119,7 @@ class AccountClient(BaseClient):
|
|
|
118
119
|
path = '/'.join([self.ACCOUNTS_BASEURL, account])
|
|
119
120
|
url = build_url(choice(self.list_hosts), path=path)
|
|
120
121
|
|
|
121
|
-
res = self._send_request(url)
|
|
122
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
122
123
|
if res.status_code == codes.ok:
|
|
123
124
|
acc = self._load_json_data(res)
|
|
124
125
|
return next(acc)
|
|
@@ -152,7 +153,7 @@ class AccountClient(BaseClient):
|
|
|
152
153
|
path = '/'.join([self.ACCOUNTS_BASEURL, account])
|
|
153
154
|
url = build_url(choice(self.list_hosts), path=path)
|
|
154
155
|
|
|
155
|
-
res = self._send_request(url,
|
|
156
|
+
res = self._send_request(url, method=HTTPMethod.PUT, data=data)
|
|
156
157
|
|
|
157
158
|
if res.status_code == codes.ok:
|
|
158
159
|
return True
|
|
@@ -199,7 +200,7 @@ class AccountClient(BaseClient):
|
|
|
199
200
|
for key in filters:
|
|
200
201
|
params[key] = filters[key]
|
|
201
202
|
|
|
202
|
-
res = self._send_request(url, params=params)
|
|
203
|
+
res = self._send_request(url, method=HTTPMethod.GET, params=params)
|
|
203
204
|
|
|
204
205
|
if res.status_code == codes.ok:
|
|
205
206
|
accounts = self._load_json_data(res)
|
|
@@ -263,7 +264,7 @@ class AccountClient(BaseClient):
|
|
|
263
264
|
|
|
264
265
|
url = build_url(choice(self.list_hosts), path=path)
|
|
265
266
|
|
|
266
|
-
res = self._send_request(url,
|
|
267
|
+
res = self._send_request(url, method=HTTPMethod.POST, data=data)
|
|
267
268
|
|
|
268
269
|
if res.status_code == codes.created:
|
|
269
270
|
return True
|
|
@@ -300,7 +301,7 @@ class AccountClient(BaseClient):
|
|
|
300
301
|
|
|
301
302
|
url = build_url(choice(self.list_hosts), path=path)
|
|
302
303
|
|
|
303
|
-
res = self._send_request(url,
|
|
304
|
+
res = self._send_request(url, method=HTTPMethod.DELETE, data=data)
|
|
304
305
|
|
|
305
306
|
if res.status_code == codes.ok:
|
|
306
307
|
return True
|
|
@@ -319,7 +320,7 @@ class AccountClient(BaseClient):
|
|
|
319
320
|
"""
|
|
320
321
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'identities'])
|
|
321
322
|
url = build_url(choice(self.list_hosts), path=path)
|
|
322
|
-
res = self._send_request(url)
|
|
323
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
323
324
|
if res.status_code == codes.ok:
|
|
324
325
|
identities = self._load_json_data(res)
|
|
325
326
|
return identities
|
|
@@ -340,7 +341,7 @@ class AccountClient(BaseClient):
|
|
|
340
341
|
|
|
341
342
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'rules'])
|
|
342
343
|
url = build_url(choice(self.list_hosts), path=path)
|
|
343
|
-
res = self._send_request(url,
|
|
344
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
344
345
|
if res.status_code == codes.ok:
|
|
345
346
|
return self._load_json_data(res)
|
|
346
347
|
else:
|
|
@@ -385,7 +386,7 @@ class AccountClient(BaseClient):
|
|
|
385
386
|
|
|
386
387
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'limits', 'global', quote_plus(rse_expression)])
|
|
387
388
|
url = build_url(choice(self.list_hosts), path=path)
|
|
388
|
-
res = self._send_request(url,
|
|
389
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
389
390
|
if res.status_code == codes.ok:
|
|
390
391
|
return next(self._load_json_data(res))
|
|
391
392
|
exc_cls, exc_msg = self._get_exception(headers=res.headers, status_code=res.status_code, data=res.content)
|
|
@@ -403,7 +404,7 @@ class AccountClient(BaseClient):
|
|
|
403
404
|
|
|
404
405
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'limits', 'global'])
|
|
405
406
|
url = build_url(choice(self.list_hosts), path=path)
|
|
406
|
-
res = self._send_request(url,
|
|
407
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
407
408
|
if res.status_code == codes.ok:
|
|
408
409
|
return next(self._load_json_data(res))
|
|
409
410
|
exc_cls, exc_msg = self._get_exception(headers=res.headers, status_code=res.status_code, data=res.content)
|
|
@@ -421,7 +422,7 @@ class AccountClient(BaseClient):
|
|
|
421
422
|
|
|
422
423
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'limits', 'local'])
|
|
423
424
|
url = build_url(choice(self.list_hosts), path=path)
|
|
424
|
-
res = self._send_request(url,
|
|
425
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
425
426
|
if res.status_code == codes.ok:
|
|
426
427
|
return next(self._load_json_data(res))
|
|
427
428
|
exc_cls, exc_msg = self._get_exception(headers=res.headers, status_code=res.status_code, data=res.content)
|
|
@@ -441,7 +442,7 @@ class AccountClient(BaseClient):
|
|
|
441
442
|
|
|
442
443
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'limits', 'local', rse])
|
|
443
444
|
url = build_url(choice(self.list_hosts), path=path)
|
|
444
|
-
res = self._send_request(url,
|
|
445
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
445
446
|
if res.status_code == codes.ok:
|
|
446
447
|
return next(self._load_json_data(res))
|
|
447
448
|
exc_cls, exc_msg = self._get_exception(headers=res.headers, status_code=res.status_code, data=res.content)
|
|
@@ -463,7 +464,7 @@ class AccountClient(BaseClient):
|
|
|
463
464
|
else:
|
|
464
465
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'usage', 'local'])
|
|
465
466
|
url = build_url(choice(self.list_hosts), path=path)
|
|
466
|
-
res = self._send_request(url,
|
|
467
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
467
468
|
if res.status_code == codes.ok:
|
|
468
469
|
return self._load_json_data(res)
|
|
469
470
|
else:
|
|
@@ -486,7 +487,7 @@ class AccountClient(BaseClient):
|
|
|
486
487
|
else:
|
|
487
488
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'usage', 'global'])
|
|
488
489
|
url = build_url(choice(self.list_hosts), path=path)
|
|
489
|
-
res = self._send_request(url,
|
|
490
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
490
491
|
if res.status_code == codes.ok:
|
|
491
492
|
return self._load_json_data(res)
|
|
492
493
|
else:
|
|
@@ -506,7 +507,7 @@ class AccountClient(BaseClient):
|
|
|
506
507
|
"""
|
|
507
508
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'usage/history', rse])
|
|
508
509
|
url = build_url(choice(self.list_hosts), path=path)
|
|
509
|
-
res = self._send_request(url,
|
|
510
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
510
511
|
if res.status_code == codes.ok:
|
|
511
512
|
return next(self._load_json_data(res))
|
|
512
513
|
else:
|
|
@@ -524,7 +525,7 @@ class AccountClient(BaseClient):
|
|
|
524
525
|
"""
|
|
525
526
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'attr/'])
|
|
526
527
|
url = build_url(choice(self.list_hosts), path=path)
|
|
527
|
-
res = self._send_request(url,
|
|
528
|
+
res = self._send_request(url, method=HTTPMethod.GET)
|
|
528
529
|
if res.status_code == codes.ok:
|
|
529
530
|
return self._load_json_data(res)
|
|
530
531
|
else:
|
|
@@ -548,7 +549,7 @@ class AccountClient(BaseClient):
|
|
|
548
549
|
data = dumps({'key': key, 'value': value})
|
|
549
550
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'attr', key])
|
|
550
551
|
url = build_url(choice(self.list_hosts), path=path)
|
|
551
|
-
res = self._send_request(url,
|
|
552
|
+
res = self._send_request(url, method=HTTPMethod.POST, data=data)
|
|
552
553
|
if res.status_code == codes.created:
|
|
553
554
|
return True
|
|
554
555
|
else:
|
|
@@ -569,7 +570,7 @@ class AccountClient(BaseClient):
|
|
|
569
570
|
|
|
570
571
|
path = '/'.join([self.ACCOUNTS_BASEURL, account, 'attr', key])
|
|
571
572
|
url = build_url(choice(self.list_hosts), path=path)
|
|
572
|
-
res = self._send_request(url,
|
|
573
|
+
res = self._send_request(url, method=HTTPMethod.DELETE, data=None)
|
|
573
574
|
if res.status_code == codes.ok:
|
|
574
575
|
return True
|
|
575
576
|
else:
|
|
@@ -19,6 +19,7 @@ from urllib.parse import quote_plus
|
|
|
19
19
|
from requests.status_codes import codes
|
|
20
20
|
|
|
21
21
|
from rucio.client.baseclient import BaseClient, choice
|
|
22
|
+
from rucio.common.constants import HTTPMethod
|
|
22
23
|
from rucio.common.utils import build_url
|
|
23
24
|
|
|
24
25
|
|
|
@@ -123,7 +124,7 @@ class AccountLimitClient(BaseClient):
|
|
|
123
124
|
path = '/'.join([self.ACCOUNTLIMIT_BASEURL, 'local', account, rse])
|
|
124
125
|
url = build_url(choice(self.list_hosts), path=path)
|
|
125
126
|
|
|
126
|
-
r = self._send_request(url,
|
|
127
|
+
r = self._send_request(url, method=HTTPMethod.POST, data=data)
|
|
127
128
|
|
|
128
129
|
if r.status_code == codes.created:
|
|
129
130
|
return True
|
|
@@ -160,7 +161,7 @@ class AccountLimitClient(BaseClient):
|
|
|
160
161
|
path = '/'.join([self.ACCOUNTLIMIT_BASEURL, 'local', account, rse])
|
|
161
162
|
url = build_url(choice(self.list_hosts), path=path)
|
|
162
163
|
|
|
163
|
-
r = self._send_request(url,
|
|
164
|
+
r = self._send_request(url, method=HTTPMethod.DELETE)
|
|
164
165
|
|
|
165
166
|
if r.status_code == codes.ok:
|
|
166
167
|
return True
|
|
@@ -196,7 +197,7 @@ class AccountLimitClient(BaseClient):
|
|
|
196
197
|
path = '/'.join([self.ACCOUNTLIMIT_BASEURL, 'global', account, quote_plus(rse_expression)])
|
|
197
198
|
url = build_url(choice(self.list_hosts), path=path)
|
|
198
199
|
|
|
199
|
-
r = self._send_request(url,
|
|
200
|
+
r = self._send_request(url, method=HTTPMethod.POST, data=data)
|
|
200
201
|
|
|
201
202
|
if r.status_code == codes.created:
|
|
202
203
|
return True
|
|
@@ -233,7 +234,7 @@ class AccountLimitClient(BaseClient):
|
|
|
233
234
|
path = '/'.join([self.ACCOUNTLIMIT_BASEURL, 'global', account, quote_plus(rse_expression)])
|
|
234
235
|
url = build_url(choice(self.list_hosts), path=path)
|
|
235
236
|
|
|
236
|
-
r = self._send_request(url,
|
|
237
|
+
r = self._send_request(url, method=HTTPMethod.DELETE)
|
|
237
238
|
|
|
238
239
|
if r.status_code == codes.ok:
|
|
239
240
|
return True
|
|
@@ -38,7 +38,7 @@ from requests.status_codes import codes
|
|
|
38
38
|
from rucio import version
|
|
39
39
|
from rucio.common import exception
|
|
40
40
|
from rucio.common.config import config_get, config_get_bool, config_get_int, config_has_section
|
|
41
|
-
from rucio.common.constants import DEFAULT_VO
|
|
41
|
+
from rucio.common.constants import DEFAULT_VO, HTTPMethod
|
|
42
42
|
from rucio.common.exception import CannotAuthenticate, ClientProtocolNotFound, ClientProtocolNotSupported, ConfigNotFound, MissingClientParameter, MissingModuleException, NoAuthInformation, ServerConnectionException
|
|
43
43
|
from rucio.common.extra import import_extras
|
|
44
44
|
from rucio.common.utils import build_url, get_tmp_dir, my_key_generator, parse_response, setup_logger, ssh_sign, wlcg_token_discovery
|
|
@@ -440,14 +440,14 @@ class BaseClient:
|
|
|
440
440
|
self.logger.warning("Waiting {}s due to reason: {} ".format(sleep_time, reason))
|
|
441
441
|
time.sleep(sleep_time)
|
|
442
442
|
|
|
443
|
-
def _send_request(self, url, headers=None,
|
|
443
|
+
def _send_request(self, url, method, headers=None, data=None, params=None, stream=False, get_token=False,
|
|
444
444
|
cert=None, auth=None, verify=None):
|
|
445
445
|
"""
|
|
446
446
|
Helper method to send requests to the rucio server. Gets a new token and retries if an unauthorized error is returned.
|
|
447
447
|
|
|
448
448
|
:param url: the http url to use.
|
|
449
449
|
:param headers: additional http headers to send.
|
|
450
|
-
:param
|
|
450
|
+
:param method: the http request type to use.
|
|
451
451
|
:param data: post data.
|
|
452
452
|
:param params: (optional) Dictionary or bytes to be sent in the url query string.
|
|
453
453
|
:param get_token: (optional) if it is called from a _get_token function.
|
|
@@ -469,28 +469,28 @@ class BaseClient:
|
|
|
469
469
|
if verify is None:
|
|
470
470
|
verify = self.ca_cert or False # Maybe unnecessary but make sure to convert "" -> False
|
|
471
471
|
|
|
472
|
-
self.logger.debug("HTTP request: %s %s" % (
|
|
472
|
+
self.logger.debug("HTTP request: %s %s" % (method.value, url))
|
|
473
473
|
for h, v in hds.items():
|
|
474
474
|
if h == 'X-Rucio-Auth-Token':
|
|
475
475
|
v = "[hidden]"
|
|
476
476
|
self.logger.debug("HTTP header: %s: %s" % (h, v))
|
|
477
|
-
if
|
|
477
|
+
if method != HTTPMethod.GET and data:
|
|
478
478
|
text = self._reduce_data(data)
|
|
479
479
|
self.logger.debug("Request data (length=%d): [%s]" % (len(data), text))
|
|
480
480
|
|
|
481
481
|
result = None
|
|
482
482
|
for retry in range(self.AUTH_RETRIES + 1):
|
|
483
483
|
try:
|
|
484
|
-
if
|
|
484
|
+
if method == HTTPMethod.GET:
|
|
485
485
|
result = self.session.get(url, headers=hds, verify=verify, timeout=self.timeout, params=params, stream=True, cert=cert, auth=auth)
|
|
486
|
-
elif
|
|
486
|
+
elif method == HTTPMethod.PUT:
|
|
487
487
|
result = self.session.put(url, headers=hds, data=data, verify=verify, timeout=self.timeout)
|
|
488
|
-
elif
|
|
488
|
+
elif method == HTTPMethod.POST:
|
|
489
489
|
result = self.session.post(url, headers=hds, data=data, verify=verify, timeout=self.timeout, stream=stream)
|
|
490
|
-
elif
|
|
490
|
+
elif method == HTTPMethod.DELETE:
|
|
491
491
|
result = self.session.delete(url, headers=hds, data=data, verify=verify, timeout=self.timeout)
|
|
492
492
|
else:
|
|
493
|
-
self.logger.debug("Unknown request type %s. Request was not sent" % (
|
|
493
|
+
self.logger.debug("Unknown request type %s. Request was not sent" % (method,))
|
|
494
494
|
return None
|
|
495
495
|
self.logger.debug("HTTP Response: %s %s" % (result.status_code, result.reason))
|
|
496
496
|
if result.status_code in STATUS_CODES_TO_RETRY:
|
|
@@ -537,7 +537,7 @@ class BaseClient:
|
|
|
537
537
|
|
|
538
538
|
url = build_url(self.auth_host, path='auth/userpass')
|
|
539
539
|
|
|
540
|
-
result = self._send_request(url, headers=headers, get_token=True)
|
|
540
|
+
result = self._send_request(url, method=HTTPMethod.GET, headers=headers, get_token=True)
|
|
541
541
|
|
|
542
542
|
if not result:
|
|
543
543
|
# result is either None or not OK.
|
|
@@ -590,7 +590,7 @@ class BaseClient:
|
|
|
590
590
|
return False
|
|
591
591
|
|
|
592
592
|
request_refresh_url = build_url(self.auth_host, path='auth/oidc_refresh')
|
|
593
|
-
refresh_result = self._send_request(request_refresh_url, get_token=True)
|
|
593
|
+
refresh_result = self._send_request(request_refresh_url,method=HTTPMethod.GET, get_token=True)
|
|
594
594
|
if refresh_result.status_code == codes.ok:
|
|
595
595
|
if 'X-Rucio-Auth-Token-Expires' not in refresh_result.headers or \
|
|
596
596
|
'X-Rucio-Auth-Token' not in refresh_result.headers:
|
|
@@ -644,7 +644,7 @@ class BaseClient:
|
|
|
644
644
|
request_auth_url = build_url(self.auth_host, path='auth/oidc')
|
|
645
645
|
# requesting authorization URL specific to the user & Rucio OIDC Client
|
|
646
646
|
self.logger.debug("Initial auth URL request headers %s to files" % str(headers))
|
|
647
|
-
oidc_auth_res = self._send_request(request_auth_url, headers=headers, get_token=True)
|
|
647
|
+
oidc_auth_res = self._send_request(request_auth_url, method=HTTPMethod.GET, headers=headers, get_token=True)
|
|
648
648
|
self.logger.debug("Response headers %s and text %s" % (str(oidc_auth_res.headers), str(oidc_auth_res.text)))
|
|
649
649
|
# with the obtained authorization URL we will contact the Identity Provider to get to the login page
|
|
650
650
|
if 'X-Rucio-OIDC-Auth-URL' not in oidc_auth_res.headers:
|
|
@@ -665,7 +665,7 @@ class BaseClient:
|
|
|
665
665
|
\nthe Rucio authentication server for a token.")
|
|
666
666
|
print("----------------------------------------------")
|
|
667
667
|
while time.time() - start < timeout:
|
|
668
|
-
result = self._send_request(auth_url, headers=headers, get_token=True)
|
|
668
|
+
result = self._send_request(auth_url, method=HTTPMethod.GET, headers=headers, get_token=True)
|
|
669
669
|
if 'X-Rucio-Auth-Token' in result.headers and result.status_code == codes.ok:
|
|
670
670
|
break
|
|
671
671
|
time.sleep(2)
|
|
@@ -675,7 +675,7 @@ class BaseClient:
|
|
|
675
675
|
while count < 3:
|
|
676
676
|
fetchcode = input()
|
|
677
677
|
fetch_url = build_url(self.auth_host, path='auth/oidc_redirect', params=fetchcode)
|
|
678
|
-
result = self._send_request(fetch_url, headers=headers, get_token=True)
|
|
678
|
+
result = self._send_request(fetch_url, method=HTTPMethod.GET, headers=headers, get_token=True)
|
|
679
679
|
if 'X-Rucio-Auth-Token' in result.headers and result.status_code == codes.ok:
|
|
680
680
|
break
|
|
681
681
|
else:
|
|
@@ -688,11 +688,11 @@ class BaseClient:
|
|
|
688
688
|
+ "your password with any 3rd party application, therefore, \n" # NOQA: W503
|
|
689
689
|
+ "we strongly discourage you from following this --oidc-auto approach.") # NOQA: W503
|
|
690
690
|
print("-------------------------------------------------------------------------")
|
|
691
|
-
auth_res = self._send_request(auth_url, get_token=True)
|
|
691
|
+
auth_res = self._send_request(auth_url, method=HTTPMethod.GET, get_token=True)
|
|
692
692
|
# getting the login URL and logging in the user
|
|
693
693
|
login_url = auth_res.url
|
|
694
694
|
start = time.time()
|
|
695
|
-
result = self._send_request(login_url,
|
|
695
|
+
result = self._send_request(login_url, method=HTTPMethod.POST, data=userpass)
|
|
696
696
|
|
|
697
697
|
# if the Rucio OIDC Client configuration does not match the one registered at the Identity Provider
|
|
698
698
|
# the user will get an OAuth error
|
|
@@ -714,7 +714,7 @@ class BaseClient:
|
|
|
714
714
|
self.logger.warning('Automatically authorising request of the following info on behalf of user: %s',
|
|
715
715
|
str(form_data))
|
|
716
716
|
# authorizing info request on behalf of the user until he/she revokes this authorization !
|
|
717
|
-
result = self._send_request(result.url,
|
|
717
|
+
result = self._send_request(result.url, method=HTTPMethod.POST, data=form_data)
|
|
718
718
|
|
|
719
719
|
if not result:
|
|
720
720
|
self.logger.error('Cannot retrieve authentication token!')
|
|
@@ -767,7 +767,7 @@ class BaseClient:
|
|
|
767
767
|
else:
|
|
768
768
|
cert = (client_cert, client_key)
|
|
769
769
|
|
|
770
|
-
result = self._send_request(url, get_token=True, cert=cert)
|
|
770
|
+
result = self._send_request(url, method=HTTPMethod.GET, get_token=True, cert=cert)
|
|
771
771
|
|
|
772
772
|
# Note a response object for a failed request evaluates to false, so we cannot
|
|
773
773
|
# use "not result" here
|
|
@@ -802,7 +802,7 @@ class BaseClient:
|
|
|
802
802
|
|
|
803
803
|
url = build_url(self.auth_host, path='auth/ssh_challenge_token')
|
|
804
804
|
|
|
805
|
-
result = self._send_request(url, get_token=True)
|
|
805
|
+
result = self._send_request(url, method=HTTPMethod.GET, get_token=True)
|
|
806
806
|
|
|
807
807
|
if not result:
|
|
808
808
|
self.logger.error('cannot get ssh_challenge_token')
|
|
@@ -825,7 +825,7 @@ class BaseClient:
|
|
|
825
825
|
|
|
826
826
|
url = build_url(self.auth_host, path='auth/ssh')
|
|
827
827
|
|
|
828
|
-
result = self._send_request(url, headers=headers, get_token=True)
|
|
828
|
+
result = self._send_request(url, method=HTTPMethod.GET, headers=headers, get_token=True)
|
|
829
829
|
|
|
830
830
|
if not result:
|
|
831
831
|
self.logger.error('Cannot retrieve authentication token!')
|
|
@@ -851,7 +851,7 @@ class BaseClient:
|
|
|
851
851
|
|
|
852
852
|
url = build_url(self.auth_host, path='auth/gss')
|
|
853
853
|
|
|
854
|
-
result = self._send_request(url, get_token=True, auth=HTTPKerberosAuth())
|
|
854
|
+
result = self._send_request(url, method=HTTPMethod.GET, get_token=True, auth=HTTPKerberosAuth())
|
|
855
855
|
|
|
856
856
|
if not result:
|
|
857
857
|
self.logger.error('Cannot retrieve authentication token!')
|
|
@@ -876,12 +876,12 @@ class BaseClient:
|
|
|
876
876
|
url = build_url(self.auth_host, path='auth/saml')
|
|
877
877
|
|
|
878
878
|
result = None
|
|
879
|
-
saml_auth_result = self._send_request(url, get_token=True)
|
|
879
|
+
saml_auth_result = self._send_request(url, method=HTTPMethod.GET, get_token=True)
|
|
880
880
|
if saml_auth_result.headers['X-Rucio-Auth-Token']:
|
|
881
881
|
return saml_auth_result.headers['X-Rucio-Auth-Token']
|
|
882
882
|
saml_auth_url = saml_auth_result.headers['X-Rucio-SAML-Auth-URL']
|
|
883
|
-
result = self._send_request(saml_auth_url,
|
|
884
|
-
result = self._send_request(url, get_token=True)
|
|
883
|
+
result = self._send_request(saml_auth_url, method=HTTPMethod.POST, data=userpass, verify=False)
|
|
884
|
+
result = self._send_request(url, method=HTTPMethod.GET, get_token=True)
|
|
885
885
|
|
|
886
886
|
if not result:
|
|
887
887
|
self.logger.error('Cannot retrieve authentication token!')
|
|
@@ -18,6 +18,7 @@ from typing import Any, Optional
|
|
|
18
18
|
from requests.status_codes import codes
|
|
19
19
|
|
|
20
20
|
from rucio.client.baseclient import BaseClient, choice
|
|
21
|
+
from rucio.common.constants import HTTPMethod
|
|
21
22
|
from rucio.common.utils import build_url
|
|
22
23
|
|
|
23
24
|
|
|
@@ -54,7 +55,7 @@ class ConfigClient(BaseClient):
|
|
|
54
55
|
|
|
55
56
|
url = build_url(choice(self.list_hosts), path=path)
|
|
56
57
|
|
|
57
|
-
r = self._send_request(url,
|
|
58
|
+
r = self._send_request(url, method=HTTPMethod.GET)
|
|
58
59
|
if r.status_code == codes.ok:
|
|
59
60
|
return r.json()
|
|
60
61
|
else:
|
|
@@ -90,7 +91,7 @@ class ConfigClient(BaseClient):
|
|
|
90
91
|
Note:
|
|
91
92
|
------
|
|
92
93
|
The format of the /config endpoint was recently changed. We migrated from performing a PUT on
|
|
93
|
-
"/config
|
|
94
|
+
"/config/{section}/{option}/{value}" to sending the parameters using a json-encoded body.
|
|
94
95
|
This was done to fix multiple un-wanted side effects related to how the middleware treats
|
|
95
96
|
values encoded in a path.
|
|
96
97
|
For a smooth transition, we allow both cases for now, but we should migrate to only passing
|
|
@@ -104,11 +105,11 @@ class ConfigClient(BaseClient):
|
|
|
104
105
|
option: value
|
|
105
106
|
}
|
|
106
107
|
})
|
|
107
|
-
r = self._send_request(url,
|
|
108
|
+
r = self._send_request(url, method=HTTPMethod.POST, data=data)
|
|
108
109
|
else:
|
|
109
110
|
path = '/'.join([self.CONFIG_BASEURL, section, option, value])
|
|
110
111
|
url = build_url(choice(self.list_hosts), path=path)
|
|
111
|
-
r = self._send_request(url,
|
|
112
|
+
r = self._send_request(url, method=HTTPMethod.PUT)
|
|
112
113
|
|
|
113
114
|
if r.status_code == codes.created:
|
|
114
115
|
return True
|
|
@@ -140,7 +141,7 @@ class ConfigClient(BaseClient):
|
|
|
140
141
|
path = '/'.join([self.CONFIG_BASEURL, section, option])
|
|
141
142
|
url = build_url(choice(self.list_hosts), path=path)
|
|
142
143
|
|
|
143
|
-
r = self._send_request(url,
|
|
144
|
+
r = self._send_request(url, method=HTTPMethod.DELETE)
|
|
144
145
|
|
|
145
146
|
if r.status_code == codes.ok:
|
|
146
147
|
return True
|
|
@@ -163,7 +164,7 @@ class ConfigClient(BaseClient):
|
|
|
163
164
|
"""
|
|
164
165
|
path = '/'.join([self.CONFIG_BASEURL, section])
|
|
165
166
|
url = build_url(choice(self.list_hosts), path=path)
|
|
166
|
-
r = self._send_request(url,
|
|
167
|
+
r = self._send_request(url, method=HTTPMethod.DELETE)
|
|
167
168
|
|
|
168
169
|
if r.status_code == codes.ok:
|
|
169
170
|
return True
|
|
@@ -15,6 +15,7 @@
|
|
|
15
15
|
from requests.status_codes import codes
|
|
16
16
|
|
|
17
17
|
from rucio.client.baseclient import BaseClient, choice
|
|
18
|
+
from rucio.common.constants import HTTPMethod
|
|
18
19
|
from rucio.common.utils import build_url
|
|
19
20
|
|
|
20
21
|
|
|
@@ -60,7 +61,7 @@ class CredentialClient(BaseClient):
|
|
|
60
61
|
params['op'] = operation
|
|
61
62
|
params['url'] = url
|
|
62
63
|
rurl = build_url(choice(self.list_hosts), path=path, params=params)
|
|
63
|
-
r = self._send_request(rurl,
|
|
64
|
+
r = self._send_request(rurl, method=HTTPMethod.GET)
|
|
64
65
|
|
|
65
66
|
if r.status_code == codes.ok:
|
|
66
67
|
return r.text
|