wmglobalqueue 2.4.5.1__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.
Files changed (347) hide show
  1. Utils/CPMetrics.py +270 -0
  2. Utils/CertTools.py +100 -0
  3. Utils/EmailAlert.py +50 -0
  4. Utils/ExtendedUnitTestCase.py +62 -0
  5. Utils/FileTools.py +182 -0
  6. Utils/IteratorTools.py +80 -0
  7. Utils/MathUtils.py +31 -0
  8. Utils/MemoryCache.py +119 -0
  9. Utils/Patterns.py +24 -0
  10. Utils/Pipeline.py +137 -0
  11. Utils/PortForward.py +97 -0
  12. Utils/ProcFS.py +112 -0
  13. Utils/ProcessStats.py +194 -0
  14. Utils/PythonVersion.py +17 -0
  15. Utils/Signals.py +36 -0
  16. Utils/TemporaryEnvironment.py +27 -0
  17. Utils/Throttled.py +227 -0
  18. Utils/Timers.py +130 -0
  19. Utils/Timestamps.py +86 -0
  20. Utils/TokenManager.py +143 -0
  21. Utils/Tracing.py +60 -0
  22. Utils/TwPrint.py +98 -0
  23. Utils/Utilities.py +318 -0
  24. Utils/__init__.py +11 -0
  25. Utils/wmcoreDTools.py +707 -0
  26. WMCore/ACDC/Collection.py +57 -0
  27. WMCore/ACDC/CollectionTypes.py +12 -0
  28. WMCore/ACDC/CouchCollection.py +67 -0
  29. WMCore/ACDC/CouchFileset.py +238 -0
  30. WMCore/ACDC/CouchService.py +73 -0
  31. WMCore/ACDC/DataCollectionService.py +485 -0
  32. WMCore/ACDC/Fileset.py +94 -0
  33. WMCore/ACDC/__init__.py +11 -0
  34. WMCore/Algorithms/Alarm.py +39 -0
  35. WMCore/Algorithms/MathAlgos.py +274 -0
  36. WMCore/Algorithms/MiscAlgos.py +67 -0
  37. WMCore/Algorithms/ParseXMLFile.py +115 -0
  38. WMCore/Algorithms/Permissions.py +27 -0
  39. WMCore/Algorithms/Singleton.py +58 -0
  40. WMCore/Algorithms/SubprocessAlgos.py +129 -0
  41. WMCore/Algorithms/__init__.py +7 -0
  42. WMCore/Cache/GenericDataCache.py +98 -0
  43. WMCore/Cache/WMConfigCache.py +572 -0
  44. WMCore/Cache/__init__.py +0 -0
  45. WMCore/Configuration.py +659 -0
  46. WMCore/DAOFactory.py +47 -0
  47. WMCore/DataStructs/File.py +177 -0
  48. WMCore/DataStructs/Fileset.py +140 -0
  49. WMCore/DataStructs/Job.py +182 -0
  50. WMCore/DataStructs/JobGroup.py +142 -0
  51. WMCore/DataStructs/JobPackage.py +49 -0
  52. WMCore/DataStructs/LumiList.py +734 -0
  53. WMCore/DataStructs/Mask.py +219 -0
  54. WMCore/DataStructs/MathStructs/ContinuousSummaryHistogram.py +197 -0
  55. WMCore/DataStructs/MathStructs/DiscreteSummaryHistogram.py +92 -0
  56. WMCore/DataStructs/MathStructs/SummaryHistogram.py +117 -0
  57. WMCore/DataStructs/MathStructs/__init__.py +0 -0
  58. WMCore/DataStructs/Pickleable.py +24 -0
  59. WMCore/DataStructs/Run.py +256 -0
  60. WMCore/DataStructs/Subscription.py +175 -0
  61. WMCore/DataStructs/WMObject.py +47 -0
  62. WMCore/DataStructs/WorkUnit.py +112 -0
  63. WMCore/DataStructs/Workflow.py +60 -0
  64. WMCore/DataStructs/__init__.py +8 -0
  65. WMCore/Database/CMSCouch.py +1430 -0
  66. WMCore/Database/ConfigDBMap.py +29 -0
  67. WMCore/Database/CouchMonitoring.py +450 -0
  68. WMCore/Database/CouchUtils.py +118 -0
  69. WMCore/Database/DBCore.py +198 -0
  70. WMCore/Database/DBCreator.py +113 -0
  71. WMCore/Database/DBExceptionHandler.py +59 -0
  72. WMCore/Database/DBFactory.py +117 -0
  73. WMCore/Database/DBFormatter.py +177 -0
  74. WMCore/Database/Dialects.py +13 -0
  75. WMCore/Database/ExecuteDAO.py +327 -0
  76. WMCore/Database/MongoDB.py +241 -0
  77. WMCore/Database/MySQL/Destroy.py +42 -0
  78. WMCore/Database/MySQL/ListUserContent.py +20 -0
  79. WMCore/Database/MySQL/__init__.py +9 -0
  80. WMCore/Database/MySQLCore.py +132 -0
  81. WMCore/Database/Oracle/Destroy.py +56 -0
  82. WMCore/Database/Oracle/ListUserContent.py +19 -0
  83. WMCore/Database/Oracle/__init__.py +9 -0
  84. WMCore/Database/ResultSet.py +44 -0
  85. WMCore/Database/Transaction.py +91 -0
  86. WMCore/Database/__init__.py +9 -0
  87. WMCore/Database/ipy_profile_couch.py +438 -0
  88. WMCore/GlobalWorkQueue/CherryPyThreads/CleanUpTask.py +29 -0
  89. WMCore/GlobalWorkQueue/CherryPyThreads/HeartbeatMonitor.py +105 -0
  90. WMCore/GlobalWorkQueue/CherryPyThreads/LocationUpdateTask.py +28 -0
  91. WMCore/GlobalWorkQueue/CherryPyThreads/ReqMgrInteractionTask.py +35 -0
  92. WMCore/GlobalWorkQueue/CherryPyThreads/__init__.py +0 -0
  93. WMCore/GlobalWorkQueue/__init__.py +0 -0
  94. WMCore/GroupUser/CouchObject.py +127 -0
  95. WMCore/GroupUser/Decorators.py +51 -0
  96. WMCore/GroupUser/Group.py +33 -0
  97. WMCore/GroupUser/Interface.py +73 -0
  98. WMCore/GroupUser/User.py +96 -0
  99. WMCore/GroupUser/__init__.py +11 -0
  100. WMCore/Lexicon.py +836 -0
  101. WMCore/REST/Auth.py +202 -0
  102. WMCore/REST/CherryPyPeriodicTask.py +166 -0
  103. WMCore/REST/Error.py +333 -0
  104. WMCore/REST/Format.py +642 -0
  105. WMCore/REST/HeartbeatMonitorBase.py +90 -0
  106. WMCore/REST/Main.py +636 -0
  107. WMCore/REST/Server.py +2435 -0
  108. WMCore/REST/Services.py +24 -0
  109. WMCore/REST/Test.py +120 -0
  110. WMCore/REST/Tools.py +38 -0
  111. WMCore/REST/Validation.py +250 -0
  112. WMCore/REST/__init__.py +1 -0
  113. WMCore/ReqMgr/DataStructs/RequestStatus.py +209 -0
  114. WMCore/ReqMgr/DataStructs/RequestType.py +13 -0
  115. WMCore/ReqMgr/DataStructs/__init__.py +0 -0
  116. WMCore/ReqMgr/__init__.py +1 -0
  117. WMCore/Services/AlertManager/AlertManagerAPI.py +111 -0
  118. WMCore/Services/AlertManager/__init__.py +0 -0
  119. WMCore/Services/CRIC/CRIC.py +238 -0
  120. WMCore/Services/CRIC/__init__.py +0 -0
  121. WMCore/Services/DBS/DBS3Reader.py +1044 -0
  122. WMCore/Services/DBS/DBSConcurrency.py +44 -0
  123. WMCore/Services/DBS/DBSErrors.py +112 -0
  124. WMCore/Services/DBS/DBSReader.py +23 -0
  125. WMCore/Services/DBS/DBSUtils.py +166 -0
  126. WMCore/Services/DBS/DBSWriterObjects.py +381 -0
  127. WMCore/Services/DBS/ProdException.py +133 -0
  128. WMCore/Services/DBS/__init__.py +8 -0
  129. WMCore/Services/FWJRDB/FWJRDBAPI.py +118 -0
  130. WMCore/Services/FWJRDB/__init__.py +0 -0
  131. WMCore/Services/HTTPS/HTTPSAuthHandler.py +66 -0
  132. WMCore/Services/HTTPS/__init__.py +0 -0
  133. WMCore/Services/LogDB/LogDB.py +201 -0
  134. WMCore/Services/LogDB/LogDBBackend.py +191 -0
  135. WMCore/Services/LogDB/LogDBExceptions.py +11 -0
  136. WMCore/Services/LogDB/LogDBReport.py +85 -0
  137. WMCore/Services/LogDB/__init__.py +0 -0
  138. WMCore/Services/MSPileup/__init__.py +0 -0
  139. WMCore/Services/MSUtils/MSUtils.py +54 -0
  140. WMCore/Services/MSUtils/__init__.py +0 -0
  141. WMCore/Services/McM/McM.py +173 -0
  142. WMCore/Services/McM/__init__.py +8 -0
  143. WMCore/Services/MonIT/Grafana.py +133 -0
  144. WMCore/Services/MonIT/__init__.py +0 -0
  145. WMCore/Services/PyCondor/PyCondorAPI.py +154 -0
  146. WMCore/Services/PyCondor/__init__.py +0 -0
  147. WMCore/Services/ReqMgr/ReqMgr.py +261 -0
  148. WMCore/Services/ReqMgr/__init__.py +0 -0
  149. WMCore/Services/ReqMgrAux/ReqMgrAux.py +419 -0
  150. WMCore/Services/ReqMgrAux/__init__.py +0 -0
  151. WMCore/Services/RequestDB/RequestDBReader.py +267 -0
  152. WMCore/Services/RequestDB/RequestDBWriter.py +39 -0
  153. WMCore/Services/RequestDB/__init__.py +0 -0
  154. WMCore/Services/Requests.py +624 -0
  155. WMCore/Services/Rucio/Rucio.py +1290 -0
  156. WMCore/Services/Rucio/RucioUtils.py +74 -0
  157. WMCore/Services/Rucio/__init__.py +0 -0
  158. WMCore/Services/RucioConMon/RucioConMon.py +121 -0
  159. WMCore/Services/RucioConMon/__init__.py +0 -0
  160. WMCore/Services/Service.py +400 -0
  161. WMCore/Services/StompAMQ/__init__.py +0 -0
  162. WMCore/Services/TagCollector/TagCollector.py +155 -0
  163. WMCore/Services/TagCollector/XMLUtils.py +98 -0
  164. WMCore/Services/TagCollector/__init__.py +0 -0
  165. WMCore/Services/UUIDLib.py +13 -0
  166. WMCore/Services/UserFileCache/UserFileCache.py +160 -0
  167. WMCore/Services/UserFileCache/__init__.py +8 -0
  168. WMCore/Services/WMAgent/WMAgent.py +63 -0
  169. WMCore/Services/WMAgent/__init__.py +0 -0
  170. WMCore/Services/WMArchive/CMSSWMetrics.py +526 -0
  171. WMCore/Services/WMArchive/DataMap.py +463 -0
  172. WMCore/Services/WMArchive/WMArchive.py +33 -0
  173. WMCore/Services/WMArchive/__init__.py +0 -0
  174. WMCore/Services/WMBS/WMBS.py +97 -0
  175. WMCore/Services/WMBS/__init__.py +0 -0
  176. WMCore/Services/WMStats/DataStruct/RequestInfoCollection.py +300 -0
  177. WMCore/Services/WMStats/DataStruct/__init__.py +0 -0
  178. WMCore/Services/WMStats/WMStatsPycurl.py +145 -0
  179. WMCore/Services/WMStats/WMStatsReader.py +445 -0
  180. WMCore/Services/WMStats/WMStatsWriter.py +273 -0
  181. WMCore/Services/WMStats/__init__.py +0 -0
  182. WMCore/Services/WMStatsServer/WMStatsServer.py +134 -0
  183. WMCore/Services/WMStatsServer/__init__.py +0 -0
  184. WMCore/Services/WorkQueue/WorkQueue.py +492 -0
  185. WMCore/Services/WorkQueue/__init__.py +0 -0
  186. WMCore/Services/__init__.py +8 -0
  187. WMCore/Services/pycurl_manager.py +574 -0
  188. WMCore/WMBase.py +50 -0
  189. WMCore/WMConnectionBase.py +164 -0
  190. WMCore/WMException.py +183 -0
  191. WMCore/WMExceptions.py +269 -0
  192. WMCore/WMFactory.py +76 -0
  193. WMCore/WMInit.py +377 -0
  194. WMCore/WMLogging.py +104 -0
  195. WMCore/WMSpec/ConfigSectionTree.py +442 -0
  196. WMCore/WMSpec/Persistency.py +135 -0
  197. WMCore/WMSpec/Steps/BuildMaster.py +87 -0
  198. WMCore/WMSpec/Steps/BuildTools.py +201 -0
  199. WMCore/WMSpec/Steps/Builder.py +97 -0
  200. WMCore/WMSpec/Steps/Diagnostic.py +89 -0
  201. WMCore/WMSpec/Steps/Emulator.py +62 -0
  202. WMCore/WMSpec/Steps/ExecuteMaster.py +208 -0
  203. WMCore/WMSpec/Steps/Executor.py +210 -0
  204. WMCore/WMSpec/Steps/StepFactory.py +213 -0
  205. WMCore/WMSpec/Steps/TaskEmulator.py +75 -0
  206. WMCore/WMSpec/Steps/Template.py +204 -0
  207. WMCore/WMSpec/Steps/Templates/AlcaHarvest.py +76 -0
  208. WMCore/WMSpec/Steps/Templates/CMSSW.py +613 -0
  209. WMCore/WMSpec/Steps/Templates/DQMUpload.py +59 -0
  210. WMCore/WMSpec/Steps/Templates/DeleteFiles.py +70 -0
  211. WMCore/WMSpec/Steps/Templates/LogArchive.py +84 -0
  212. WMCore/WMSpec/Steps/Templates/LogCollect.py +105 -0
  213. WMCore/WMSpec/Steps/Templates/StageOut.py +105 -0
  214. WMCore/WMSpec/Steps/Templates/__init__.py +10 -0
  215. WMCore/WMSpec/Steps/WMExecutionFailure.py +21 -0
  216. WMCore/WMSpec/Steps/__init__.py +8 -0
  217. WMCore/WMSpec/Utilities.py +63 -0
  218. WMCore/WMSpec/WMSpecErrors.py +12 -0
  219. WMCore/WMSpec/WMStep.py +347 -0
  220. WMCore/WMSpec/WMTask.py +1997 -0
  221. WMCore/WMSpec/WMWorkload.py +2288 -0
  222. WMCore/WMSpec/WMWorkloadTools.py +382 -0
  223. WMCore/WMSpec/__init__.py +9 -0
  224. WMCore/WorkQueue/DataLocationMapper.py +273 -0
  225. WMCore/WorkQueue/DataStructs/ACDCBlock.py +47 -0
  226. WMCore/WorkQueue/DataStructs/Block.py +48 -0
  227. WMCore/WorkQueue/DataStructs/CouchWorkQueueElement.py +148 -0
  228. WMCore/WorkQueue/DataStructs/WorkQueueElement.py +274 -0
  229. WMCore/WorkQueue/DataStructs/WorkQueueElementResult.py +152 -0
  230. WMCore/WorkQueue/DataStructs/WorkQueueElementsSummary.py +185 -0
  231. WMCore/WorkQueue/DataStructs/__init__.py +0 -0
  232. WMCore/WorkQueue/Policy/End/EndPolicyInterface.py +44 -0
  233. WMCore/WorkQueue/Policy/End/SingleShot.py +22 -0
  234. WMCore/WorkQueue/Policy/End/__init__.py +32 -0
  235. WMCore/WorkQueue/Policy/PolicyInterface.py +17 -0
  236. WMCore/WorkQueue/Policy/Start/Block.py +258 -0
  237. WMCore/WorkQueue/Policy/Start/Dataset.py +180 -0
  238. WMCore/WorkQueue/Policy/Start/MonteCarlo.py +131 -0
  239. WMCore/WorkQueue/Policy/Start/ResubmitBlock.py +171 -0
  240. WMCore/WorkQueue/Policy/Start/StartPolicyInterface.py +316 -0
  241. WMCore/WorkQueue/Policy/Start/__init__.py +34 -0
  242. WMCore/WorkQueue/Policy/__init__.py +57 -0
  243. WMCore/WorkQueue/WMBSHelper.py +772 -0
  244. WMCore/WorkQueue/WorkQueue.py +1237 -0
  245. WMCore/WorkQueue/WorkQueueBackend.py +750 -0
  246. WMCore/WorkQueue/WorkQueueBase.py +39 -0
  247. WMCore/WorkQueue/WorkQueueExceptions.py +44 -0
  248. WMCore/WorkQueue/WorkQueueReqMgrInterface.py +278 -0
  249. WMCore/WorkQueue/WorkQueueUtils.py +130 -0
  250. WMCore/WorkQueue/__init__.py +13 -0
  251. WMCore/Wrappers/JsonWrapper/JSONThunker.py +342 -0
  252. WMCore/Wrappers/JsonWrapper/__init__.py +7 -0
  253. WMCore/Wrappers/__init__.py +6 -0
  254. WMCore/__init__.py +10 -0
  255. wmglobalqueue-2.4.5.1.data/data/bin/wmc-dist-patch +15 -0
  256. wmglobalqueue-2.4.5.1.data/data/bin/wmc-dist-unpatch +8 -0
  257. wmglobalqueue-2.4.5.1.data/data/bin/wmc-httpd +3 -0
  258. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/.couchapprc +1 -0
  259. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/README.md +40 -0
  260. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/index.html +264 -0
  261. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/ElementInfoByWorkflow.js +96 -0
  262. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/StuckElementInfo.js +57 -0
  263. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/WorkloadInfoTable.js +80 -0
  264. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/dataTable.js +70 -0
  265. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/namespace.js +23 -0
  266. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/style/main.css +75 -0
  267. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/couchapp.json +4 -0
  268. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/filters/childQueueFilter.js +13 -0
  269. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/filters/filterDeletedDocs.js +3 -0
  270. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/filters/queueFilter.js +11 -0
  271. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/language +1 -0
  272. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lib/mustache.js +333 -0
  273. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lib/validate.js +27 -0
  274. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lib/workqueue_utils.js +61 -0
  275. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/elementsDetail.js +28 -0
  276. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/filter.js +86 -0
  277. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/stuckElements.js +38 -0
  278. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/workRestrictions.js +153 -0
  279. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/workflowSummary.js +28 -0
  280. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/rewrites.json +73 -0
  281. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/shows/redirect.js +23 -0
  282. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/shows/status.js +40 -0
  283. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/ElementSummaryByWorkflow.html +27 -0
  284. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/StuckElementSummary.html +26 -0
  285. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/TaskStatus.html +23 -0
  286. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/WorkflowSummary.html +27 -0
  287. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/partials/workqueue-common-lib.html +2 -0
  288. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/partials/yui-lib-remote.html +16 -0
  289. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/partials/yui-lib.html +18 -0
  290. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/updates/in-place.js +50 -0
  291. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/validate_doc_update.js +8 -0
  292. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/vendor/couchapp/_attachments/jquery.couch.app.js +235 -0
  293. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/vendor/couchapp/_attachments/jquery.pathbinder.js +173 -0
  294. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activeData/map.js +8 -0
  295. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activeData/reduce.js +2 -0
  296. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activeParentData/map.js +8 -0
  297. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activeParentData/reduce.js +2 -0
  298. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activePileupData/map.js +8 -0
  299. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activePileupData/reduce.js +2 -0
  300. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/analyticsData/map.js +11 -0
  301. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/analyticsData/reduce.js +1 -0
  302. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/availableByPriority/map.js +6 -0
  303. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/conflicts/map.js +5 -0
  304. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elements/map.js +5 -0
  305. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByData/map.js +8 -0
  306. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByParent/map.js +8 -0
  307. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByParentData/map.js +8 -0
  308. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByPileupData/map.js +8 -0
  309. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByStatus/map.js +8 -0
  310. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsBySubscription/map.js +6 -0
  311. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByWorkflow/map.js +8 -0
  312. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByWorkflow/reduce.js +3 -0
  313. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsDetailByWorkflowAndStatus/map.js +26 -0
  314. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobInjectStatusByRequest/map.js +10 -0
  315. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobInjectStatusByRequest/reduce.js +1 -0
  316. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobStatusByRequest/map.js +6 -0
  317. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobStatusByRequest/reduce.js +1 -0
  318. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndPriority/map.js +6 -0
  319. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndPriority/reduce.js +1 -0
  320. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndStatus/map.js +6 -0
  321. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndStatus/reduce.js +1 -0
  322. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByRequest/map.js +6 -0
  323. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByRequest/reduce.js +1 -0
  324. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatus/map.js +6 -0
  325. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatus/reduce.js +1 -0
  326. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatusAndPriority/map.js +6 -0
  327. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatusAndPriority/reduce.js +1 -0
  328. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/openRequests/map.js +6 -0
  329. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/recent-items/map.js +5 -0
  330. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/siteWhitelistByRequest/map.js +6 -0
  331. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/siteWhitelistByRequest/reduce.js +1 -0
  332. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/specsByWorkflow/map.js +5 -0
  333. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/stuckElements/map.js +38 -0
  334. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsInjectStatusByRequest/map.js +12 -0
  335. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsInjectStatusByRequest/reduce.js +3 -0
  336. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsUrl/map.js +6 -0
  337. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsUrl/reduce.js +2 -0
  338. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsUrlByRequest/map.js +6 -0
  339. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsUrlByRequest/reduce.js +2 -0
  340. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/workflowSummary/map.js +9 -0
  341. wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/workflowSummary/reduce.js +10 -0
  342. wmglobalqueue-2.4.5.1.dist-info/METADATA +26 -0
  343. wmglobalqueue-2.4.5.1.dist-info/RECORD +347 -0
  344. wmglobalqueue-2.4.5.1.dist-info/WHEEL +5 -0
  345. wmglobalqueue-2.4.5.1.dist-info/licenses/LICENSE +202 -0
  346. wmglobalqueue-2.4.5.1.dist-info/licenses/NOTICE +16 -0
  347. wmglobalqueue-2.4.5.1.dist-info/top_level.txt +2 -0
@@ -0,0 +1,235 @@
1
+ // Licensed under the Apache License, Version 2.0 (the "License"); you may not
2
+ // use this file except in compliance with the License. You may obtain a copy
3
+ // of the License at
4
+ //
5
+ // http://www.apache.org/licenses/LICENSE-2.0
6
+ //
7
+ // Unless required by applicable law or agreed to in writing, software
8
+ // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
9
+ // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
10
+ // License for the specific language governing permissions and limitations under
11
+ // the License.
12
+
13
+ // Usage: The passed in function is called when the page is ready.
14
+ // CouchApp passes in the app object, which takes care of linking to
15
+ // the proper database, and provides access to the CouchApp helpers.
16
+ // $.couch.app(function(app) {
17
+ // app.db.view(...)
18
+ // ...
19
+ // });
20
+
21
+ (function($) {
22
+
23
+ function Design(db, name, code) {
24
+ this.doc_id = "_design/"+name;
25
+ if (code) {
26
+ this.code_path = this.doc_id + "/" + code;
27
+ } else {
28
+ this.code_path = this.doc_id;
29
+ }
30
+ this.view = function(view, opts) {
31
+ db.view(name+'/'+view, opts);
32
+ };
33
+ this.list = function(list, view, opts) {
34
+ db.list(name+'/'+list, view, opts);
35
+ };
36
+ }
37
+
38
+ function docForm() { alert("docForm has been moved to vendor/couchapp/lib/docForm.js, use app.require to load") };
39
+
40
+ function resolveModule(path, names, parents, current) {
41
+ parents = parents || [];
42
+ if (names.length === 0) {
43
+ if (typeof current != "string") {
44
+ throw ["error","invalid_require_path",
45
+ 'Must require a JavaScript string, not: '+(typeof current)];
46
+ }
47
+ return [current, parents];
48
+ }
49
+ var n = names.shift();
50
+ if (n == '..') {
51
+ parents.pop();
52
+ var pp = parents.pop();
53
+ if (!pp) {
54
+ throw ["error", "invalid_require_path", path];
55
+ }
56
+ return resolveModule(path, names, parents, pp);
57
+ } else if (n == '.') {
58
+ var p = parents.pop();
59
+ if (!p) {
60
+ throw ["error", "invalid_require_path", path];
61
+ }
62
+ return resolveModule(path, names, parents, p);
63
+ } else {
64
+ parents = [];
65
+ }
66
+ if (!current[n]) {
67
+ throw ["error", "invalid_require_path", path];
68
+ }
69
+ parents.push(current);
70
+ return resolveModule(path, names, parents, current[n]);
71
+ }
72
+
73
+ function makeRequire(ddoc) {
74
+ var moduleCache = [];
75
+ function getCachedModule(name, parents) {
76
+ var key, i, len = moduleCache.length;
77
+ for (i=0;i<len;++i) {
78
+ key = moduleCache[i].key;
79
+ if (key[0] === name && key[1] === parents) {
80
+ return moduleCache[i].module;
81
+ }
82
+ }
83
+ return null;
84
+ }
85
+ function setCachedModule(name, parents, module) {
86
+ moduleCache.push({ key: [name, parents], module: module });
87
+ }
88
+ var require = function (name, parents) {
89
+ var cachedModule = getCachedModule(name, parents);
90
+ if (cachedModule !== null) {
91
+ return cachedModule;
92
+ }
93
+ var exports = {};
94
+ var resolved = resolveModule(name, name.split('/'), parents, ddoc);
95
+ var source = resolved[0];
96
+ parents = resolved[1];
97
+ var s = "var func = function (exports, require) { " + source + " };";
98
+ try {
99
+ eval(s);
100
+ func.apply(ddoc, [exports, function(name) {return require(name, parents)}]);
101
+ } catch(e) {
102
+ throw ["error","compilation_error","Module require('"+name+"') raised error "+e.toSource()];
103
+ }
104
+ setCachedModule(name, parents, exports);
105
+ return exports;
106
+ }
107
+ return require;
108
+ };
109
+
110
+ function mockReq() {
111
+ var p = document.location.pathname.split('/'),
112
+ qs = document.location.search.replace(/^\?/,'').split('&'),
113
+ q = {};
114
+ qs.forEach(function(param) {
115
+ var ps = param.split('='),
116
+ k = decodeURIComponent(ps[0]),
117
+ v = decodeURIComponent(ps[1]);
118
+ if (["startkey", "endkey", "key"].indexOf(k) != -1) {
119
+ q[k] = JSON.parse(v);
120
+ } else {
121
+ q[k] = v;
122
+ }
123
+ });
124
+ p.shift();
125
+ return {
126
+ path : p,
127
+ query : q
128
+ };
129
+ };
130
+
131
+ $.couch.app = $.couch.app || function(appFun, opts) {
132
+ opts = opts || {};
133
+ var urlPrefix = (opts.urlPrefix || ""),
134
+ index = urlPrefix.split('/').length,
135
+ fragments = unescape(document.location.href).split('/'),
136
+ dbname = opts.db || fragments[index + 2],
137
+ dname = opts.design || fragments[index + 4];
138
+ $.couch.urlPrefix = urlPrefix;
139
+ var db = $.couch.db(dbname),
140
+ design = new Design(db, dname, opts.load_path);
141
+ var appExports = $.extend({
142
+ db : db,
143
+ design : design,
144
+ view : design.view,
145
+ list : design.list,
146
+ docForm : docForm, // deprecated
147
+ req : mockReq()
148
+ }, $.couch.app.app);
149
+ function handleDDoc(ddoc) {
150
+ if (ddoc) {
151
+ appExports.ddoc = ddoc;
152
+ appExports.require = makeRequire(ddoc);
153
+ }
154
+ appFun.apply(appExports, [appExports]);
155
+ }
156
+ if (opts.ddoc) {
157
+ // allow the ddoc to be embedded in the html
158
+ // to avoid a second http request
159
+ $.couch.app.ddocs[design.doc_id] = opts.ddoc;
160
+ }
161
+ if ($.couch.app.ddocs[design.doc_id]) {
162
+ $(function() {handleDDoc($.couch.app.ddocs[design.doc_id])});
163
+ } else {
164
+ // only open 1 connection for this ddoc
165
+ if ($.couch.app.ddoc_handlers[design.doc_id]) {
166
+ // we are already fetching, just wait
167
+ $.couch.app.ddoc_handlers[design.doc_id].push(handleDDoc);
168
+ } else {
169
+ $.couch.app.ddoc_handlers[design.doc_id] = [handleDDoc];
170
+ // use getDbProperty to bypass %2F encoding on _show/app
171
+ db.getDbProperty(design.code_path, {
172
+ success : function(doc) {
173
+ $.couch.app.ddocs[design.doc_id] = doc;
174
+ $.couch.app.ddoc_handlers[design.doc_id].forEach(function(h) {
175
+ $(function() {h(doc)});
176
+ });
177
+ $.couch.app.ddoc_handlers[design.doc_id] = null;
178
+ },
179
+ error : function() {
180
+ $.couch.app.ddoc_handlers[design.doc_id].forEach(function(h) {
181
+ $(function() {h()});
182
+ });
183
+ $.couch.app.ddoc_handlers[design.doc_id] = null;
184
+ }
185
+ });
186
+ }
187
+ }
188
+ };
189
+ $.couch.app.ddocs = {};
190
+ $.couch.app.ddoc_handlers = {};
191
+ // legacy support. $.CouchApp is deprecated, please use $.couch.app
192
+ $.CouchApp = $.couch.app;
193
+ })(jQuery);
194
+
195
+ // JavaScript 1.6 compatibility functions that are missing from IE7/IE8
196
+
197
+ if (!Array.prototype.forEach)
198
+ {
199
+ Array.prototype.forEach = function(fun /*, thisp*/)
200
+ {
201
+ var len = this.length >>> 0;
202
+ if (typeof fun != "function")
203
+ throw new TypeError();
204
+
205
+ var thisp = arguments[1];
206
+ for (var i = 0; i < len; i++)
207
+ {
208
+ if (i in this)
209
+ fun.call(thisp, this[i], i, this);
210
+ }
211
+ };
212
+ }
213
+
214
+ if (!Array.prototype.indexOf)
215
+ {
216
+ Array.prototype.indexOf = function(elt)
217
+ {
218
+ var len = this.length >>> 0;
219
+
220
+ var from = Number(arguments[1]) || 0;
221
+ from = (from < 0)
222
+ ? Math.ceil(from)
223
+ : Math.floor(from);
224
+ if (from < 0)
225
+ from += len;
226
+
227
+ for (; from < len; from++)
228
+ {
229
+ if (from in this &&
230
+ this[from] === elt)
231
+ return from;
232
+ }
233
+ return -1;
234
+ };
235
+ }a
@@ -0,0 +1,173 @@
1
+ (function($) {
2
+ // functions for handling the path
3
+ // thanks sammy.js
4
+ var PATH_REPLACER = "([^\/]+)",
5
+ PATH_NAME_MATCHER = /:([\w\d]+)/g,
6
+ QUERY_STRING_MATCHER = /\?([^#]*)$/,
7
+ SPLAT_MATCHER = /(\*)/,
8
+ SPLAT_REPLACER = "(.+)",
9
+ _currentPath,
10
+ _lastPath,
11
+ _pathInterval;
12
+
13
+ function hashChanged() {
14
+ _currentPath = getPath();
15
+ // if path is actually changed from what we thought it was, then react
16
+ if (_lastPath != _currentPath) {
17
+ _lastPath = _currentPath;
18
+ return triggerOnPath(_currentPath);
19
+ }
20
+ }
21
+
22
+ $.pathbinder = {
23
+ changeFuns : [],
24
+ paths : [],
25
+ begin : function(defaultPath) {
26
+ // this should trigger the defaultPath if there's not a path in the URL
27
+ // otherwise it should trigger the URL's path
28
+ $(function() {
29
+ var loadPath = getPath();
30
+ if (loadPath) {
31
+ triggerOnPath(loadPath);
32
+ } else {
33
+ goPath(defaultPath);
34
+ triggerOnPath(defaultPath);
35
+ }
36
+ })
37
+ },
38
+ go : function(path) {
39
+ goPath(path);
40
+ triggerOnPath(path);
41
+ },
42
+ currentPath : function() {
43
+ return getPath();
44
+ },
45
+ onChange : function (fun) {
46
+ $.pathbinder.changeFuns.push(fun);
47
+ }
48
+ };
49
+
50
+ function pollPath(every) {
51
+ function hashCheck() {
52
+ _currentPath = getPath();
53
+ // path changed if _currentPath != _lastPath
54
+ if (_lastPath != _currentPath) {
55
+ setTimeout(function() {
56
+ $(window).trigger('hashchange');
57
+ }, 1);
58
+ }
59
+ };
60
+ hashCheck();
61
+ _pathInterval = setInterval(hashCheck, every);
62
+ $(window).bind('unload', function() {
63
+ clearInterval(_pathInterval);
64
+ });
65
+ }
66
+
67
+ function triggerOnPath(path) {
68
+ path = path.replace(/^#/,'');
69
+ $.pathbinder.changeFuns.forEach(function(fun) {fun(path)});
70
+ var pathSpec, path_params, params = {}, param_name, param;
71
+ for (var i=0; i < $.pathbinder.paths.length; i++) {
72
+ pathSpec = $.pathbinder.paths[i];
73
+ // $.log("pathSpec", pathSpec);
74
+ if ((path_params = pathSpec.matcher.exec(path)) !== null) {
75
+ // $.log("path_params", path_params);
76
+ path_params.shift();
77
+ for (var j=0; j < path_params.length; j++) {
78
+ param_name = pathSpec.param_names[j];
79
+ param = decodeURIComponent(path_params[j]);
80
+ if (param_name) {
81
+ params[param_name] = param;
82
+ } else {
83
+ if (!params.splat) params.splat = [];
84
+ params.splat.push(param);
85
+ }
86
+ };
87
+ pathSpec.callback(params);
88
+ // return true; // removed this to allow for multi match
89
+ }
90
+ };
91
+ };
92
+
93
+ // bind the event
94
+ $(function() {
95
+ if ('onhashchange' in window) {
96
+ // we have a native event
97
+ } else {
98
+ pollPath(10);
99
+ }
100
+ // setTimeout(hashChanged,50);
101
+ $(window).bind('hashchange', hashChanged);
102
+ });
103
+
104
+ function registerPath(pathSpec) {
105
+ $.pathbinder.paths.push(pathSpec);
106
+ };
107
+
108
+ function setPath(pathSpec, params) {
109
+ var newPath = $.mustache(pathSpec.template, params);
110
+ goPath(newPath);
111
+ };
112
+
113
+ function goPath(newPath) {
114
+ if (newPath) {
115
+ // $.log("goPath", newPath)
116
+ window.location = '#'+newPath;
117
+ }
118
+ _lastPath = getPath();
119
+ };
120
+
121
+ function getPath() {
122
+ var matches = window.location.toString().match(/^[^#]*(#.+)$/);
123
+ return matches ? matches[1] : '';
124
+ };
125
+
126
+ function makePathSpec(path, callback) {
127
+ var param_names = [];
128
+ var template = "";
129
+
130
+ PATH_NAME_MATCHER.lastIndex = 0;
131
+
132
+ while ((path_match = PATH_NAME_MATCHER.exec(path)) !== null) {
133
+ param_names.push(path_match[1]);
134
+ }
135
+
136
+ return {
137
+ param_names : param_names,
138
+ matcher : new RegExp("^" + path.replace(
139
+ PATH_NAME_MATCHER, PATH_REPLACER).replace(
140
+ SPLAT_MATCHER, SPLAT_REPLACER) + "/?$"),
141
+ template : path.replace(PATH_NAME_MATCHER, function(a, b) {
142
+ return '{{'+b+'}}';
143
+ }).replace(SPLAT_MATCHER, '{{splat}}'),
144
+ callback : callback
145
+ };
146
+ };
147
+
148
+ $.fn.pathbinder = function(name, paths, options) {
149
+ options = options || {};
150
+ var self = $(this), pathList = paths.split(/\n/);
151
+ $.each(pathList, function() {
152
+ var path = this;
153
+ if (path) {
154
+ // $.log("bind path", path);
155
+ var pathSpec = makePathSpec(path, function(params) {
156
+ // $.log("path cb", name, path, self)
157
+ // $.log("trigger path: "+path+" params: ", params);
158
+ self.trigger(name, [params]);
159
+ });
160
+ // set the path when the event triggered through other means
161
+ if (options.bindPath) {
162
+ self.bind(name, function(ev, params) {
163
+ params = params || {};
164
+ // $.log("set path", name, pathSpec)
165
+ setPath(pathSpec, params);
166
+ });
167
+ }
168
+ // trigger when the path matches
169
+ registerPath(pathSpec);
170
+ }
171
+ });
172
+ };
173
+ })(jQuery);
@@ -0,0 +1,8 @@
1
+ function(doc, site) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele["Status"] === "Available") {
4
+ for (var i in ele.Inputs) {
5
+ emit([ele["Dbs"], i], null);
6
+ }
7
+ }
8
+ }
@@ -0,0 +1,2 @@
1
+ function(keys, values) {
2
+ }
@@ -0,0 +1,8 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele["Status"] === "Available" && ele["ParentData"]) {
4
+ for (var i in ele.ParentData) {
5
+ emit([ele.Dbs, i], null);
6
+ }
7
+ }
8
+ }
@@ -0,0 +1,8 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele["Status"] === "Available" && ele["PileupData"]) {
4
+ for (var i in ele["PileupData"]) {
5
+ emit([ele["Dbs"], i], null);
6
+ }
7
+ }
8
+ }
@@ -0,0 +1,11 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele['Jobs']) {
4
+ // assumes request name and input data is one to one (None for MC workflow)
5
+ if (ele['Status'] == 'Available' || ele['Status'] == 'Negotiating') {
6
+ emit([ele["RequestName"], ele['Inputs'], 'inQueue'], ele['Jobs']);
7
+ } else {
8
+ emit([ele["RequestName"], ele['Inputs'], 'inWMBS'], ele['Jobs'])
9
+ }
10
+ }
11
+ }
@@ -0,0 +1,6 @@
1
+ function(doc, site) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele["Status"] === "Available") {
4
+ emit(ele["Priority"], {"_id" : doc["_id"]});
5
+ }
6
+ }
@@ -0,0 +1,5 @@
1
+ function(doc) {
2
+ if (doc._conflicts) {
3
+ emit(null, [doc._rev].concat(doc._conflicts));
4
+ }
5
+ }
@@ -0,0 +1,5 @@
1
+ function(doc) {
2
+ if (doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"]) {
3
+ emit(null, {'_id' : doc['_id']});
4
+ }
5
+ }
@@ -0,0 +1,8 @@
1
+ function(doc, site) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele["Status"] === "Available") {
4
+ for (var i in ele.Inputs) {
5
+ emit(i, {_id: doc._id});
6
+ }
7
+ }
8
+ }
@@ -0,0 +1,8 @@
1
+ function(doc, site) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ // Can't get multiple keys to work - use one for now
4
+ //emit([ele["Status"], ele["RequestName"], doc._id, doc.timestamp, ele["ParentQueueId"]],
5
+ if (ele) {
6
+ emit(ele["ParentQueueId"], {'_id' : doc['_id']});
7
+ }
8
+ }
@@ -0,0 +1,8 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele["Status"] === "Available" && ele.ParentFlag) {
4
+ for (var i in ele.ParentData) {
5
+ emit(i, {'_id' : doc['_id']});
6
+ }
7
+ }
8
+ }
@@ -0,0 +1,8 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele["Status"] === "Available" && ele["PileupData"]) {
4
+ for (var i in ele["PileupData"]) {
5
+ emit(i, {'_id' : doc['_id']});
6
+ }
7
+ }
8
+ }
@@ -0,0 +1,8 @@
1
+ function(doc, site) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ // Can't get multiple keys to work - use one for now
4
+ //emit([ele["Status"], ele["RequestName"], doc._id, doc.timestamp, ele["ParentQueueId"]],
5
+ if (ele) {
6
+ emit(ele["Status"], {'_id' : doc['_id']});
7
+ }
8
+ }
@@ -0,0 +1,6 @@
1
+ function(doc, site) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele) {
4
+ emit(ele["SubscriptionId"], {'_id' : doc['_id']});
5
+ }
6
+ }
@@ -0,0 +1,8 @@
1
+ function(doc, site) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ // Can't get multiple keys to work - use one for now
4
+ //emit([ele["Status"], ele["RequestName"], doc._id, doc.timestamp, ele["ParentQueueId"]],
5
+ if (ele) {
6
+ emit(ele["RequestName"], {'_id' : doc['_id']});
7
+ }
8
+ }
@@ -0,0 +1,3 @@
1
+ function(keys, values) {
2
+ return true;
3
+ }
@@ -0,0 +1,26 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele) {
4
+ emit([ele.RequestName, ele.Status], {'Id' : doc['_id'],
5
+ 'RequestName':ele.RequestName,
6
+ 'Inputs': ele.Inputs,
7
+ 'Jobs': ele.Jobs,
8
+ 'SiteWhitelist': ele.SiteWhitelist,
9
+ 'SiteBlacklist': ele.SiteBlacklist,
10
+ 'Dbs': ele.Dbs,
11
+ 'Task': ele.Task,
12
+ 'Priority': ele.Priority,
13
+ 'Status': ele.Status,
14
+ 'EventsWritten': ele.EventsWritten,
15
+ 'FilesProcessed': ele.FilesProcessed,
16
+ 'PercentComplete': ele.PercentComplete,
17
+ 'PercentSuccess': ele.PercentSuccess,
18
+ 'TeamName': ele.TeamName,
19
+ 'ChildQueueUrl': ele.ChildQueueUrl,
20
+ 'WMBSUrl': ele.WMBSUrl,
21
+ 'ACDC': ele.ACDC,
22
+ 'InsertTime': doc.timestamp,
23
+ 'UpdateTime': doc.updatetime
24
+ });
25
+ }
26
+ }
@@ -0,0 +1,10 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele['Jobs']) {
4
+ if (ele['Status'] == 'Available' || ele['Status'] == 'Negotiating') {
5
+ emit([ele["RequestName"], 'inQueue'], ele['Jobs']);
6
+ } else {
7
+ emit([ele["RequestName"], 'inWMBS'], ele['Jobs'])
8
+ }
9
+ }
10
+ }
@@ -0,0 +1,6 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele['Jobs'] !== undefined) {
4
+ emit([ele["RequestName"], ele['Status']], ele['Jobs']);
5
+ }
6
+ }
@@ -0,0 +1,6 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele) {
4
+ emit([ele["ChildQueueUrl"], ele["Priority"]], ele["Jobs"]);
5
+ }
6
+ }
@@ -0,0 +1,6 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele) {
4
+ emit([ele["ChildQueueUrl"], ele["Status"]], ele["Jobs"]);
5
+ }
6
+ }
@@ -0,0 +1,6 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele && ele['Jobs']) {
4
+ emit(ele["RequestName"], ele["Jobs"]);
5
+ }
6
+ }
@@ -0,0 +1,6 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele) {
4
+ emit(ele["Status"], ele["Jobs"]);
5
+ }
6
+ }
@@ -0,0 +1,6 @@
1
+ function(doc) {
2
+ var ele = doc["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
3
+ if (ele) {
4
+ emit([ele["Status"], ele["Priority"]], ele["Jobs"]);
5
+ }
6
+ }