wmglobalqueue 2.3.10rc10__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 (345) hide show
  1. Utils/CPMetrics.py +270 -0
  2. Utils/CertTools.py +62 -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/ProcessStats.py +103 -0
  13. Utils/PythonVersion.py +17 -0
  14. Utils/Signals.py +36 -0
  15. Utils/TemporaryEnvironment.py +27 -0
  16. Utils/Throttled.py +227 -0
  17. Utils/Timers.py +130 -0
  18. Utils/Timestamps.py +86 -0
  19. Utils/TokenManager.py +143 -0
  20. Utils/Tracing.py +60 -0
  21. Utils/TwPrint.py +98 -0
  22. Utils/Utilities.py +308 -0
  23. Utils/__init__.py +11 -0
  24. WMCore/ACDC/Collection.py +57 -0
  25. WMCore/ACDC/CollectionTypes.py +12 -0
  26. WMCore/ACDC/CouchCollection.py +67 -0
  27. WMCore/ACDC/CouchFileset.py +238 -0
  28. WMCore/ACDC/CouchService.py +73 -0
  29. WMCore/ACDC/DataCollectionService.py +485 -0
  30. WMCore/ACDC/Fileset.py +94 -0
  31. WMCore/ACDC/__init__.py +11 -0
  32. WMCore/Algorithms/Alarm.py +39 -0
  33. WMCore/Algorithms/MathAlgos.py +274 -0
  34. WMCore/Algorithms/MiscAlgos.py +67 -0
  35. WMCore/Algorithms/ParseXMLFile.py +115 -0
  36. WMCore/Algorithms/Permissions.py +27 -0
  37. WMCore/Algorithms/Singleton.py +58 -0
  38. WMCore/Algorithms/SubprocessAlgos.py +129 -0
  39. WMCore/Algorithms/__init__.py +7 -0
  40. WMCore/Cache/GenericDataCache.py +98 -0
  41. WMCore/Cache/WMConfigCache.py +572 -0
  42. WMCore/Cache/__init__.py +0 -0
  43. WMCore/Configuration.py +651 -0
  44. WMCore/DAOFactory.py +47 -0
  45. WMCore/DataStructs/File.py +177 -0
  46. WMCore/DataStructs/Fileset.py +140 -0
  47. WMCore/DataStructs/Job.py +182 -0
  48. WMCore/DataStructs/JobGroup.py +142 -0
  49. WMCore/DataStructs/JobPackage.py +49 -0
  50. WMCore/DataStructs/LumiList.py +734 -0
  51. WMCore/DataStructs/Mask.py +219 -0
  52. WMCore/DataStructs/MathStructs/ContinuousSummaryHistogram.py +197 -0
  53. WMCore/DataStructs/MathStructs/DiscreteSummaryHistogram.py +92 -0
  54. WMCore/DataStructs/MathStructs/SummaryHistogram.py +117 -0
  55. WMCore/DataStructs/MathStructs/__init__.py +0 -0
  56. WMCore/DataStructs/Pickleable.py +24 -0
  57. WMCore/DataStructs/Run.py +256 -0
  58. WMCore/DataStructs/Subscription.py +175 -0
  59. WMCore/DataStructs/WMObject.py +47 -0
  60. WMCore/DataStructs/WorkUnit.py +112 -0
  61. WMCore/DataStructs/Workflow.py +60 -0
  62. WMCore/DataStructs/__init__.py +8 -0
  63. WMCore/Database/CMSCouch.py +1349 -0
  64. WMCore/Database/ConfigDBMap.py +29 -0
  65. WMCore/Database/CouchUtils.py +118 -0
  66. WMCore/Database/DBCore.py +198 -0
  67. WMCore/Database/DBCreator.py +113 -0
  68. WMCore/Database/DBExceptionHandler.py +57 -0
  69. WMCore/Database/DBFactory.py +110 -0
  70. WMCore/Database/DBFormatter.py +177 -0
  71. WMCore/Database/Dialects.py +13 -0
  72. WMCore/Database/ExecuteDAO.py +327 -0
  73. WMCore/Database/MongoDB.py +241 -0
  74. WMCore/Database/MySQL/Destroy.py +42 -0
  75. WMCore/Database/MySQL/ListUserContent.py +20 -0
  76. WMCore/Database/MySQL/__init__.py +9 -0
  77. WMCore/Database/MySQLCore.py +132 -0
  78. WMCore/Database/Oracle/Destroy.py +56 -0
  79. WMCore/Database/Oracle/ListUserContent.py +19 -0
  80. WMCore/Database/Oracle/__init__.py +9 -0
  81. WMCore/Database/ResultSet.py +44 -0
  82. WMCore/Database/Transaction.py +91 -0
  83. WMCore/Database/__init__.py +9 -0
  84. WMCore/Database/ipy_profile_couch.py +438 -0
  85. WMCore/GlobalWorkQueue/CherryPyThreads/CleanUpTask.py +29 -0
  86. WMCore/GlobalWorkQueue/CherryPyThreads/HeartbeatMonitor.py +105 -0
  87. WMCore/GlobalWorkQueue/CherryPyThreads/LocationUpdateTask.py +28 -0
  88. WMCore/GlobalWorkQueue/CherryPyThreads/ReqMgrInteractionTask.py +35 -0
  89. WMCore/GlobalWorkQueue/CherryPyThreads/__init__.py +0 -0
  90. WMCore/GlobalWorkQueue/__init__.py +0 -0
  91. WMCore/GroupUser/CouchObject.py +127 -0
  92. WMCore/GroupUser/Decorators.py +51 -0
  93. WMCore/GroupUser/Group.py +33 -0
  94. WMCore/GroupUser/Interface.py +73 -0
  95. WMCore/GroupUser/User.py +96 -0
  96. WMCore/GroupUser/__init__.py +11 -0
  97. WMCore/Lexicon.py +836 -0
  98. WMCore/REST/Auth.py +202 -0
  99. WMCore/REST/CherryPyPeriodicTask.py +166 -0
  100. WMCore/REST/Error.py +333 -0
  101. WMCore/REST/Format.py +642 -0
  102. WMCore/REST/HeartbeatMonitorBase.py +90 -0
  103. WMCore/REST/Main.py +623 -0
  104. WMCore/REST/Server.py +2435 -0
  105. WMCore/REST/Services.py +24 -0
  106. WMCore/REST/Test.py +120 -0
  107. WMCore/REST/Tools.py +38 -0
  108. WMCore/REST/Validation.py +250 -0
  109. WMCore/REST/__init__.py +1 -0
  110. WMCore/ReqMgr/DataStructs/RequestStatus.py +209 -0
  111. WMCore/ReqMgr/DataStructs/RequestType.py +13 -0
  112. WMCore/ReqMgr/DataStructs/__init__.py +0 -0
  113. WMCore/ReqMgr/__init__.py +1 -0
  114. WMCore/Services/AlertManager/AlertManagerAPI.py +111 -0
  115. WMCore/Services/AlertManager/__init__.py +0 -0
  116. WMCore/Services/CRIC/CRIC.py +238 -0
  117. WMCore/Services/CRIC/__init__.py +0 -0
  118. WMCore/Services/DBS/DBS3Reader.py +1044 -0
  119. WMCore/Services/DBS/DBSConcurrency.py +44 -0
  120. WMCore/Services/DBS/DBSErrors.py +113 -0
  121. WMCore/Services/DBS/DBSReader.py +23 -0
  122. WMCore/Services/DBS/DBSUtils.py +139 -0
  123. WMCore/Services/DBS/DBSWriterObjects.py +381 -0
  124. WMCore/Services/DBS/ProdException.py +133 -0
  125. WMCore/Services/DBS/__init__.py +8 -0
  126. WMCore/Services/FWJRDB/FWJRDBAPI.py +118 -0
  127. WMCore/Services/FWJRDB/__init__.py +0 -0
  128. WMCore/Services/HTTPS/HTTPSAuthHandler.py +66 -0
  129. WMCore/Services/HTTPS/__init__.py +0 -0
  130. WMCore/Services/LogDB/LogDB.py +201 -0
  131. WMCore/Services/LogDB/LogDBBackend.py +191 -0
  132. WMCore/Services/LogDB/LogDBExceptions.py +11 -0
  133. WMCore/Services/LogDB/LogDBReport.py +85 -0
  134. WMCore/Services/LogDB/__init__.py +0 -0
  135. WMCore/Services/MSPileup/__init__.py +0 -0
  136. WMCore/Services/MSUtils/MSUtils.py +54 -0
  137. WMCore/Services/MSUtils/__init__.py +0 -0
  138. WMCore/Services/McM/McM.py +173 -0
  139. WMCore/Services/McM/__init__.py +8 -0
  140. WMCore/Services/MonIT/Grafana.py +133 -0
  141. WMCore/Services/MonIT/__init__.py +0 -0
  142. WMCore/Services/PyCondor/PyCondorAPI.py +154 -0
  143. WMCore/Services/PyCondor/PyCondorUtils.py +105 -0
  144. WMCore/Services/PyCondor/__init__.py +0 -0
  145. WMCore/Services/ReqMgr/ReqMgr.py +261 -0
  146. WMCore/Services/ReqMgr/__init__.py +0 -0
  147. WMCore/Services/ReqMgrAux/ReqMgrAux.py +419 -0
  148. WMCore/Services/ReqMgrAux/__init__.py +0 -0
  149. WMCore/Services/RequestDB/RequestDBReader.py +267 -0
  150. WMCore/Services/RequestDB/RequestDBWriter.py +39 -0
  151. WMCore/Services/RequestDB/__init__.py +0 -0
  152. WMCore/Services/Requests.py +624 -0
  153. WMCore/Services/Rucio/Rucio.py +1287 -0
  154. WMCore/Services/Rucio/RucioUtils.py +74 -0
  155. WMCore/Services/Rucio/__init__.py +0 -0
  156. WMCore/Services/RucioConMon/RucioConMon.py +128 -0
  157. WMCore/Services/RucioConMon/__init__.py +0 -0
  158. WMCore/Services/Service.py +400 -0
  159. WMCore/Services/StompAMQ/__init__.py +0 -0
  160. WMCore/Services/TagCollector/TagCollector.py +155 -0
  161. WMCore/Services/TagCollector/XMLUtils.py +98 -0
  162. WMCore/Services/TagCollector/__init__.py +0 -0
  163. WMCore/Services/UUIDLib.py +13 -0
  164. WMCore/Services/UserFileCache/UserFileCache.py +160 -0
  165. WMCore/Services/UserFileCache/__init__.py +8 -0
  166. WMCore/Services/WMAgent/WMAgent.py +63 -0
  167. WMCore/Services/WMAgent/__init__.py +0 -0
  168. WMCore/Services/WMArchive/CMSSWMetrics.py +526 -0
  169. WMCore/Services/WMArchive/DataMap.py +463 -0
  170. WMCore/Services/WMArchive/WMArchive.py +33 -0
  171. WMCore/Services/WMArchive/__init__.py +0 -0
  172. WMCore/Services/WMBS/WMBS.py +97 -0
  173. WMCore/Services/WMBS/__init__.py +0 -0
  174. WMCore/Services/WMStats/DataStruct/RequestInfoCollection.py +300 -0
  175. WMCore/Services/WMStats/DataStruct/__init__.py +0 -0
  176. WMCore/Services/WMStats/WMStatsPycurl.py +145 -0
  177. WMCore/Services/WMStats/WMStatsReader.py +445 -0
  178. WMCore/Services/WMStats/WMStatsWriter.py +273 -0
  179. WMCore/Services/WMStats/__init__.py +0 -0
  180. WMCore/Services/WMStatsServer/WMStatsServer.py +134 -0
  181. WMCore/Services/WMStatsServer/__init__.py +0 -0
  182. WMCore/Services/WorkQueue/WorkQueue.py +492 -0
  183. WMCore/Services/WorkQueue/__init__.py +0 -0
  184. WMCore/Services/__init__.py +8 -0
  185. WMCore/Services/pycurl_manager.py +574 -0
  186. WMCore/WMBase.py +50 -0
  187. WMCore/WMConnectionBase.py +164 -0
  188. WMCore/WMException.py +183 -0
  189. WMCore/WMExceptions.py +269 -0
  190. WMCore/WMFactory.py +76 -0
  191. WMCore/WMInit.py +228 -0
  192. WMCore/WMLogging.py +108 -0
  193. WMCore/WMSpec/ConfigSectionTree.py +442 -0
  194. WMCore/WMSpec/Persistency.py +135 -0
  195. WMCore/WMSpec/Steps/BuildMaster.py +87 -0
  196. WMCore/WMSpec/Steps/BuildTools.py +201 -0
  197. WMCore/WMSpec/Steps/Builder.py +97 -0
  198. WMCore/WMSpec/Steps/Diagnostic.py +89 -0
  199. WMCore/WMSpec/Steps/Emulator.py +62 -0
  200. WMCore/WMSpec/Steps/ExecuteMaster.py +208 -0
  201. WMCore/WMSpec/Steps/Executor.py +210 -0
  202. WMCore/WMSpec/Steps/StepFactory.py +213 -0
  203. WMCore/WMSpec/Steps/TaskEmulator.py +75 -0
  204. WMCore/WMSpec/Steps/Template.py +204 -0
  205. WMCore/WMSpec/Steps/Templates/AlcaHarvest.py +76 -0
  206. WMCore/WMSpec/Steps/Templates/CMSSW.py +613 -0
  207. WMCore/WMSpec/Steps/Templates/DQMUpload.py +59 -0
  208. WMCore/WMSpec/Steps/Templates/DeleteFiles.py +70 -0
  209. WMCore/WMSpec/Steps/Templates/LogArchive.py +84 -0
  210. WMCore/WMSpec/Steps/Templates/LogCollect.py +105 -0
  211. WMCore/WMSpec/Steps/Templates/StageOut.py +105 -0
  212. WMCore/WMSpec/Steps/Templates/__init__.py +10 -0
  213. WMCore/WMSpec/Steps/WMExecutionFailure.py +21 -0
  214. WMCore/WMSpec/Steps/__init__.py +8 -0
  215. WMCore/WMSpec/Utilities.py +63 -0
  216. WMCore/WMSpec/WMSpecErrors.py +12 -0
  217. WMCore/WMSpec/WMStep.py +347 -0
  218. WMCore/WMSpec/WMTask.py +1980 -0
  219. WMCore/WMSpec/WMWorkload.py +2288 -0
  220. WMCore/WMSpec/WMWorkloadTools.py +370 -0
  221. WMCore/WMSpec/__init__.py +9 -0
  222. WMCore/WorkQueue/DataLocationMapper.py +269 -0
  223. WMCore/WorkQueue/DataStructs/ACDCBlock.py +47 -0
  224. WMCore/WorkQueue/DataStructs/Block.py +48 -0
  225. WMCore/WorkQueue/DataStructs/CouchWorkQueueElement.py +148 -0
  226. WMCore/WorkQueue/DataStructs/WorkQueueElement.py +274 -0
  227. WMCore/WorkQueue/DataStructs/WorkQueueElementResult.py +152 -0
  228. WMCore/WorkQueue/DataStructs/WorkQueueElementsSummary.py +185 -0
  229. WMCore/WorkQueue/DataStructs/__init__.py +0 -0
  230. WMCore/WorkQueue/Policy/End/EndPolicyInterface.py +44 -0
  231. WMCore/WorkQueue/Policy/End/SingleShot.py +22 -0
  232. WMCore/WorkQueue/Policy/End/__init__.py +32 -0
  233. WMCore/WorkQueue/Policy/PolicyInterface.py +17 -0
  234. WMCore/WorkQueue/Policy/Start/Block.py +258 -0
  235. WMCore/WorkQueue/Policy/Start/Dataset.py +180 -0
  236. WMCore/WorkQueue/Policy/Start/MonteCarlo.py +131 -0
  237. WMCore/WorkQueue/Policy/Start/ResubmitBlock.py +171 -0
  238. WMCore/WorkQueue/Policy/Start/StartPolicyInterface.py +316 -0
  239. WMCore/WorkQueue/Policy/Start/__init__.py +34 -0
  240. WMCore/WorkQueue/Policy/__init__.py +57 -0
  241. WMCore/WorkQueue/WMBSHelper.py +772 -0
  242. WMCore/WorkQueue/WorkQueue.py +1237 -0
  243. WMCore/WorkQueue/WorkQueueBackend.py +741 -0
  244. WMCore/WorkQueue/WorkQueueBase.py +39 -0
  245. WMCore/WorkQueue/WorkQueueExceptions.py +44 -0
  246. WMCore/WorkQueue/WorkQueueReqMgrInterface.py +278 -0
  247. WMCore/WorkQueue/WorkQueueUtils.py +130 -0
  248. WMCore/WorkQueue/__init__.py +13 -0
  249. WMCore/Wrappers/JsonWrapper/JSONThunker.py +342 -0
  250. WMCore/Wrappers/JsonWrapper/__init__.py +7 -0
  251. WMCore/Wrappers/__init__.py +6 -0
  252. WMCore/__init__.py +10 -0
  253. wmglobalqueue-2.3.10rc10.data/data/bin/wmc-dist-patch +15 -0
  254. wmglobalqueue-2.3.10rc10.data/data/bin/wmc-dist-unpatch +8 -0
  255. wmglobalqueue-2.3.10rc10.data/data/bin/wmc-httpd +3 -0
  256. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/.couchapprc +1 -0
  257. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/README.md +40 -0
  258. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/_attachments/index.html +264 -0
  259. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/_attachments/js/ElementInfoByWorkflow.js +96 -0
  260. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/_attachments/js/StuckElementInfo.js +57 -0
  261. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/_attachments/js/WorkloadInfoTable.js +80 -0
  262. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/_attachments/js/dataTable.js +70 -0
  263. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/_attachments/js/namespace.js +23 -0
  264. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/_attachments/style/main.css +75 -0
  265. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/couchapp.json +4 -0
  266. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/filters/childQueueFilter.js +13 -0
  267. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/filters/filterDeletedDocs.js +3 -0
  268. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/filters/queueFilter.js +11 -0
  269. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/language +1 -0
  270. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/lib/mustache.js +333 -0
  271. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/lib/validate.js +27 -0
  272. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/lib/workqueue_utils.js +61 -0
  273. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/lists/elementsDetail.js +28 -0
  274. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/lists/filter.js +86 -0
  275. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/lists/stuckElements.js +38 -0
  276. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/lists/workRestrictions.js +153 -0
  277. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/lists/workflowSummary.js +28 -0
  278. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/rewrites.json +73 -0
  279. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/shows/redirect.js +23 -0
  280. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/shows/status.js +40 -0
  281. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/templates/ElementSummaryByWorkflow.html +27 -0
  282. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/templates/StuckElementSummary.html +26 -0
  283. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/templates/TaskStatus.html +23 -0
  284. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/templates/WorkflowSummary.html +27 -0
  285. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/templates/partials/workqueue-common-lib.html +2 -0
  286. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/templates/partials/yui-lib-remote.html +16 -0
  287. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/templates/partials/yui-lib.html +18 -0
  288. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/updates/in-place.js +50 -0
  289. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/validate_doc_update.js +8 -0
  290. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/vendor/couchapp/_attachments/jquery.couch.app.js +235 -0
  291. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/vendor/couchapp/_attachments/jquery.pathbinder.js +173 -0
  292. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/activeData/map.js +8 -0
  293. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/activeData/reduce.js +2 -0
  294. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/activeParentData/map.js +8 -0
  295. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/activeParentData/reduce.js +2 -0
  296. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/activePileupData/map.js +8 -0
  297. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/activePileupData/reduce.js +2 -0
  298. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/analyticsData/map.js +11 -0
  299. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/analyticsData/reduce.js +1 -0
  300. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/availableByPriority/map.js +6 -0
  301. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/conflicts/map.js +5 -0
  302. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elements/map.js +5 -0
  303. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsByData/map.js +8 -0
  304. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsByParent/map.js +8 -0
  305. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsByParentData/map.js +8 -0
  306. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsByPileupData/map.js +8 -0
  307. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsByStatus/map.js +8 -0
  308. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsBySubscription/map.js +6 -0
  309. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsByWorkflow/map.js +8 -0
  310. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsByWorkflow/reduce.js +3 -0
  311. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/elementsDetailByWorkflowAndStatus/map.js +26 -0
  312. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobInjectStatusByRequest/map.js +10 -0
  313. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobInjectStatusByRequest/reduce.js +1 -0
  314. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobStatusByRequest/map.js +6 -0
  315. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobStatusByRequest/reduce.js +1 -0
  316. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndPriority/map.js +6 -0
  317. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndPriority/reduce.js +1 -0
  318. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndStatus/map.js +6 -0
  319. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndStatus/reduce.js +1 -0
  320. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByRequest/map.js +6 -0
  321. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByRequest/reduce.js +1 -0
  322. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByStatus/map.js +6 -0
  323. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByStatus/reduce.js +1 -0
  324. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByStatusAndPriority/map.js +6 -0
  325. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/jobsByStatusAndPriority/reduce.js +1 -0
  326. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/openRequests/map.js +6 -0
  327. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/recent-items/map.js +5 -0
  328. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/siteWhitelistByRequest/map.js +6 -0
  329. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/siteWhitelistByRequest/reduce.js +1 -0
  330. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/specsByWorkflow/map.js +5 -0
  331. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/stuckElements/map.js +38 -0
  332. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/wmbsInjectStatusByRequest/map.js +12 -0
  333. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/wmbsInjectStatusByRequest/reduce.js +3 -0
  334. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/wmbsUrl/map.js +6 -0
  335. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/wmbsUrl/reduce.js +2 -0
  336. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/wmbsUrlByRequest/map.js +6 -0
  337. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/wmbsUrlByRequest/reduce.js +2 -0
  338. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/workflowSummary/map.js +9 -0
  339. wmglobalqueue-2.3.10rc10.data/data/data/couchapps/WorkQueue/views/workflowSummary/reduce.js +10 -0
  340. wmglobalqueue-2.3.10rc10.dist-info/METADATA +26 -0
  341. wmglobalqueue-2.3.10rc10.dist-info/RECORD +345 -0
  342. wmglobalqueue-2.3.10rc10.dist-info/WHEEL +5 -0
  343. wmglobalqueue-2.3.10rc10.dist-info/licenses/LICENSE +202 -0
  344. wmglobalqueue-2.3.10rc10.dist-info/licenses/NOTICE +16 -0
  345. wmglobalqueue-2.3.10rc10.dist-info/top_level.txt +2 -0
@@ -0,0 +1,153 @@
1
+ function(head, req) {
2
+
3
+ // Apply restrictions provided in query to find elements that can run
4
+ // at the given sites.
5
+
6
+ // Include checks on data location, site white/blacklists & team.
7
+
8
+ // Return at least one element for each site with free job slots,
9
+ // then take element size into account for further allocation.
10
+
11
+ if (!req.query.resources) {
12
+ send(toJSON({}));
13
+ return;
14
+ }
15
+
16
+ try {
17
+ var num_elem = JSON.parse(req.query.num_elem);
18
+ } catch (ex) {
19
+ send('"Error parsing number of elements" ' + req.query.num_elem);
20
+ return;
21
+ }
22
+
23
+ try {
24
+ var resources = JSON.parse(req.query.resources);
25
+ } catch (ex) {
26
+ send('"Error parsing resources" ' + req.query.resources);
27
+ return;
28
+ }
29
+
30
+ var team = "";
31
+ if (req.query.team) {
32
+ try {
33
+ team = JSON.parse(req.query.team);
34
+ } catch (ex) {
35
+ send('"Error parsing team" ' + req.query.team);
36
+ return;
37
+ }
38
+ }
39
+
40
+ var wfs = [];
41
+ if (req.query.wfs) {
42
+ try {
43
+ wfs = JSON.parse(req.query.wfs);
44
+ } catch (ex) {
45
+ send('"Error parsing wfs" ' + req.query.wfs);
46
+ return;
47
+ }
48
+ }
49
+
50
+ send("[");
51
+ // loop over elements, applying site restrictions
52
+ var first = true;
53
+ while (row = getRow()) {
54
+
55
+ if (resources.length == 0) {
56
+ break;
57
+ }
58
+
59
+ if (num_elem <= 0) {
60
+ break;
61
+ }
62
+
63
+ //in case document is already deleted
64
+ if (!row.doc) {
65
+ continue;
66
+ };
67
+
68
+ var ele = row["doc"]["WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement"];
69
+
70
+ // check work is for a team in the request
71
+ if (team && ele["TeamName"] && team !== ele["TeamName"]) {
72
+ continue;
73
+ }
74
+
75
+ // skip if we only want work from certain wf's which don't include this one.
76
+ if (wfs.length && wfs.indexOf(ele["RequestName"]) == -1) {
77
+ continue;
78
+ }
79
+
80
+ for (var site in resources) {
81
+ // skip if in blacklist
82
+ if (ele["SiteBlacklist"].indexOf(site) !== -1) {
83
+ continue;
84
+ }
85
+
86
+ //skip if not in whitelist
87
+ if (ele["SiteWhitelist"].indexOf(site) === -1) {
88
+ continue;
89
+ }
90
+
91
+ // Input data location restrictions
92
+ // don't check input data location if trustSitelists is enabled
93
+ var noInputSite = false;
94
+ if (ele["NoInputUpdate"] === true) {
95
+ noInputSite = false;
96
+ } else if (ele["Inputs"]) {
97
+ for (block in ele['Inputs']) {
98
+ if (ele['Inputs'][block].indexOf(site) === -1) {
99
+ noInputSite = true;
100
+ break;
101
+ }
102
+ }
103
+ }
104
+ if (noInputSite) {
105
+ continue;
106
+ }
107
+
108
+ // Pileup data location restrictions, all pileup datasets must be at the site
109
+ // don't check pileup data location if trustPUSitelists
110
+ var noPileupSite = false;
111
+ if (ele["NoPileupUpdate"] === true) {
112
+ noPileupSite = false;
113
+ } else if (ele["PileupData"]) {
114
+ for(dataset in ele["PileupData"]) {
115
+ if(ele["PileupData"][dataset].indexOf(site) === -1) {
116
+ noPileupSite = true;
117
+ break;
118
+ }
119
+ }
120
+ }
121
+ if (noPileupSite){
122
+ continue;
123
+ }
124
+
125
+ //skip if parent processing flag is set and parent block is not in the site.
126
+ //all the parent block has to be in the same site
127
+ var noParentSite = false;
128
+ if (ele["NoInputUpdate"] === true) {
129
+ noParentSite = false;
130
+ } else if (ele["ParentFlag"]) {
131
+ for (block in ele["ParentData"]) {
132
+ if (ele["ParentData"][block].indexOf(site) === -1) {
133
+ noParentSite = true;
134
+ break;
135
+ }
136
+ }
137
+ }
138
+ if (noParentSite) {
139
+ continue;
140
+ }
141
+
142
+ if (first !== true) {
143
+ send(",");
144
+ }
145
+ send(toJSON(row["doc"])); // need whole document, id etc...
146
+ first = false; // from now on prepend "," to output
147
+ num_elem--; // decrement the counter for the number of elements
148
+ break; // we have work, move to next element (break out of site loop)
149
+ } // end resources
150
+ } // end rows
151
+
152
+ send("]");
153
+ } // end function
@@ -0,0 +1,28 @@
1
+ function(head, req) {
2
+ // this function is used for elementsDetailByWorkflowAndStatus
3
+ var mainDoc = this;
4
+ provides("html", function() {
5
+ var Mustache = require("lib/mustache");
6
+ var requestInfo;
7
+ if (req.query.key) {
8
+ requestInfo = {request: req.query.key};
9
+ } else {
10
+ requestInfo = {request: ""};
11
+ }
12
+ return Mustache.to_html(mainDoc.templates.WorkflowSummary,
13
+ requestInfo, mainDoc.templates.partials, send);
14
+ });
15
+
16
+ provides("json", function() {
17
+ send("[");
18
+ var row = getRow();
19
+ if (row) {
20
+ send(toJSON(row.value));
21
+ while (row = getRow()){
22
+ send(",");
23
+ send(toJSON(row.value));
24
+ }
25
+ }// end rows
26
+ send("]");
27
+ });
28
+ } // end function
@@ -0,0 +1,73 @@
1
+ [
2
+ {"from": "elementsInfo",
3
+ "to": "_list/elementsDetail/elementsDetailByWorkflowAndStatus",
4
+ "method": "GET",
5
+ "query": {"startkey": [":request"],
6
+ "endkey": [":request", {}],
7
+ "reduce": "false"
8
+ }
9
+ },
10
+
11
+ {"from": "workflowInfo",
12
+ "to": "_list/workflowSummary/workflowSummary",
13
+ "method": "GET",
14
+ "query": {"group": "true"
15
+ }
16
+ },
17
+
18
+ {"from": "stuckElementsInfo",
19
+ "to": "_list/stuckElements/stuckElements",
20
+ "method": "GET",
21
+ "query" : {"include_docs" : "true"}
22
+ },
23
+
24
+ {
25
+ "from": "index.html",
26
+ "to": "index.html"
27
+ },
28
+
29
+ {
30
+ "from": "",
31
+ "to": "_show/redirect"
32
+ },
33
+
34
+ {
35
+ "from": "vendor/*",
36
+ "to": "vendor/*"
37
+ },
38
+
39
+ {
40
+ "from": "config/*",
41
+ "to": "config/*"
42
+ },
43
+
44
+ {
45
+ "from": "_view/*",
46
+ "to": "_view/*"
47
+ },
48
+
49
+ {
50
+ "from": "_list/*",
51
+ "to": "_list/*"
52
+ },
53
+
54
+ {
55
+ "from": "_show/*",
56
+ "to": "_show/*"
57
+ },
58
+
59
+ {
60
+ "from": "_update/*",
61
+ "to": "_update/*"
62
+ },
63
+
64
+ {
65
+ "from": "js/*",
66
+ "to": "js/*"
67
+ },
68
+
69
+ {
70
+ "from": "element/:id",
71
+ "to": "../../:id"
72
+ }
73
+ ]
@@ -0,0 +1,23 @@
1
+ function(doc, req) {
2
+ // redirect from _rewrite to index.html - only call this from _rewrite
3
+ // See http://wiki.apache.org/couchdb/Throw%20a%20404%20or%20a%20redirect
4
+ if (req.headers['Cms-Request-Uri']) {
5
+ // we are behind a cms frontend which is proxying requests
6
+ var http = req.headers.Https === 'on' ? 'https://' : 'http://';
7
+ var uri = req.headers['Cms-Request-Uri'];
8
+ if (uri.length > 0) {
9
+ uri = uri[uri.length - 1] === '/' ? uri : uri + '/';
10
+ }
11
+ var location = http + req.headers['X-Forwarded-Host'] + uri + 'index.html';
12
+ } else {
13
+ // assemble uri from path - assume http
14
+ req.path.pop(); req.path.pop(); // need to remove '_show/redirect' from uri
15
+ var location = 'http://' + req.headers.Host + '/' + req.path.join('/') + '/_rewrite/index.html';
16
+ }
17
+
18
+ var redirect = {code : 301,
19
+ headers : {"Location" : location
20
+ }
21
+ };
22
+ return redirect;
23
+ }
@@ -0,0 +1,40 @@
1
+ function(doc, req) {
2
+ var mainDoc = this
3
+ var data = {tasks : []}
4
+ var now = new Date()
5
+
6
+ for (var name in doc.tasks) {
7
+ if (doc.tasks.hasOwnProperty(name) === false) {
8
+ continue;
9
+ }
10
+ var task = doc.tasks[name]
11
+ // convert {} to [] - must be a better way...
12
+ task['name'] = name;
13
+ // convert time stamp to Date object
14
+ var timestamp = new Date(task['timestamp'] * 1000);
15
+ task['timestamp'] = timestamp.toUTCString();
16
+ // mark if not run recently (2 hours)
17
+ if ((now - timestamp) < 7200000) {
18
+ task['uptodate'] = true
19
+ }
20
+ data.tasks.push(doc.tasks[name]);
21
+ }
22
+
23
+ provides("html", function() {
24
+ var Mustache = require("lib/mustache");
25
+ html_out = Mustache.to_html(mainDoc.templates.TaskStatus, data);
26
+ return {body : html_out,
27
+ headers: {
28
+ "Content-Type": "text/html",
29
+ "Cache-Control" : "no-cache" // need to recompute even if etag the same
30
+ }};
31
+ })
32
+
33
+ provides("json", function() {
34
+ return {body : toJSON(data),
35
+ headers: {
36
+ "Content-Type": "application/json",
37
+ "Cache-Control" : "no-cache" // need to recompute even if etag the same
38
+ }};
39
+ })
40
+ } // end function
@@ -0,0 +1,27 @@
1
+ <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
2
+ <html>
3
+ <head>
4
+ <title> {{request}} : WorkQueue Elements</title>
5
+ <!--YUI Library -->
6
+ {{>yui-lib}}
7
+
8
+ <!-- WorkQueue library -->
9
+ {{>workqueue-common-lib}}
10
+
11
+ <script src="js/ElementInfoByWorkflow.js"></script>
12
+
13
+ </head>
14
+ <body class="yui-skin-sam">
15
+ <h3> Workqueue Elements for {{request}} </h3>
16
+ <div id="elements"></div>
17
+ <script>
18
+
19
+ var oArgs = {};
20
+ oArgs.divID = "elements";
21
+ oArgs.workflow = "{{{request}}}";
22
+
23
+ WQ.ElementInfoByWorkflow.elementTable(oArgs);
24
+
25
+ </script>
26
+ </body>
27
+ </html>
@@ -0,0 +1,26 @@
1
+ <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
2
+ <html>
3
+ <head>
4
+ <title> Stuck WorkQueue Elements</title>
5
+ <!--YUI Library -->
6
+ {{>yui-lib}}
7
+
8
+ <!-- WorkQueue library -->
9
+ {{>workqueue-common-lib}}
10
+
11
+ <script src="js/StuckElementInfo.js"></script>
12
+
13
+ </head>
14
+ <body class="yui-skin-sam">
15
+ <h3> Stuck Workqueue Elements </h3>
16
+ <div id="elements"></div>
17
+ <script>
18
+
19
+ var oArgs = {};
20
+ oArgs.divID = "elements";
21
+
22
+ WQ.StuckElementInfo.elementTable(oArgs);
23
+
24
+ </script>
25
+ </body>
26
+ </html>
@@ -0,0 +1,23 @@
1
+ <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
2
+ <html>
3
+ <head>
4
+ <title>WorkQueue task status</title>
5
+ </head>
6
+ <body>
7
+ <h3>Status of periodic tasks</h3>
8
+ <div id="tasks">
9
+ <table cellspacing="10" align="center">
10
+ <th>Name</th><th>Last run</th><th>Status</th><th>Info</th>
11
+ {{#tasks}}
12
+ <tr>
13
+ <td>{{name}}</td><td>{{timestamp}}</td>
14
+ <td>{{#uptodate}}ok{{/uptodate}}{{^uptodate}}ERROR! Task not run recently{{/uptodate}}</td>
15
+ <td>{{comment}}</td>
16
+ </tr>
17
+ {{/tasks}}
18
+
19
+ </table>
20
+ </div>
21
+
22
+ </body>
23
+ </html>
@@ -0,0 +1,27 @@
1
+ <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
2
+ <html>
3
+ <head>
4
+ <title> {{request}} : Workflow Summary</title>
5
+ <!--YUI Library -->
6
+ {{>yui-lib}}
7
+
8
+ <!-- WorkQueue library -->
9
+ {{>workqueue-common-lib}}
10
+
11
+ <script src="js/WorkloadInfoTable.js"></script>
12
+
13
+ </head>
14
+ <body class="yui-skin-sam">
15
+ <h3> Workflow Summary for {{request}} </h3>
16
+ <div id="workflow"></div>
17
+ <script>
18
+
19
+ var oArgs = {};
20
+ oArgs.divID = "workflow";
21
+ oArgs.workflow = "{{{request}}}";
22
+
23
+ WQ.WorkloadInfoTable.workloadTable(oArgs);
24
+
25
+ </script>
26
+ </body>
27
+ </html>
@@ -0,0 +1,2 @@
1
+ <script src="js/namespace.js"></script>
2
+ <script src="js/dataTable.js"></script>
@@ -0,0 +1,16 @@
1
+ <!-- YAHOO YUI Library -->
2
+ <link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/2.8.0r4/build/fonts/fonts-min.css" />
3
+ <link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/2.8.0r4/build/paginator/assets/skins/sam/paginator.css" />
4
+ <link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/2.8.0r4/build/datatable/assets/skins/sam/datatable.css" />
5
+ <!--
6
+ <script type="text/javascript" src="http://yui.yahooapis.com/combo?2.8.0r4/build/yahoo-dom-event/yahoo-dom-event.js&2.8.0r4/build/connection/connection-min.js&2.8.0r4/build/datasource/datasource-min.js&2.8.0r4/build/datatable/datatable-min.js&2.8.0r4/build/json/json-min.js"></script>
7
+ -->
8
+
9
+ <script src="http://yui.yahooapis.com/2.8.0r4/build/yahoo-dom-event/yahoo-dom-event.js"></script>
10
+ <script src="http://yui.yahooapis.com/2.8.0r4/build/dragdrop/dragdrop-min.js"></script>
11
+ <script src="http://yui.yahooapis.com/2.8.0r4/build/connection/connection-min.js"></script>
12
+ <script src="http://yui.yahooapis.com/2.8.0r4/build/element/element-min.js"></script>
13
+ <script src="http://yui.yahooapis.com/2.8.0r4/build/datasource/datasource-min.js"></script>
14
+ <script src="http://yui.yahooapis.com/2.8.0r4/build/datatable/datatable-min.js"></script>
15
+ <script src="http://yui.yahooapis.com/2.8.0r4/build/json/json-min.js"></script>
16
+ <script src="http://yui.yahooapis.com/2.8.0r4/build/paginator/paginator-min.js"></script>
@@ -0,0 +1,18 @@
1
+ <!-- YAHOO YUI Library -->
2
+ <link rel="stylesheet" type="text/css" href="vendor/yui/build/fonts/fonts-min.css" />
3
+ <link rel="stylesheet" type="text/css" href="vendor/yui/build/paginator/assets/skins/sam/paginator.css" />
4
+ <link rel="stylesheet" type="text/css" href="vendor/yui/build/datatable/assets/skins/sam/datatable.css" />
5
+ <link rel="stylesheet" type="text/css" href="vendor/yui/build/progressbar/assets/skins/sam/progressbar.css" />
6
+ <!--
7
+ <script type="text/javascript" src="http://yui.yahooapis.com/combo?2.8.0r4/build/yahoo-dom-event/yahoo-dom-event.js&2.8.0r4/build/connection/connection-min.js&2.8.0r4/build/datasource/datasource-min.js&2.8.0r4/build/datatable/datatable-min.js&2.8.0r4/build/json/json-min.js"></script>
8
+ -->
9
+
10
+ <script src="vendor/yui/build/yahoo-dom-event/yahoo-dom-event.js"></script>
11
+ <script src="vendor/yui/build/dragdrop/dragdrop-min.js"></script>
12
+ <script src="vendor/yui/build/connection/connection-min.js"></script>
13
+ <script src="vendor/yui/build/element/element-min.js"></script>
14
+ <script src="vendor/yui/build/datasource/datasource-min.js"></script>
15
+ <script src="vendor/yui/build/datatable/datatable-min.js"></script>
16
+ <script src="vendor/yui/build/json/json-min.js"></script>
17
+ <script src="vendor/yui/build/paginator/paginator-min.js"></script>
18
+ <script src="vendor/yui/build/progressbar/progressbar-min.js"></script>
@@ -0,0 +1,50 @@
1
+ // update arbitrary fields
2
+ // adapted from http://wiki.apache.org/couchdb/Document_Update_Handlers
3
+ function(doc, req) {
4
+ if (!req.query.updates) {
5
+ return [doc, '"No updates provided"'];
6
+ }
7
+
8
+ try {
9
+ var updates = JSON.parse(req.query.updates);
10
+ } catch (ex) {
11
+ return [doc, '"Error parsing JSON"'];
12
+ }
13
+
14
+ try {
15
+ var options = JSON.parse(req.query.options);
16
+ } catch (ex) {
17
+ return [doc, '"Error parsing JSON"'];
18
+ }
19
+
20
+ for (var field in updates) {
21
+ var value = updates[field];
22
+ var ele = doc['WMCore.WorkQueue.DataStructs.WorkQueueElement.WorkQueueElement'];
23
+
24
+ // attempt to preserve type
25
+ var type = typeof(ele[field]);
26
+ if (type === "number") {
27
+ value = parseFloat(value);
28
+ }
29
+ // Check if we are doing incremental updates
30
+ // Currently only supports arrays
31
+ if ("incremental" in options && options["incremental"]){
32
+ if ((Object.prototype.toString.call(ele[field]) === '[object Array]')){
33
+ for(var i = 0; i < value.length; i++){
34
+ singleValue = value[i]
35
+ ele[field].push(singleValue)
36
+ }
37
+ } else {
38
+ // Unsupported type
39
+ ele[field] = value;
40
+ }
41
+ } else {
42
+ ele[field] = value;
43
+ }
44
+ }
45
+
46
+ //record update time
47
+ doc.updatetime = new Date().getTime() / 1000; // epoch seconds
48
+
49
+ return [doc, ''];
50
+ }
@@ -0,0 +1,8 @@
1
+ function(newDoc, oldDoc, userCtx) {
2
+ // Check permissions and filter out replication of _deleted docs
3
+
4
+ if (newDoc._deleted === true && !oldDoc) {
5
+ throw({forbidden: 'Do not create deleted docs'});
6
+ }
7
+
8
+ }