forked from CMSCompOps/WmAgentScripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRucioClient.py
executable file
·120 lines (107 loc) · 3.67 KB
/
RucioClient.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#!/usr/bin/env python
"""
Encapsulates requests to Rucio API
Requieres:
rucio-client
Environment:
export X509_USER_PROXY=/tmp/x509up_$UID
export RUCIO_HOME=~/.local/
${RUCIO_HOME}/rucio.cfg
"""
from rucio.client import Client
from WMCore.Services.CRIC.CRIC import CRIC
class RucioClient(Client):
"""
A wrapper class for the Rucio client.
"""
def __init__(self, **kwargs):
"""
Default configuration provided directly into the constructor to avoid
the need of an external configuration file.
All arguments passed to the constructor supersede the defaults.
"""
defaultConfig = {
'rucio_host': 'http://cms-rucio.cern.ch',
'auth_host': 'https://cms-rucio-auth.cern.ch',
'auth_type': 'x509_proxy',
'ca_cert': '/etc/grid-security/certificates/',
'account': 'unified'
}
defaultConfig.update(kwargs)
super(RucioClient, self).__init__(**defaultConfig)
self.scope = 'cms'
def getFileCountDataset(self, dataset):
"""
Returns the number of files registered in Rucio
"""
try:
files = list(self.list_files(self.scope, dataset))
except Exception as e:
print(str(e))
return 0
return len(files)
def getFileNamesDataset(self, dataset):
"""
Returns a set of file names in a dataset registered in Rucio
"""
try:
files = list(self.list_files(self.scope, dataset))
except Exception as e:
print(str(e))
return []
fileNames = [_file['name'] for _file in files]
return fileNames
def getBlockNamesDataset(self, dataset):
"""
Returns a set of block names in a dataset registerd in Rucio
"""
try:
blockNames = [block['name'] for block in self.list_content(self.scope, dataset)]
except Exception as e:
print(str(e))
return []
return blockNames
def getFileCountBlock(self, block):
"""
Returns the number of files in a block registered in Rucio
"""
try:
numFiles = self.get_metadata(self.scope, block)['length']
if numFiles is None:
raise Exception("block length in rucio is None")
except Exception as e:
print(str(e))
return 0
return numFiles
def getFileCountPerBlock(self, dataset):
"""
Returns the number of files per block in a dataset registered in Rucio
"""
# we need blocks to be a list of tuples so we can create a set out of this
try:
blocks = []
for block in self.getBlockNamesDataset(dataset):
blocks.append((block, self.getFileCountBlock(block)))
except Exception as e:
print(str(e))
return []
return blocks
def getDatasetLocationsByAccount(self, dataset, account):
"""
Returns the dataset locations for the given account in terms of computing element (not RSE name).
This function assumes that the returned RSE expression includes only one RSE
"""
try:
rules = self.list_did_rules(self.scope, dataset)
RSEs = []
for rule in rules:
if rule['account'] == account:
RSEs.append(rule['rse_expression'])
#RSE to CE conversion
cric = CRIC()
CEs = cric.PNNstoPSNs(RSEs)
except Exception as e:
print "Exception while getting the dataset location"
print(str(e))
return []
return CEs