rucio 37.0.0rc1__py3-none-any.whl

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.

Files changed (487) hide show
  1. rucio/__init__.py +17 -0
  2. rucio/alembicrevision.py +15 -0
  3. rucio/cli/__init__.py +14 -0
  4. rucio/cli/account.py +216 -0
  5. rucio/cli/bin_legacy/__init__.py +13 -0
  6. rucio/cli/bin_legacy/rucio.py +2825 -0
  7. rucio/cli/bin_legacy/rucio_admin.py +2500 -0
  8. rucio/cli/command.py +272 -0
  9. rucio/cli/config.py +72 -0
  10. rucio/cli/did.py +191 -0
  11. rucio/cli/download.py +128 -0
  12. rucio/cli/lifetime_exception.py +33 -0
  13. rucio/cli/replica.py +162 -0
  14. rucio/cli/rse.py +293 -0
  15. rucio/cli/rule.py +158 -0
  16. rucio/cli/scope.py +40 -0
  17. rucio/cli/subscription.py +73 -0
  18. rucio/cli/upload.py +60 -0
  19. rucio/cli/utils.py +226 -0
  20. rucio/client/__init__.py +15 -0
  21. rucio/client/accountclient.py +432 -0
  22. rucio/client/accountlimitclient.py +183 -0
  23. rucio/client/baseclient.py +983 -0
  24. rucio/client/client.py +120 -0
  25. rucio/client/configclient.py +126 -0
  26. rucio/client/credentialclient.py +59 -0
  27. rucio/client/didclient.py +868 -0
  28. rucio/client/diracclient.py +56 -0
  29. rucio/client/downloadclient.py +1783 -0
  30. rucio/client/exportclient.py +44 -0
  31. rucio/client/fileclient.py +50 -0
  32. rucio/client/importclient.py +42 -0
  33. rucio/client/lifetimeclient.py +90 -0
  34. rucio/client/lockclient.py +109 -0
  35. rucio/client/metaconventionsclient.py +140 -0
  36. rucio/client/pingclient.py +44 -0
  37. rucio/client/replicaclient.py +452 -0
  38. rucio/client/requestclient.py +125 -0
  39. rucio/client/richclient.py +317 -0
  40. rucio/client/rseclient.py +746 -0
  41. rucio/client/ruleclient.py +294 -0
  42. rucio/client/scopeclient.py +90 -0
  43. rucio/client/subscriptionclient.py +173 -0
  44. rucio/client/touchclient.py +82 -0
  45. rucio/client/uploadclient.py +969 -0
  46. rucio/common/__init__.py +13 -0
  47. rucio/common/bittorrent.py +234 -0
  48. rucio/common/cache.py +111 -0
  49. rucio/common/checksum.py +168 -0
  50. rucio/common/client.py +122 -0
  51. rucio/common/config.py +788 -0
  52. rucio/common/constants.py +217 -0
  53. rucio/common/constraints.py +17 -0
  54. rucio/common/didtype.py +237 -0
  55. rucio/common/dumper/__init__.py +342 -0
  56. rucio/common/dumper/consistency.py +497 -0
  57. rucio/common/dumper/data_models.py +362 -0
  58. rucio/common/dumper/path_parsing.py +75 -0
  59. rucio/common/exception.py +1208 -0
  60. rucio/common/extra.py +31 -0
  61. rucio/common/logging.py +420 -0
  62. rucio/common/pcache.py +1409 -0
  63. rucio/common/plugins.py +185 -0
  64. rucio/common/policy.py +93 -0
  65. rucio/common/schema/__init__.py +200 -0
  66. rucio/common/schema/generic.py +416 -0
  67. rucio/common/schema/generic_multi_vo.py +395 -0
  68. rucio/common/stomp_utils.py +423 -0
  69. rucio/common/stopwatch.py +55 -0
  70. rucio/common/test_rucio_server.py +154 -0
  71. rucio/common/types.py +483 -0
  72. rucio/common/utils.py +1688 -0
  73. rucio/core/__init__.py +13 -0
  74. rucio/core/account.py +496 -0
  75. rucio/core/account_counter.py +236 -0
  76. rucio/core/account_limit.py +425 -0
  77. rucio/core/authentication.py +620 -0
  78. rucio/core/config.py +437 -0
  79. rucio/core/credential.py +224 -0
  80. rucio/core/did.py +3004 -0
  81. rucio/core/did_meta_plugins/__init__.py +252 -0
  82. rucio/core/did_meta_plugins/did_column_meta.py +331 -0
  83. rucio/core/did_meta_plugins/did_meta_plugin_interface.py +165 -0
  84. rucio/core/did_meta_plugins/elasticsearch_meta.py +407 -0
  85. rucio/core/did_meta_plugins/filter_engine.py +672 -0
  86. rucio/core/did_meta_plugins/json_meta.py +240 -0
  87. rucio/core/did_meta_plugins/mongo_meta.py +229 -0
  88. rucio/core/did_meta_plugins/postgres_meta.py +352 -0
  89. rucio/core/dirac.py +237 -0
  90. rucio/core/distance.py +187 -0
  91. rucio/core/exporter.py +59 -0
  92. rucio/core/heartbeat.py +363 -0
  93. rucio/core/identity.py +301 -0
  94. rucio/core/importer.py +260 -0
  95. rucio/core/lifetime_exception.py +377 -0
  96. rucio/core/lock.py +577 -0
  97. rucio/core/message.py +288 -0
  98. rucio/core/meta_conventions.py +203 -0
  99. rucio/core/monitor.py +448 -0
  100. rucio/core/naming_convention.py +195 -0
  101. rucio/core/nongrid_trace.py +136 -0
  102. rucio/core/oidc.py +1463 -0
  103. rucio/core/permission/__init__.py +161 -0
  104. rucio/core/permission/generic.py +1124 -0
  105. rucio/core/permission/generic_multi_vo.py +1144 -0
  106. rucio/core/quarantined_replica.py +224 -0
  107. rucio/core/replica.py +4483 -0
  108. rucio/core/replica_sorter.py +362 -0
  109. rucio/core/request.py +3091 -0
  110. rucio/core/rse.py +2079 -0
  111. rucio/core/rse_counter.py +185 -0
  112. rucio/core/rse_expression_parser.py +459 -0
  113. rucio/core/rse_selector.py +304 -0
  114. rucio/core/rule.py +4484 -0
  115. rucio/core/rule_grouping.py +1620 -0
  116. rucio/core/scope.py +181 -0
  117. rucio/core/subscription.py +362 -0
  118. rucio/core/topology.py +490 -0
  119. rucio/core/trace.py +375 -0
  120. rucio/core/transfer.py +1531 -0
  121. rucio/core/vo.py +169 -0
  122. rucio/core/volatile_replica.py +151 -0
  123. rucio/daemons/__init__.py +13 -0
  124. rucio/daemons/abacus/__init__.py +13 -0
  125. rucio/daemons/abacus/account.py +116 -0
  126. rucio/daemons/abacus/collection_replica.py +124 -0
  127. rucio/daemons/abacus/rse.py +117 -0
  128. rucio/daemons/atropos/__init__.py +13 -0
  129. rucio/daemons/atropos/atropos.py +242 -0
  130. rucio/daemons/auditor/__init__.py +289 -0
  131. rucio/daemons/auditor/hdfs.py +97 -0
  132. rucio/daemons/auditor/srmdumps.py +355 -0
  133. rucio/daemons/automatix/__init__.py +13 -0
  134. rucio/daemons/automatix/automatix.py +304 -0
  135. rucio/daemons/badreplicas/__init__.py +13 -0
  136. rucio/daemons/badreplicas/minos.py +322 -0
  137. rucio/daemons/badreplicas/minos_temporary_expiration.py +171 -0
  138. rucio/daemons/badreplicas/necromancer.py +196 -0
  139. rucio/daemons/bb8/__init__.py +13 -0
  140. rucio/daemons/bb8/bb8.py +353 -0
  141. rucio/daemons/bb8/common.py +759 -0
  142. rucio/daemons/bb8/nuclei_background_rebalance.py +153 -0
  143. rucio/daemons/bb8/t2_background_rebalance.py +153 -0
  144. rucio/daemons/cache/__init__.py +13 -0
  145. rucio/daemons/cache/consumer.py +133 -0
  146. rucio/daemons/common.py +405 -0
  147. rucio/daemons/conveyor/__init__.py +13 -0
  148. rucio/daemons/conveyor/common.py +562 -0
  149. rucio/daemons/conveyor/finisher.py +529 -0
  150. rucio/daemons/conveyor/poller.py +394 -0
  151. rucio/daemons/conveyor/preparer.py +205 -0
  152. rucio/daemons/conveyor/receiver.py +179 -0
  153. rucio/daemons/conveyor/stager.py +133 -0
  154. rucio/daemons/conveyor/submitter.py +403 -0
  155. rucio/daemons/conveyor/throttler.py +532 -0
  156. rucio/daemons/follower/__init__.py +13 -0
  157. rucio/daemons/follower/follower.py +101 -0
  158. rucio/daemons/hermes/__init__.py +13 -0
  159. rucio/daemons/hermes/hermes.py +534 -0
  160. rucio/daemons/judge/__init__.py +13 -0
  161. rucio/daemons/judge/cleaner.py +159 -0
  162. rucio/daemons/judge/evaluator.py +185 -0
  163. rucio/daemons/judge/injector.py +162 -0
  164. rucio/daemons/judge/repairer.py +154 -0
  165. rucio/daemons/oauthmanager/__init__.py +13 -0
  166. rucio/daemons/oauthmanager/oauthmanager.py +198 -0
  167. rucio/daemons/reaper/__init__.py +13 -0
  168. rucio/daemons/reaper/dark_reaper.py +282 -0
  169. rucio/daemons/reaper/reaper.py +739 -0
  170. rucio/daemons/replicarecoverer/__init__.py +13 -0
  171. rucio/daemons/replicarecoverer/suspicious_replica_recoverer.py +626 -0
  172. rucio/daemons/rsedecommissioner/__init__.py +13 -0
  173. rucio/daemons/rsedecommissioner/config.py +81 -0
  174. rucio/daemons/rsedecommissioner/profiles/__init__.py +24 -0
  175. rucio/daemons/rsedecommissioner/profiles/atlas.py +60 -0
  176. rucio/daemons/rsedecommissioner/profiles/generic.py +452 -0
  177. rucio/daemons/rsedecommissioner/profiles/types.py +93 -0
  178. rucio/daemons/rsedecommissioner/rse_decommissioner.py +280 -0
  179. rucio/daemons/storage/__init__.py +13 -0
  180. rucio/daemons/storage/consistency/__init__.py +13 -0
  181. rucio/daemons/storage/consistency/actions.py +848 -0
  182. rucio/daemons/tracer/__init__.py +13 -0
  183. rucio/daemons/tracer/kronos.py +511 -0
  184. rucio/daemons/transmogrifier/__init__.py +13 -0
  185. rucio/daemons/transmogrifier/transmogrifier.py +762 -0
  186. rucio/daemons/undertaker/__init__.py +13 -0
  187. rucio/daemons/undertaker/undertaker.py +137 -0
  188. rucio/db/__init__.py +13 -0
  189. rucio/db/sqla/__init__.py +52 -0
  190. rucio/db/sqla/constants.py +206 -0
  191. rucio/db/sqla/migrate_repo/__init__.py +13 -0
  192. rucio/db/sqla/migrate_repo/env.py +110 -0
  193. rucio/db/sqla/migrate_repo/versions/01eaf73ab656_add_new_rule_notification_state_progress.py +70 -0
  194. rucio/db/sqla/migrate_repo/versions/0437a40dbfd1_add_eol_at_in_rules.py +47 -0
  195. rucio/db/sqla/migrate_repo/versions/0f1adb7a599a_create_transfer_hops_table.py +59 -0
  196. rucio/db/sqla/migrate_repo/versions/102efcf145f4_added_stuck_at_column_to_rules.py +43 -0
  197. rucio/db/sqla/migrate_repo/versions/13d4f70c66a9_introduce_transfer_limits.py +91 -0
  198. rucio/db/sqla/migrate_repo/versions/140fef722e91_cleanup_distances_table.py +76 -0
  199. rucio/db/sqla/migrate_repo/versions/14ec5aeb64cf_add_request_external_host.py +43 -0
  200. rucio/db/sqla/migrate_repo/versions/156fb5b5a14_add_request_type_to_requests_idx.py +50 -0
  201. rucio/db/sqla/migrate_repo/versions/1677d4d803c8_split_rse_availability_into_multiple.py +68 -0
  202. rucio/db/sqla/migrate_repo/versions/16a0aca82e12_create_index_on_table_replicas_path.py +40 -0
  203. rucio/db/sqla/migrate_repo/versions/1803333ac20f_adding_provenance_and_phys_group.py +45 -0
  204. rucio/db/sqla/migrate_repo/versions/1a29d6a9504c_add_didtype_chck_to_requests.py +60 -0
  205. rucio/db/sqla/migrate_repo/versions/1a80adff031a_create_index_on_rules_hist_recent.py +40 -0
  206. rucio/db/sqla/migrate_repo/versions/1c45d9730ca6_increase_identity_length.py +140 -0
  207. rucio/db/sqla/migrate_repo/versions/1d1215494e95_add_quarantined_replicas_table.py +73 -0
  208. rucio/db/sqla/migrate_repo/versions/1d96f484df21_asynchronous_rules_and_rule_approval.py +74 -0
  209. rucio/db/sqla/migrate_repo/versions/1f46c5f240ac_add_bytes_column_to_bad_replicas.py +43 -0
  210. rucio/db/sqla/migrate_repo/versions/1fc15ab60d43_add_message_history_table.py +50 -0
  211. rucio/db/sqla/migrate_repo/versions/2190e703eb6e_move_rse_settings_to_rse_attributes.py +134 -0
  212. rucio/db/sqla/migrate_repo/versions/21d6b9dc9961_add_mismatch_scheme_state_to_requests.py +64 -0
  213. rucio/db/sqla/migrate_repo/versions/22cf51430c78_add_availability_column_to_table_rses.py +39 -0
  214. rucio/db/sqla/migrate_repo/versions/22d887e4ec0a_create_sources_table.py +64 -0
  215. rucio/db/sqla/migrate_repo/versions/25821a8a45a3_remove_unique_constraint_on_requests.py +51 -0
  216. rucio/db/sqla/migrate_repo/versions/25fc855625cf_added_unique_constraint_to_rules.py +41 -0
  217. rucio/db/sqla/migrate_repo/versions/269fee20dee9_add_repair_cnt_to_locks.py +43 -0
  218. rucio/db/sqla/migrate_repo/versions/271a46ea6244_add_ignore_availability_column_to_rules.py +44 -0
  219. rucio/db/sqla/migrate_repo/versions/277b5fbb41d3_switch_heartbeats_executable.py +53 -0
  220. rucio/db/sqla/migrate_repo/versions/27e3a68927fb_remove_replicas_tombstone_and_replicas_.py +38 -0
  221. rucio/db/sqla/migrate_repo/versions/2854cd9e168_added_rule_id_column.py +47 -0
  222. rucio/db/sqla/migrate_repo/versions/295289b5a800_processed_by_and__at_in_requests.py +45 -0
  223. rucio/db/sqla/migrate_repo/versions/2962ece31cf4_add_nbaccesses_column_in_the_did_table.py +45 -0
  224. rucio/db/sqla/migrate_repo/versions/2af3291ec4c_added_replicas_history_table.py +57 -0
  225. rucio/db/sqla/migrate_repo/versions/2b69addda658_add_columns_for_third_party_copy_read_.py +45 -0
  226. rucio/db/sqla/migrate_repo/versions/2b8e7bcb4783_add_config_table.py +69 -0
  227. rucio/db/sqla/migrate_repo/versions/2ba5229cb54c_add_submitted_at_to_requests_table.py +43 -0
  228. rucio/db/sqla/migrate_repo/versions/2cbee484dcf9_added_column_volume_to_rse_transfer_.py +42 -0
  229. rucio/db/sqla/migrate_repo/versions/2edee4a83846_add_source_to_requests_and_requests_.py +47 -0
  230. rucio/db/sqla/migrate_repo/versions/2eef46be23d4_change_tokens_pk.py +46 -0
  231. rucio/db/sqla/migrate_repo/versions/2f648fc909f3_index_in_rule_history_on_scope_name.py +40 -0
  232. rucio/db/sqla/migrate_repo/versions/3082b8cef557_add_naming_convention_table_and_closed_.py +67 -0
  233. rucio/db/sqla/migrate_repo/versions/30d5206e9cad_increase_oauthrequest_redirect_msg_.py +37 -0
  234. rucio/db/sqla/migrate_repo/versions/30fa38b6434e_add_index_on_service_column_in_the_message_table.py +44 -0
  235. rucio/db/sqla/migrate_repo/versions/3152492b110b_added_staging_area_column.py +77 -0
  236. rucio/db/sqla/migrate_repo/versions/32c7d2783f7e_create_bad_replicas_table.py +60 -0
  237. rucio/db/sqla/migrate_repo/versions/3345511706b8_replicas_table_pk_definition_is_in_.py +72 -0
  238. rucio/db/sqla/migrate_repo/versions/35ef10d1e11b_change_index_on_table_requests.py +42 -0
  239. rucio/db/sqla/migrate_repo/versions/379a19b5332d_create_rse_limits_table.py +65 -0
  240. rucio/db/sqla/migrate_repo/versions/384b96aa0f60_created_rule_history_tables.py +133 -0
  241. rucio/db/sqla/migrate_repo/versions/3ac1660a1a72_extend_distance_table.py +55 -0
  242. rucio/db/sqla/migrate_repo/versions/3ad36e2268b0_create_collection_replicas_updates_table.py +76 -0
  243. rucio/db/sqla/migrate_repo/versions/3c9df354071b_extend_waiting_request_state.py +60 -0
  244. rucio/db/sqla/migrate_repo/versions/3d9813fab443_add_a_new_state_lost_in_badfilesstatus.py +44 -0
  245. rucio/db/sqla/migrate_repo/versions/40ad39ce3160_add_transferred_at_to_requests_table.py +43 -0
  246. rucio/db/sqla/migrate_repo/versions/4207be2fd914_add_notification_column_to_rules.py +64 -0
  247. rucio/db/sqla/migrate_repo/versions/42db2617c364_create_index_on_requests_external_id.py +40 -0
  248. rucio/db/sqla/migrate_repo/versions/436827b13f82_added_column_activity_to_table_requests.py +43 -0
  249. rucio/db/sqla/migrate_repo/versions/44278720f774_update_requests_typ_sta_upd_idx_index.py +44 -0
  250. rucio/db/sqla/migrate_repo/versions/45378a1e76a8_create_collection_replica_table.py +78 -0
  251. rucio/db/sqla/migrate_repo/versions/469d262be19_removing_created_at_index.py +41 -0
  252. rucio/db/sqla/migrate_repo/versions/4783c1f49cb4_create_distance_table.py +59 -0
  253. rucio/db/sqla/migrate_repo/versions/49a21b4d4357_create_index_on_table_tokens.py +44 -0
  254. rucio/db/sqla/migrate_repo/versions/4a2cbedda8b9_add_source_replica_expression_column_to_.py +43 -0
  255. rucio/db/sqla/migrate_repo/versions/4a7182d9578b_added_bytes_length_accessed_at_columns.py +49 -0
  256. rucio/db/sqla/migrate_repo/versions/4bab9edd01fc_create_index_on_requests_rule_id.py +40 -0
  257. rucio/db/sqla/migrate_repo/versions/4c3a4acfe006_new_attr_account_table.py +63 -0
  258. rucio/db/sqla/migrate_repo/versions/4cf0a2e127d4_adding_transient_metadata.py +43 -0
  259. rucio/db/sqla/migrate_repo/versions/4df2c5ddabc0_remove_temporary_dids.py +55 -0
  260. rucio/db/sqla/migrate_repo/versions/50280c53117c_add_qos_class_to_rse.py +45 -0
  261. rucio/db/sqla/migrate_repo/versions/52153819589c_add_rse_id_to_replicas_table.py +43 -0
  262. rucio/db/sqla/migrate_repo/versions/52fd9f4916fa_added_activity_to_rules.py +43 -0
  263. rucio/db/sqla/migrate_repo/versions/53b479c3cb0f_fix_did_meta_table_missing_updated_at_.py +45 -0
  264. rucio/db/sqla/migrate_repo/versions/5673b4b6e843_add_wfms_metadata_to_rule_tables.py +47 -0
  265. rucio/db/sqla/migrate_repo/versions/575767d9f89_added_source_history_table.py +58 -0
  266. rucio/db/sqla/migrate_repo/versions/58bff7008037_add_started_at_to_requests.py +45 -0
  267. rucio/db/sqla/migrate_repo/versions/58c8b78301ab_rename_callback_to_message.py +106 -0
  268. rucio/db/sqla/migrate_repo/versions/5f139f77382a_added_child_rule_id_column.py +55 -0
  269. rucio/db/sqla/migrate_repo/versions/688ef1840840_adding_did_meta_table.py +50 -0
  270. rucio/db/sqla/migrate_repo/versions/6e572a9bfbf3_add_new_split_container_column_to_rules.py +47 -0
  271. rucio/db/sqla/migrate_repo/versions/70587619328_add_comment_column_for_subscriptions.py +43 -0
  272. rucio/db/sqla/migrate_repo/versions/739064d31565_remove_history_table_pks.py +41 -0
  273. rucio/db/sqla/migrate_repo/versions/7541902bf173_add_didsfollowed_and_followevents_table.py +91 -0
  274. rucio/db/sqla/migrate_repo/versions/7ec22226cdbf_new_replica_state_for_temporary_.py +72 -0
  275. rucio/db/sqla/migrate_repo/versions/810a41685bc1_added_columns_rse_transfer_limits.py +49 -0
  276. rucio/db/sqla/migrate_repo/versions/83f991c63a93_correct_rse_expression_length.py +43 -0
  277. rucio/db/sqla/migrate_repo/versions/8523998e2e76_increase_size_of_extended_attributes_.py +43 -0
  278. rucio/db/sqla/migrate_repo/versions/8ea9122275b1_adding_missing_function_based_indices.py +53 -0
  279. rucio/db/sqla/migrate_repo/versions/90f47792bb76_add_clob_payload_to_messages.py +45 -0
  280. rucio/db/sqla/migrate_repo/versions/914b8f02df38_new_table_for_lifetime_model_exceptions.py +68 -0
  281. rucio/db/sqla/migrate_repo/versions/94a5961ddbf2_add_estimator_columns.py +45 -0
  282. rucio/db/sqla/migrate_repo/versions/9a1b149a2044_add_saml_identity_type.py +94 -0
  283. rucio/db/sqla/migrate_repo/versions/9a45bc4ea66d_add_vp_table.py +54 -0
  284. rucio/db/sqla/migrate_repo/versions/9eb936a81eb1_true_is_true.py +72 -0
  285. rucio/db/sqla/migrate_repo/versions/a08fa8de1545_transfer_stats_table.py +55 -0
  286. rucio/db/sqla/migrate_repo/versions/a118956323f8_added_vo_table_and_vo_col_to_rse.py +76 -0
  287. rucio/db/sqla/migrate_repo/versions/a193a275255c_add_status_column_in_messages.py +47 -0
  288. rucio/db/sqla/migrate_repo/versions/a5f6f6e928a7_1_7_0.py +121 -0
  289. rucio/db/sqla/migrate_repo/versions/a616581ee47_added_columns_to_table_requests.py +59 -0
  290. rucio/db/sqla/migrate_repo/versions/a6eb23955c28_state_idx_non_functional.py +52 -0
  291. rucio/db/sqla/migrate_repo/versions/a74275a1ad30_added_global_quota_table.py +54 -0
  292. rucio/db/sqla/migrate_repo/versions/a93e4e47bda_heartbeats.py +64 -0
  293. rucio/db/sqla/migrate_repo/versions/ae2a56fcc89_added_comment_column_to_rules.py +49 -0
  294. rucio/db/sqla/migrate_repo/versions/b0070f3695c8_add_deletedidmeta_table.py +57 -0
  295. rucio/db/sqla/migrate_repo/versions/b4293a99f344_added_column_identity_to_table_tokens.py +43 -0
  296. rucio/db/sqla/migrate_repo/versions/b5493606bbf5_fix_primary_key_for_subscription_history.py +41 -0
  297. rucio/db/sqla/migrate_repo/versions/b7d287de34fd_removal_of_replicastate_source.py +91 -0
  298. rucio/db/sqla/migrate_repo/versions/b818052fa670_add_index_to_quarantined_replicas.py +40 -0
  299. rucio/db/sqla/migrate_repo/versions/b8caac94d7f0_add_comments_column_for_subscriptions_.py +43 -0
  300. rucio/db/sqla/migrate_repo/versions/b96a1c7e1cc4_new_bad_pfns_table_and_bad_replicas_.py +143 -0
  301. rucio/db/sqla/migrate_repo/versions/bb695f45c04_extend_request_state.py +76 -0
  302. rucio/db/sqla/migrate_repo/versions/bc68e9946deb_add_staging_timestamps_to_request.py +50 -0
  303. rucio/db/sqla/migrate_repo/versions/bf3baa1c1474_correct_pk_and_idx_for_history_tables.py +72 -0
  304. rucio/db/sqla/migrate_repo/versions/c0937668555f_add_qos_policy_map_table.py +55 -0
  305. rucio/db/sqla/migrate_repo/versions/c129ccdb2d5_add_lumiblocknr_to_dids.py +43 -0
  306. rucio/db/sqla/migrate_repo/versions/ccdbcd48206e_add_did_type_column_index_on_did_meta_.py +65 -0
  307. rucio/db/sqla/migrate_repo/versions/cebad904c4dd_new_payload_column_for_heartbeats.py +47 -0
  308. rucio/db/sqla/migrate_repo/versions/d1189a09c6e0_oauth2_0_and_jwt_feature_support_adding_.py +146 -0
  309. rucio/db/sqla/migrate_repo/versions/d23453595260_extend_request_state_for_preparer.py +104 -0
  310. rucio/db/sqla/migrate_repo/versions/d6dceb1de2d_added_purge_column_to_rules.py +44 -0
  311. rucio/db/sqla/migrate_repo/versions/d6e2c3b2cf26_remove_third_party_copy_column_from_rse.py +43 -0
  312. rucio/db/sqla/migrate_repo/versions/d91002c5841_new_account_limits_table.py +103 -0
  313. rucio/db/sqla/migrate_repo/versions/e138c364ebd0_extending_columns_for_filter_and_.py +49 -0
  314. rucio/db/sqla/migrate_repo/versions/e59300c8b179_support_for_archive.py +104 -0
  315. rucio/db/sqla/migrate_repo/versions/f1b14a8c2ac1_postgres_use_check_constraints.py +29 -0
  316. rucio/db/sqla/migrate_repo/versions/f41ffe206f37_oracle_global_temporary_tables.py +74 -0
  317. rucio/db/sqla/migrate_repo/versions/f85a2962b021_adding_transfertool_column_to_requests_.py +47 -0
  318. rucio/db/sqla/migrate_repo/versions/fa7a7d78b602_increase_refresh_token_size.py +43 -0
  319. rucio/db/sqla/migrate_repo/versions/fb28a95fe288_add_replicas_rse_id_tombstone_idx.py +37 -0
  320. rucio/db/sqla/migrate_repo/versions/fe1a65b176c9_set_third_party_copy_read_and_write_.py +43 -0
  321. rucio/db/sqla/migrate_repo/versions/fe8ea2fa9788_added_third_party_copy_column_to_rse_.py +43 -0
  322. rucio/db/sqla/models.py +1743 -0
  323. rucio/db/sqla/sautils.py +55 -0
  324. rucio/db/sqla/session.py +529 -0
  325. rucio/db/sqla/types.py +206 -0
  326. rucio/db/sqla/util.py +543 -0
  327. rucio/gateway/__init__.py +13 -0
  328. rucio/gateway/account.py +345 -0
  329. rucio/gateway/account_limit.py +363 -0
  330. rucio/gateway/authentication.py +381 -0
  331. rucio/gateway/config.py +227 -0
  332. rucio/gateway/credential.py +70 -0
  333. rucio/gateway/did.py +987 -0
  334. rucio/gateway/dirac.py +83 -0
  335. rucio/gateway/exporter.py +60 -0
  336. rucio/gateway/heartbeat.py +76 -0
  337. rucio/gateway/identity.py +189 -0
  338. rucio/gateway/importer.py +46 -0
  339. rucio/gateway/lifetime_exception.py +121 -0
  340. rucio/gateway/lock.py +153 -0
  341. rucio/gateway/meta_conventions.py +98 -0
  342. rucio/gateway/permission.py +74 -0
  343. rucio/gateway/quarantined_replica.py +79 -0
  344. rucio/gateway/replica.py +538 -0
  345. rucio/gateway/request.py +330 -0
  346. rucio/gateway/rse.py +632 -0
  347. rucio/gateway/rule.py +437 -0
  348. rucio/gateway/scope.py +100 -0
  349. rucio/gateway/subscription.py +280 -0
  350. rucio/gateway/vo.py +126 -0
  351. rucio/rse/__init__.py +96 -0
  352. rucio/rse/protocols/__init__.py +13 -0
  353. rucio/rse/protocols/bittorrent.py +194 -0
  354. rucio/rse/protocols/cache.py +111 -0
  355. rucio/rse/protocols/dummy.py +100 -0
  356. rucio/rse/protocols/gfal.py +708 -0
  357. rucio/rse/protocols/globus.py +243 -0
  358. rucio/rse/protocols/http_cache.py +82 -0
  359. rucio/rse/protocols/mock.py +123 -0
  360. rucio/rse/protocols/ngarc.py +209 -0
  361. rucio/rse/protocols/posix.py +250 -0
  362. rucio/rse/protocols/protocol.py +361 -0
  363. rucio/rse/protocols/rclone.py +365 -0
  364. rucio/rse/protocols/rfio.py +145 -0
  365. rucio/rse/protocols/srm.py +338 -0
  366. rucio/rse/protocols/ssh.py +414 -0
  367. rucio/rse/protocols/storm.py +195 -0
  368. rucio/rse/protocols/webdav.py +594 -0
  369. rucio/rse/protocols/xrootd.py +302 -0
  370. rucio/rse/rsemanager.py +881 -0
  371. rucio/rse/translation.py +260 -0
  372. rucio/tests/__init__.py +13 -0
  373. rucio/tests/common.py +280 -0
  374. rucio/tests/common_server.py +149 -0
  375. rucio/transfertool/__init__.py +13 -0
  376. rucio/transfertool/bittorrent.py +200 -0
  377. rucio/transfertool/bittorrent_driver.py +50 -0
  378. rucio/transfertool/bittorrent_driver_qbittorrent.py +134 -0
  379. rucio/transfertool/fts3.py +1600 -0
  380. rucio/transfertool/fts3_plugins.py +152 -0
  381. rucio/transfertool/globus.py +201 -0
  382. rucio/transfertool/globus_library.py +181 -0
  383. rucio/transfertool/mock.py +89 -0
  384. rucio/transfertool/transfertool.py +221 -0
  385. rucio/vcsversion.py +11 -0
  386. rucio/version.py +45 -0
  387. rucio/web/__init__.py +13 -0
  388. rucio/web/rest/__init__.py +13 -0
  389. rucio/web/rest/flaskapi/__init__.py +13 -0
  390. rucio/web/rest/flaskapi/authenticated_bp.py +27 -0
  391. rucio/web/rest/flaskapi/v1/__init__.py +13 -0
  392. rucio/web/rest/flaskapi/v1/accountlimits.py +236 -0
  393. rucio/web/rest/flaskapi/v1/accounts.py +1103 -0
  394. rucio/web/rest/flaskapi/v1/archives.py +102 -0
  395. rucio/web/rest/flaskapi/v1/auth.py +1644 -0
  396. rucio/web/rest/flaskapi/v1/common.py +426 -0
  397. rucio/web/rest/flaskapi/v1/config.py +304 -0
  398. rucio/web/rest/flaskapi/v1/credentials.py +213 -0
  399. rucio/web/rest/flaskapi/v1/dids.py +2340 -0
  400. rucio/web/rest/flaskapi/v1/dirac.py +116 -0
  401. rucio/web/rest/flaskapi/v1/export.py +75 -0
  402. rucio/web/rest/flaskapi/v1/heartbeats.py +127 -0
  403. rucio/web/rest/flaskapi/v1/identities.py +285 -0
  404. rucio/web/rest/flaskapi/v1/import.py +132 -0
  405. rucio/web/rest/flaskapi/v1/lifetime_exceptions.py +312 -0
  406. rucio/web/rest/flaskapi/v1/locks.py +358 -0
  407. rucio/web/rest/flaskapi/v1/main.py +91 -0
  408. rucio/web/rest/flaskapi/v1/meta_conventions.py +241 -0
  409. rucio/web/rest/flaskapi/v1/metrics.py +36 -0
  410. rucio/web/rest/flaskapi/v1/nongrid_traces.py +97 -0
  411. rucio/web/rest/flaskapi/v1/ping.py +88 -0
  412. rucio/web/rest/flaskapi/v1/redirect.py +366 -0
  413. rucio/web/rest/flaskapi/v1/replicas.py +1894 -0
  414. rucio/web/rest/flaskapi/v1/requests.py +998 -0
  415. rucio/web/rest/flaskapi/v1/rses.py +2250 -0
  416. rucio/web/rest/flaskapi/v1/rules.py +854 -0
  417. rucio/web/rest/flaskapi/v1/scopes.py +159 -0
  418. rucio/web/rest/flaskapi/v1/subscriptions.py +650 -0
  419. rucio/web/rest/flaskapi/v1/templates/auth_crash.html +80 -0
  420. rucio/web/rest/flaskapi/v1/templates/auth_granted.html +82 -0
  421. rucio/web/rest/flaskapi/v1/traces.py +137 -0
  422. rucio/web/rest/flaskapi/v1/types.py +20 -0
  423. rucio/web/rest/flaskapi/v1/vos.py +278 -0
  424. rucio/web/rest/main.py +18 -0
  425. rucio/web/rest/metrics.py +27 -0
  426. rucio/web/rest/ping.py +27 -0
  427. rucio-37.0.0rc1.data/data/rucio/etc/alembic.ini.template +71 -0
  428. rucio-37.0.0rc1.data/data/rucio/etc/alembic_offline.ini.template +74 -0
  429. rucio-37.0.0rc1.data/data/rucio/etc/globus-config.yml.template +5 -0
  430. rucio-37.0.0rc1.data/data/rucio/etc/ldap.cfg.template +30 -0
  431. rucio-37.0.0rc1.data/data/rucio/etc/mail_templates/rule_approval_request.tmpl +38 -0
  432. rucio-37.0.0rc1.data/data/rucio/etc/mail_templates/rule_approved_admin.tmpl +4 -0
  433. rucio-37.0.0rc1.data/data/rucio/etc/mail_templates/rule_approved_user.tmpl +17 -0
  434. rucio-37.0.0rc1.data/data/rucio/etc/mail_templates/rule_denied_admin.tmpl +6 -0
  435. rucio-37.0.0rc1.data/data/rucio/etc/mail_templates/rule_denied_user.tmpl +17 -0
  436. rucio-37.0.0rc1.data/data/rucio/etc/mail_templates/rule_ok_notification.tmpl +19 -0
  437. rucio-37.0.0rc1.data/data/rucio/etc/rse-accounts.cfg.template +25 -0
  438. rucio-37.0.0rc1.data/data/rucio/etc/rucio.cfg.atlas.client.template +43 -0
  439. rucio-37.0.0rc1.data/data/rucio/etc/rucio.cfg.template +241 -0
  440. rucio-37.0.0rc1.data/data/rucio/etc/rucio_multi_vo.cfg.template +217 -0
  441. rucio-37.0.0rc1.data/data/rucio/requirements.server.txt +297 -0
  442. rucio-37.0.0rc1.data/data/rucio/tools/bootstrap.py +34 -0
  443. rucio-37.0.0rc1.data/data/rucio/tools/merge_rucio_configs.py +144 -0
  444. rucio-37.0.0rc1.data/data/rucio/tools/reset_database.py +40 -0
  445. rucio-37.0.0rc1.data/scripts/rucio +133 -0
  446. rucio-37.0.0rc1.data/scripts/rucio-abacus-account +74 -0
  447. rucio-37.0.0rc1.data/scripts/rucio-abacus-collection-replica +46 -0
  448. rucio-37.0.0rc1.data/scripts/rucio-abacus-rse +78 -0
  449. rucio-37.0.0rc1.data/scripts/rucio-admin +97 -0
  450. rucio-37.0.0rc1.data/scripts/rucio-atropos +60 -0
  451. rucio-37.0.0rc1.data/scripts/rucio-auditor +206 -0
  452. rucio-37.0.0rc1.data/scripts/rucio-automatix +50 -0
  453. rucio-37.0.0rc1.data/scripts/rucio-bb8 +57 -0
  454. rucio-37.0.0rc1.data/scripts/rucio-cache-client +141 -0
  455. rucio-37.0.0rc1.data/scripts/rucio-cache-consumer +42 -0
  456. rucio-37.0.0rc1.data/scripts/rucio-conveyor-finisher +58 -0
  457. rucio-37.0.0rc1.data/scripts/rucio-conveyor-poller +66 -0
  458. rucio-37.0.0rc1.data/scripts/rucio-conveyor-preparer +37 -0
  459. rucio-37.0.0rc1.data/scripts/rucio-conveyor-receiver +44 -0
  460. rucio-37.0.0rc1.data/scripts/rucio-conveyor-stager +76 -0
  461. rucio-37.0.0rc1.data/scripts/rucio-conveyor-submitter +139 -0
  462. rucio-37.0.0rc1.data/scripts/rucio-conveyor-throttler +104 -0
  463. rucio-37.0.0rc1.data/scripts/rucio-dark-reaper +53 -0
  464. rucio-37.0.0rc1.data/scripts/rucio-dumper +160 -0
  465. rucio-37.0.0rc1.data/scripts/rucio-follower +44 -0
  466. rucio-37.0.0rc1.data/scripts/rucio-hermes +54 -0
  467. rucio-37.0.0rc1.data/scripts/rucio-judge-cleaner +89 -0
  468. rucio-37.0.0rc1.data/scripts/rucio-judge-evaluator +137 -0
  469. rucio-37.0.0rc1.data/scripts/rucio-judge-injector +44 -0
  470. rucio-37.0.0rc1.data/scripts/rucio-judge-repairer +44 -0
  471. rucio-37.0.0rc1.data/scripts/rucio-kronos +44 -0
  472. rucio-37.0.0rc1.data/scripts/rucio-minos +53 -0
  473. rucio-37.0.0rc1.data/scripts/rucio-minos-temporary-expiration +50 -0
  474. rucio-37.0.0rc1.data/scripts/rucio-necromancer +120 -0
  475. rucio-37.0.0rc1.data/scripts/rucio-oauth-manager +63 -0
  476. rucio-37.0.0rc1.data/scripts/rucio-reaper +83 -0
  477. rucio-37.0.0rc1.data/scripts/rucio-replica-recoverer +248 -0
  478. rucio-37.0.0rc1.data/scripts/rucio-rse-decommissioner +66 -0
  479. rucio-37.0.0rc1.data/scripts/rucio-storage-consistency-actions +74 -0
  480. rucio-37.0.0rc1.data/scripts/rucio-transmogrifier +77 -0
  481. rucio-37.0.0rc1.data/scripts/rucio-undertaker +76 -0
  482. rucio-37.0.0rc1.dist-info/METADATA +92 -0
  483. rucio-37.0.0rc1.dist-info/RECORD +487 -0
  484. rucio-37.0.0rc1.dist-info/WHEEL +5 -0
  485. rucio-37.0.0rc1.dist-info/licenses/AUTHORS.rst +100 -0
  486. rucio-37.0.0rc1.dist-info/licenses/LICENSE +201 -0
  487. rucio-37.0.0rc1.dist-info/top_level.txt +1 -0
@@ -0,0 +1,71 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Copyright European Organization for Nuclear Research (CERN) since 2012
3
+ #
4
+ # Licensed under the Apache License, Version 2.0 (the "License");
5
+ # you may not use this file except in compliance with the License.
6
+ # You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS,
12
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ # See the License for the specific language governing permissions and
14
+ # limitations under the License.
15
+
16
+ [alembic]
17
+
18
+ # Choose one of the databases+schema below
19
+ # Oracle, PostgreSQL, MySQL/MariaDB are fully supported
20
+
21
+ sqlalchemy.url=oracle://user:pass@servicename
22
+ version_table_schema=rucio
23
+
24
+ #sqlalchemy.url=postgresql+psycopg://rucio:rucio@psql-hostname:5432/rucio
25
+ #version_table_schema=rucio
26
+
27
+ #sqlalchemy.url=mysql+pymysql://rucio:rucio@rucio-hostname:3306/rucio
28
+ #version_table_schema=rucio
29
+
30
+ # SQLite doesn't support our migrations
31
+ # Only enable it to correctly skip the alembic unittests on SQLite
32
+ default = sqlite:////tmp/rucio.db
33
+ version_table_schema=rucio
34
+
35
+ # Do not modify this
36
+ script_location = lib/rucio/db/sqla/migrate_repo/
37
+
38
+ # Logging configuration
39
+ [loggers]
40
+ keys = root,sqlalchemy,alembic
41
+
42
+ [handlers]
43
+ keys = console
44
+
45
+ [formatters]
46
+ keys = generic
47
+
48
+ [logger_root]
49
+ level = WARN
50
+ handlers = console
51
+ qualname =
52
+
53
+ [logger_sqlalchemy]
54
+ level = WARN
55
+ handlers =
56
+ qualname = sqlalchemy.engine
57
+
58
+ [logger_alembic]
59
+ level = INFO
60
+ handlers =
61
+ qualname = alembic
62
+
63
+ [handler_console]
64
+ class = StreamHandler
65
+ args = (sys.stderr,)
66
+ level = NOTSET
67
+ formatter = generic
68
+
69
+ [formatter_generic]
70
+ format = %(levelname)-5.5s [%(name)s] %(message)s
71
+ datefmt = %H:%M:%S
@@ -0,0 +1,74 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Copyright European Organization for Nuclear Research (CERN) since 2012
3
+ #
4
+ # Licensed under the Apache License, Version 2.0 (the "License");
5
+ # you may not use this file except in compliance with the License.
6
+ # You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS,
12
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ # See the License for the specific language governing permissions and
14
+ # limitations under the License.
15
+
16
+ [alembic]
17
+
18
+ # Choose one of the databases+schema below
19
+ # Oracle, PostgreSQL, MySQL/MariaDB are fully supported
20
+
21
+ #sqlalchemy.url=oracle://user:pass@servicename
22
+ #version_table_schema=rucio
23
+
24
+ #sqlalchemy.url=postgresql+psycopg://rucio:rucio@psql-hostname:5432/rucio
25
+ #version_table_schema=rucio
26
+
27
+ #sqlalchemy.url=mysql+pymysql://rucio:rucio@rucio-hostname:3306/rucio
28
+ #version_table_schema=rucio
29
+
30
+ # Select DB dialect for offline mode migration, options: [sqlite, mysql, postgresql, oracle]
31
+ # If this option is specified, sqlalchemy.url is not needed
32
+ dialect=postgresql
33
+
34
+ # Specify starting revision for offline mode migration
35
+ # If this is not specified, alembic will produce SQL statements for all revisions
36
+ starting_rev=
37
+
38
+ # Do not modify this
39
+ script_location = lib/rucio/db/sqla/migrate_repo/
40
+
41
+ # Logging configuration
42
+ [loggers]
43
+ keys = root,sqlalchemy,alembic
44
+
45
+ [handlers]
46
+ keys = console
47
+
48
+ [formatters]
49
+ keys = generic
50
+
51
+ [logger_root]
52
+ level = WARN
53
+ handlers = console
54
+ qualname =
55
+
56
+ [logger_sqlalchemy]
57
+ level = WARN
58
+ handlers =
59
+ qualname = sqlalchemy.engine
60
+
61
+ [logger_alembic]
62
+ level = INFO
63
+ handlers =
64
+ qualname = alembic
65
+
66
+ [handler_console]
67
+ class = StreamHandler
68
+ args = (sys.stderr,)
69
+ level = NOTSET
70
+ formatter = generic
71
+
72
+ [formatter_generic]
73
+ format = %(levelname)-5.5s [%(name)s] %(message)s
74
+ datefmt = %H:%M:%S
@@ -0,0 +1,5 @@
1
+ globus:
2
+ apps:
3
+ my-globus-auth-client-name:
4
+ client_id: a622
5
+ refresh_token: AgK1
@@ -0,0 +1,30 @@
1
+ # Copyright European Organization for Nuclear Research (CERN)
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # You may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
6
+ #
7
+ # Authors:
8
+ # - Cheng-Hsi Chao, <cheng-hsi.chaos@cern.ch>, 2014
9
+
10
+ [ldap]
11
+ ldap_host = ldap-host.domain.name
12
+ baseDN = dc=foo,dc=bar,dc=domain,dc=
13
+ searchFilter = (objectClass=OpenLDAPperson)
14
+
15
+ # set as DEFAULT to use anonymous bind
16
+ username = DEFAULT
17
+ # Leave blank for prompt
18
+ password =
19
+
20
+ cacertfile = /etc/grid-security/certificates
21
+ certfile = /etc/grid-security/hostcert.pem
22
+ keyfile = /etc/grid-security/hostkey.pem
23
+
24
+ [attributes]
25
+ accounts = uid
26
+ uid = uid
27
+ email = mail
28
+ identity = gecos
29
+ # DEFAULT set as X509
30
+ auth_type = DEFAULT
@@ -0,0 +1,38 @@
1
+ A new rule has been requested for approval in Rucio.
2
+
3
+ Rule description:
4
+
5
+ ID: $rule_id
6
+ Creation date: $created_at
7
+ Expiration date: $expires_at
8
+ Rule owner: $account ($email)
9
+ RSE Expression: $rse_expression
10
+ Comment: $comment
11
+ Rucio UI: https://rucio-ui.cern.ch/rule?rule_id=$rule_id
12
+
13
+ DID description:
14
+
15
+ Scope:Name: $scope:$name
16
+ Type: $did_type
17
+ Number of files: $length
18
+ Total size: $bytes
19
+ Open: $open
20
+ Complete replicas: $complete_rses
21
+ Rucio UI: https://rucio-ui.cern.ch/did?scope=$scope&name=$name
22
+
23
+ RSE description:
24
+ Target RSE: $target_rse
25
+ Free space: $free_space
26
+ Free space after: $free_space_after
27
+
28
+ Action:
29
+
30
+ Approvers: mailto:$approvers
31
+ Approve: https://rucio-ui.cern.ch/rule?rule_id=$rule_id&action=approve&ui_account=$approver
32
+ Deny: https://rucio-ui.cern.ch/rule?rule_id=$rule_id&action=deny&ui_account=$approver
33
+
34
+
35
+
36
+ --
37
+ To update the quotas of this RSE go to: https://rucio-ui.cern.ch/r2d2/manage_quota?rse=$rse_expression
38
+ THIS IS AN AUTOMATICALLY GENERATED MESSAGE
@@ -0,0 +1,4 @@
1
+ Replication rule $rule_id has been approved by $approver.
2
+
3
+ --
4
+ THIS IS AN AUTOMATICALLY GENERATED MESSAGE
@@ -0,0 +1,17 @@
1
+ The replication rule has been APPROVED by $approver.
2
+
3
+ Rule description:
4
+ ID: $rule_id
5
+ RSE Expression: $rse_expression
6
+ Expires at: $expires_at
7
+ Comment: $comment
8
+ Rucio UI: https://rucio-ui.cern.ch/rule?rule_id=$rule_id
9
+
10
+ DID description:
11
+
12
+ Scope:Name: $scope:$name
13
+ Type: $did_type
14
+ Rucio UI: https://rucio-ui.cern.ch/did?scope=$scope&name=$name
15
+
16
+ --
17
+ THIS IS AN AUTOMATICALLY GENERATED MESSAGE
@@ -0,0 +1,6 @@
1
+ Replication rule $rule_id has been denied by $approver.
2
+
3
+ Reason: $reason
4
+
5
+ --
6
+ THIS IS AN AUTOMATICALLY GENERATED MESSAGE
@@ -0,0 +1,17 @@
1
+ The replication rule has been DENIED by $approver.
2
+
3
+ Rule description:
4
+ ID: $rule_id
5
+ RSE Expression: $rse_expression
6
+ Comment: $comment
7
+ Rucio UI: https://rucio-ui.cern.ch/rule?rule_id=$rule_id
8
+ Reason: $reason
9
+
10
+ DID description:
11
+
12
+ Scope:Name: $scope:$name
13
+ Type: $did_type
14
+ Rucio UI: https://rucio-ui.cern.ch/did?scope=$scope&name=$name
15
+
16
+ --
17
+ THIS IS AN AUTOMATICALLY GENERATED MESSAGE
@@ -0,0 +1,19 @@
1
+ The replication rule $rule_id has been transferred successful.
2
+
3
+ Rule description:
4
+
5
+ ID: $rule_id
6
+ Creation date: $created_at
7
+ Expiration date: $expires_at
8
+ RSE Expression: $rse_expression
9
+ Comment: $comment
10
+ Rucio UI: https://rucio-ui.cern.ch/rule?rule_id=$rule_id
11
+
12
+ DID description:
13
+
14
+ Scope:Name: $scope:$name
15
+ Type: $did_type
16
+ Rucio UI: https://rucio-ui.cern.ch/did?scope=$scope&name=$name
17
+
18
+ --
19
+ THIS IS AN AUTOMATICALLY GENERATED MESSAGE
@@ -0,0 +1,25 @@
1
+ {
2
+ "lxplus.cern.ch":{
3
+ "username":"USERNAME",
4
+ "password":"PASSWORD",
5
+ "host":"lxplus.cern.ch"
6
+ },
7
+ "swift.cern.ch": {
8
+ "access_key": "ACCESSKEY",
9
+ "secret_key": "PASSWORD",
10
+ "host_base": "swift.cern.ch",
11
+ "host_bucket": "swift.cern.ch",
12
+ "progress_meter": "False",
13
+ "skip_existing": "False"
14
+ },
15
+ "posix": {},
16
+ "DESY-ZN_SCRATCHDISK": {
17
+ "auth_type": "cert",
18
+ "timeout":300
19
+ },
20
+ "TAIWAN-LCG2_PPSSCRATCHDISK": {
21
+ "cert": ["/tmp/x509up","/tmp/x509up"],
22
+ "auth_type": "cert",
23
+ "timeout":300
24
+ }
25
+ }
@@ -0,0 +1,43 @@
1
+ # Copyright 2014-2021 CERN
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+ # Authors:
16
+ # - Vincent Garonne <vincent.garonne@cern.ch>, 2014
17
+ # - Mario Lassnig <mario.lassnig@cern.ch>, 2018
18
+ # - Nicolo Magini <nicolo.magini@cern.ch>, 2018
19
+ # - Tomas Javurek <tomas.javurek@cern.ch>, 2019
20
+ # - David Población Criado <david.poblacion.criado@cern.ch>, 2021
21
+
22
+ [common]
23
+
24
+ [client]
25
+ rucio_host = https://voatlasrucio-server-prod.cern.ch:443
26
+ auth_host = https://voatlasrucio-auth-prod.cern.ch:443
27
+ client_x509_proxy = $X509_USER_PROXY
28
+ request_retries = 3
29
+ auth_type = x509_proxy
30
+
31
+ [policy]
32
+ package = atlas_rucio_policy_package
33
+ #permission = atlas
34
+ #schema = atlas
35
+ lfn2pfn_algorithm_default = hash
36
+ support = hn-atlas-dist-analysis-help@cern.ch
37
+ support_rucio = https://github.com/rucio/rucio/issues/
38
+
39
+ [upload]
40
+ #transfer_timeout = 3600
41
+
42
+ [download]
43
+ #transfer_timeout = 3600
@@ -0,0 +1,241 @@
1
+ # Copyright 2012-2022 CERN
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+ # Authors:
16
+ # - Mario Lassnig <mario.lassnig@cern.ch>, 2012-2020
17
+ # - Vincent Garonne <vincent.garonne@cern.ch>, 2012-2017
18
+ # - Thomas Beermann <thomas.beermann@cern.ch>, 2012-2021
19
+ # - Luis Rodrigues <lfrodrigues@gmail.com>, 2013
20
+ # - Cedric Serfon <cedric.serfon@cern.ch>, 2013
21
+ # - Wen Guan <wen.guan@cern.ch>, 2014
22
+ # - Fernando López <felopez@cern.ch>, 2015
23
+ # - Martin Barisits <martin.barisits@cern.ch>, 2015-2021
24
+ # - Vitjan Zavrtanik <vitjan.zavrtanik@cern.ch>, 2017
25
+ # - Stefan Prenner <stefan.prenner@cern.ch>, 2018
26
+ # - Nicolo Magini <nicolo.magini@cern.ch>, 2018
27
+ # - Frank Berghaus <berghaus@cern.ch>, 2019
28
+ # - Dilaksun Bavarajan <dilaksun.bavarajan@cern.ch>, 2019
29
+ # - James Perry <j.perry@epcc.ed.ac.uk>, 2019
30
+ # - Ruturaj Gujar <ruturaj.gujar23@gmail.com>, 2019
31
+ # - Jaroslav Guenther <jaroslav.guenther@cern.ch>, 2019
32
+ # - Benedikt Ziemons <benedikt.ziemons@cern.ch>, 2020-2021
33
+ # - David Población Criado <david.poblacion.criado@cern.ch>, 2021
34
+ # - Radu Carpa <radu.carpa@cern.ch>, 2021-2022
35
+ # - Rakshita Varadarajan <rakshitajps@gmail.com>, 2021
36
+ # - Joel Dierkes <joel.dierkes@cern.ch>, 2021
37
+
38
+ [common]
39
+ logdir = /var/log/rucio
40
+ loglevel = DEBUG
41
+ logformat = %%(asctime)s\t%%(process)d\t%%(levelname)s\t%%(message)s
42
+ mailtemplatedir=/opt/rucio/etc/mail_templates
43
+
44
+ [client]
45
+ rucio_host = https://rucio-server-prod.cern.ch:443
46
+ auth_host = https://rucio-auth-prod.cern.ch:443
47
+ auth_type = userpass
48
+ #auth_type = gss
49
+ #auth_type = x509_proxy
50
+ #auth_type = ssh
51
+ username = ddmlab
52
+ password = secret
53
+ ca_cert = /opt/rucio/etc/web/ca.crt
54
+ #client_cert = /opt/rucio/etc/web/client.crt
55
+ #client_key = /opt/rucio/etc/web/client.key
56
+ #client_x509_proxy = $X509_USER_PROXY
57
+ #ssh_private_key = $HOME/.ssh/id_rsa
58
+ account = root
59
+ request_retries = 3
60
+ protocol_stat_retries = 6
61
+
62
+ [upload]
63
+ #transfer_timeout = 3600
64
+ #preferred_impl = xrootd, rclone
65
+
66
+ [download]
67
+ #transfer_timeout = 3600
68
+ #preferred_impl = xrootd, rclone
69
+
70
+ [core]
71
+ geoip_licence_key = LICENCEKEYGOESHERE # Get a free licence key at https://www.maxmind.com/en/geolite2/signup
72
+ default_mail_from = spamspamspam@cern.ch
73
+
74
+ [database]
75
+ default = sqlite:////tmp/rucio.db
76
+ #default = oracle://_____________:___________@(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=_________)(PORT=______))(ADDRESS=(PROTOCOL=TCP)(HOST=_________)(PORT=_____))(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=__________)))
77
+ #default = oracle://_____________:___________@(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=______))(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=_____________)))
78
+ #schema=atlas_rucio # only for cern oracle
79
+ #default = mysql+pymysql://rucio:rucio@localhost/rucio
80
+ #default = postgresql+psycopg://rucio:rucio@localhost/rucio
81
+ pool_recycle=3600
82
+ echo=0
83
+ pool_reset_on_return=rollback
84
+ # Uncomment the following line to disable database connection pooling.
85
+ #poolclass = nullpool
86
+
87
+ [bootstrap]
88
+ # Hardcoded salt = 0, String = secret, Python: hashlib.sha256("0secret").hexdigest()
89
+ userpass_identity = ddmlab
90
+ userpass_pwd = 2ccee6f6dd1bc2269cddd7cd5e47578e98e430539807c36df23fab7dd13e7583
91
+ userpass_email = ph-adp-ddm-lab@cern.ch
92
+
93
+ # Default DDMLAB client certificate from /opt/rucio/etc/web/client.crt
94
+ x509_identity = emailAddress=ph-adp-ddm-lab@cern.ch,CN=DDMLAB Client Certificate,OU=PH-ADP-CO,O=CERN,ST=Geneva,C=CH
95
+ x509_email = ph-adp-ddm-lab@cern.ch
96
+
97
+ # Default DDMLAB cern account
98
+ gss_identity = ddmlab@CERN.CH
99
+ gss_email = ph-adp-ddm-lab@cern.ch
100
+
101
+ # Default DDMLAB ssh key
102
+ ssh_identity = ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAq5LySllrQFpPL614sulXQ7wnIr1aGhGtl8b+HCB/0FhMSMTHwSjX78UbfqEorZV16rXrWPgUpvcbp2hqctw6eCbxwqcgu3uGWaeS5A0iWRw7oXUh6ydnVy89zGzX1FJFFDZ+AgiZ3ytp55tg1bjqqhK1OSC0pJxdNe878TRVVo5MLI0S/rZY2UovCSGFaQG2iLj14wz/YqI7NFMUuJFR4e6xmNsOP7fCZ4bGMsmnhR0GmY0dWYTupNiP5WdYXAfKExlnvFLTlDI5Mgh4Z11NraQ8pv4YE1woolYpqOc/IMMBBXFniTT4tC7cgikxWb9ZmFe+r4t6yCDpX4IL8L5GOQ== ddmlab
103
+ ssh_email = ph-adp-ddm-lab@cern.ch
104
+
105
+ # Default DDMLAB SAML Name ID
106
+ saml_id = ddmlab
107
+ saml_email = ph-adp-ddm-lab@cern.ch
108
+
109
+ [monitor]
110
+ carbon_server = rucio-graphite-int.cern.ch
111
+ carbon_port = 8125
112
+ user_scope = your_username
113
+ enable_metrics = False
114
+ metrics_port = 8080
115
+
116
+ [conveyor]
117
+ scheme = srm,gsiftp,root,http,https
118
+ transfertool = fts3
119
+ ftshosts = https://fts3-pilot.cern.ch:8446, https://fts3-pilot.cern.ch:8446
120
+ cacert = /opt/rucio/etc/web/ca.crt
121
+ usercert = /opt/rucio/tools/x509up
122
+
123
+ [messaging-fts3]
124
+ port = 61123
125
+ ssl_key_file = /home/mario/.ssh/hostkey.pem
126
+ ssl_cert_file = /home/mario/.ssh/hostcert.pem
127
+ destination = /topic/transfer.fts_monitoring_queue_state
128
+ brokers = dashb-test-mb.cern.ch
129
+ voname = atlas
130
+
131
+ [messaging-hermes]
132
+ username = ____
133
+ password = ____
134
+ port = 61023
135
+ nonssl_port = 61013
136
+ use_ssl = True
137
+ ssl_key_file = /etc/grid-security/hostkey.pem
138
+ ssl_cert_file = /etc/grid-security/hostcert.pem
139
+ destination = /topic/rucio.events
140
+ brokers = localhost
141
+ voname = atlas
142
+ email_from = Rucio <spamspamspam@cern.ch>
143
+ email_test = spamspamspam@cern.ch
144
+
145
+ [transmogrifier]
146
+ maxdids = 100000
147
+
148
+ [accounts]
149
+ # These are accounts that can write into scopes owned by another account
150
+ special_accounts = panda, tier0
151
+
152
+ [trace]
153
+ tracedir = /var/log/rucio/trace
154
+ brokers=localhost
155
+ port=61013
156
+ username = _________
157
+ password = _________
158
+ topic = /topic/rucio.tracer
159
+ trace_host = https://rucio-server-prod.cern.ch:443
160
+
161
+ [tracer-kronos]
162
+ brokers=localhost
163
+ port=61013
164
+ ssl_key_file = /etc/grid-security/hostkey.pem
165
+ ssl_cert_file = /etc/grid-security/hostcert.pem
166
+ queue = /queue/Consumer.kronos.rucio.tracer
167
+ prefetch_size = 10
168
+ chunksize = 10
169
+ subscription_id = rucio-tracer-listener
170
+ use_ssl = False
171
+ reconnect_attempts = 100
172
+ excluded_usrdns = CN=proxy,CN=Robot: Ganga Robot,CN=722147,CN=gangarbt,OU=Users,OU=Organic Units,DC=cern,DC=ch
173
+ username = _________
174
+ password = _________
175
+ dataset_wait = 60
176
+
177
+ [injector]
178
+ file = /opt/rucio/tools/test.file.1000
179
+ bytes = 1000
180
+ md5 = fd21ce524a9e45060fd3f62c4ef6a386
181
+ adler32 = 52590737
182
+ #file = /opt/rucio/tools/test.file.1G
183
+ #bytes = 1000000000
184
+ #md5sum = 1a3031f43cc0c0cf4f8341920a9faf52
185
+ #adler32 = 5ff2d417
186
+
187
+ [alembic]
188
+ cfg = /opt/rucio/etc/alembic.ini
189
+
190
+ [messaging-cache]
191
+ port = 61023
192
+ ssl_key_file = /etc/grid-security/hostkey.pem
193
+ ssl_cert_file = /etc/grid-security/hostcert.pem
194
+ destination = /topic/rucio.fax
195
+ brokers = localhost
196
+ voname = atlas
197
+ account = cache_mb
198
+
199
+ [test]
200
+ cacert = /opt/rucio/etc/web/ca.crt
201
+ #cacert = /etc/pki/tls/certs/CERN-bundle.pem
202
+ usercert = /opt/rucio/etc/web/usercert.pem
203
+ #usercert = /home/mario/.ssh/usercert_with_key.pem
204
+
205
+ [nagios]
206
+ proxy = /opt/rucio/etc/ddmadmin.proxy.nagios
207
+ rfcproxy = /opt/rucio/etc/ddmusr01.rfc.proxy
208
+ fts_servers = https://fts3-pilot.cern.ch:8446, https://fts3-devel.cern.ch:8446, https://fts3.cern.ch:8446, https://lcgfts3.gridpp.rl.ac.uk:8446, https://fts3-test.gridpp.rl.ac.uk:8446, https://fts.usatlas.bnl.gov:8446
209
+
210
+ [auditor]
211
+ cache = /opt/rucio/auditor-cache
212
+ results = /opt/rucio/auditor-results
213
+
214
+ [policy]
215
+ package = atlas_rucio_policy_package
216
+ permission = atlas
217
+ schema = atlas
218
+ extract_scope = atlas
219
+ lfn2pfn_algorithm_default = hash
220
+ support = hn-atlas-dist-analysis-help@cern.ch
221
+ support_rucio = https://github.com/rucio/rucio/issues/
222
+
223
+ [webui]
224
+ usercert = /opt/rucio/etc/usercert_with_key.pem
225
+
226
+ [credentials]
227
+ gcs = /opt/rucio/etc/google-cloud-storage-test.json
228
+ signature_lifetime = 3600
229
+
230
+ [saml]
231
+ config_path = /opt/rucio/lib/rucio/web/ui/common/saml/
232
+
233
+ [oidc]
234
+ idpsecrets = /opt/rucio/etc/idpsecrets.json
235
+ admin_issuer = wlcg
236
+
237
+ [api]
238
+ #endpoints = accountlimits, accounts, config, credentials, dids, export, heartbeats, identities, import, lifetime_exceptions, locks, meta, ping, redirect, replicas, requests, rses, rules, scopes, subscriptions
239
+
240
+ [transfers]
241
+ srm_https_compatibility = False