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.
- Utils/CPMetrics.py +270 -0
- Utils/CertTools.py +100 -0
- Utils/EmailAlert.py +50 -0
- Utils/ExtendedUnitTestCase.py +62 -0
- Utils/FileTools.py +182 -0
- Utils/IteratorTools.py +80 -0
- Utils/MathUtils.py +31 -0
- Utils/MemoryCache.py +119 -0
- Utils/Patterns.py +24 -0
- Utils/Pipeline.py +137 -0
- Utils/PortForward.py +97 -0
- Utils/ProcFS.py +112 -0
- Utils/ProcessStats.py +194 -0
- Utils/PythonVersion.py +17 -0
- Utils/Signals.py +36 -0
- Utils/TemporaryEnvironment.py +27 -0
- Utils/Throttled.py +227 -0
- Utils/Timers.py +130 -0
- Utils/Timestamps.py +86 -0
- Utils/TokenManager.py +143 -0
- Utils/Tracing.py +60 -0
- Utils/TwPrint.py +98 -0
- Utils/Utilities.py +318 -0
- Utils/__init__.py +11 -0
- Utils/wmcoreDTools.py +707 -0
- WMCore/ACDC/Collection.py +57 -0
- WMCore/ACDC/CollectionTypes.py +12 -0
- WMCore/ACDC/CouchCollection.py +67 -0
- WMCore/ACDC/CouchFileset.py +238 -0
- WMCore/ACDC/CouchService.py +73 -0
- WMCore/ACDC/DataCollectionService.py +485 -0
- WMCore/ACDC/Fileset.py +94 -0
- WMCore/ACDC/__init__.py +11 -0
- WMCore/Algorithms/Alarm.py +39 -0
- WMCore/Algorithms/MathAlgos.py +274 -0
- WMCore/Algorithms/MiscAlgos.py +67 -0
- WMCore/Algorithms/ParseXMLFile.py +115 -0
- WMCore/Algorithms/Permissions.py +27 -0
- WMCore/Algorithms/Singleton.py +58 -0
- WMCore/Algorithms/SubprocessAlgos.py +129 -0
- WMCore/Algorithms/__init__.py +7 -0
- WMCore/Cache/GenericDataCache.py +98 -0
- WMCore/Cache/WMConfigCache.py +572 -0
- WMCore/Cache/__init__.py +0 -0
- WMCore/Configuration.py +659 -0
- WMCore/DAOFactory.py +47 -0
- WMCore/DataStructs/File.py +177 -0
- WMCore/DataStructs/Fileset.py +140 -0
- WMCore/DataStructs/Job.py +182 -0
- WMCore/DataStructs/JobGroup.py +142 -0
- WMCore/DataStructs/JobPackage.py +49 -0
- WMCore/DataStructs/LumiList.py +734 -0
- WMCore/DataStructs/Mask.py +219 -0
- WMCore/DataStructs/MathStructs/ContinuousSummaryHistogram.py +197 -0
- WMCore/DataStructs/MathStructs/DiscreteSummaryHistogram.py +92 -0
- WMCore/DataStructs/MathStructs/SummaryHistogram.py +117 -0
- WMCore/DataStructs/MathStructs/__init__.py +0 -0
- WMCore/DataStructs/Pickleable.py +24 -0
- WMCore/DataStructs/Run.py +256 -0
- WMCore/DataStructs/Subscription.py +175 -0
- WMCore/DataStructs/WMObject.py +47 -0
- WMCore/DataStructs/WorkUnit.py +112 -0
- WMCore/DataStructs/Workflow.py +60 -0
- WMCore/DataStructs/__init__.py +8 -0
- WMCore/Database/CMSCouch.py +1430 -0
- WMCore/Database/ConfigDBMap.py +29 -0
- WMCore/Database/CouchMonitoring.py +450 -0
- WMCore/Database/CouchUtils.py +118 -0
- WMCore/Database/DBCore.py +198 -0
- WMCore/Database/DBCreator.py +113 -0
- WMCore/Database/DBExceptionHandler.py +59 -0
- WMCore/Database/DBFactory.py +117 -0
- WMCore/Database/DBFormatter.py +177 -0
- WMCore/Database/Dialects.py +13 -0
- WMCore/Database/ExecuteDAO.py +327 -0
- WMCore/Database/MongoDB.py +241 -0
- WMCore/Database/MySQL/Destroy.py +42 -0
- WMCore/Database/MySQL/ListUserContent.py +20 -0
- WMCore/Database/MySQL/__init__.py +9 -0
- WMCore/Database/MySQLCore.py +132 -0
- WMCore/Database/Oracle/Destroy.py +56 -0
- WMCore/Database/Oracle/ListUserContent.py +19 -0
- WMCore/Database/Oracle/__init__.py +9 -0
- WMCore/Database/ResultSet.py +44 -0
- WMCore/Database/Transaction.py +91 -0
- WMCore/Database/__init__.py +9 -0
- WMCore/Database/ipy_profile_couch.py +438 -0
- WMCore/GlobalWorkQueue/CherryPyThreads/CleanUpTask.py +29 -0
- WMCore/GlobalWorkQueue/CherryPyThreads/HeartbeatMonitor.py +105 -0
- WMCore/GlobalWorkQueue/CherryPyThreads/LocationUpdateTask.py +28 -0
- WMCore/GlobalWorkQueue/CherryPyThreads/ReqMgrInteractionTask.py +35 -0
- WMCore/GlobalWorkQueue/CherryPyThreads/__init__.py +0 -0
- WMCore/GlobalWorkQueue/__init__.py +0 -0
- WMCore/GroupUser/CouchObject.py +127 -0
- WMCore/GroupUser/Decorators.py +51 -0
- WMCore/GroupUser/Group.py +33 -0
- WMCore/GroupUser/Interface.py +73 -0
- WMCore/GroupUser/User.py +96 -0
- WMCore/GroupUser/__init__.py +11 -0
- WMCore/Lexicon.py +836 -0
- WMCore/REST/Auth.py +202 -0
- WMCore/REST/CherryPyPeriodicTask.py +166 -0
- WMCore/REST/Error.py +333 -0
- WMCore/REST/Format.py +642 -0
- WMCore/REST/HeartbeatMonitorBase.py +90 -0
- WMCore/REST/Main.py +636 -0
- WMCore/REST/Server.py +2435 -0
- WMCore/REST/Services.py +24 -0
- WMCore/REST/Test.py +120 -0
- WMCore/REST/Tools.py +38 -0
- WMCore/REST/Validation.py +250 -0
- WMCore/REST/__init__.py +1 -0
- WMCore/ReqMgr/DataStructs/RequestStatus.py +209 -0
- WMCore/ReqMgr/DataStructs/RequestType.py +13 -0
- WMCore/ReqMgr/DataStructs/__init__.py +0 -0
- WMCore/ReqMgr/__init__.py +1 -0
- WMCore/Services/AlertManager/AlertManagerAPI.py +111 -0
- WMCore/Services/AlertManager/__init__.py +0 -0
- WMCore/Services/CRIC/CRIC.py +238 -0
- WMCore/Services/CRIC/__init__.py +0 -0
- WMCore/Services/DBS/DBS3Reader.py +1044 -0
- WMCore/Services/DBS/DBSConcurrency.py +44 -0
- WMCore/Services/DBS/DBSErrors.py +112 -0
- WMCore/Services/DBS/DBSReader.py +23 -0
- WMCore/Services/DBS/DBSUtils.py +166 -0
- WMCore/Services/DBS/DBSWriterObjects.py +381 -0
- WMCore/Services/DBS/ProdException.py +133 -0
- WMCore/Services/DBS/__init__.py +8 -0
- WMCore/Services/FWJRDB/FWJRDBAPI.py +118 -0
- WMCore/Services/FWJRDB/__init__.py +0 -0
- WMCore/Services/HTTPS/HTTPSAuthHandler.py +66 -0
- WMCore/Services/HTTPS/__init__.py +0 -0
- WMCore/Services/LogDB/LogDB.py +201 -0
- WMCore/Services/LogDB/LogDBBackend.py +191 -0
- WMCore/Services/LogDB/LogDBExceptions.py +11 -0
- WMCore/Services/LogDB/LogDBReport.py +85 -0
- WMCore/Services/LogDB/__init__.py +0 -0
- WMCore/Services/MSPileup/__init__.py +0 -0
- WMCore/Services/MSUtils/MSUtils.py +54 -0
- WMCore/Services/MSUtils/__init__.py +0 -0
- WMCore/Services/McM/McM.py +173 -0
- WMCore/Services/McM/__init__.py +8 -0
- WMCore/Services/MonIT/Grafana.py +133 -0
- WMCore/Services/MonIT/__init__.py +0 -0
- WMCore/Services/PyCondor/PyCondorAPI.py +154 -0
- WMCore/Services/PyCondor/__init__.py +0 -0
- WMCore/Services/ReqMgr/ReqMgr.py +261 -0
- WMCore/Services/ReqMgr/__init__.py +0 -0
- WMCore/Services/ReqMgrAux/ReqMgrAux.py +419 -0
- WMCore/Services/ReqMgrAux/__init__.py +0 -0
- WMCore/Services/RequestDB/RequestDBReader.py +267 -0
- WMCore/Services/RequestDB/RequestDBWriter.py +39 -0
- WMCore/Services/RequestDB/__init__.py +0 -0
- WMCore/Services/Requests.py +624 -0
- WMCore/Services/Rucio/Rucio.py +1290 -0
- WMCore/Services/Rucio/RucioUtils.py +74 -0
- WMCore/Services/Rucio/__init__.py +0 -0
- WMCore/Services/RucioConMon/RucioConMon.py +121 -0
- WMCore/Services/RucioConMon/__init__.py +0 -0
- WMCore/Services/Service.py +400 -0
- WMCore/Services/StompAMQ/__init__.py +0 -0
- WMCore/Services/TagCollector/TagCollector.py +155 -0
- WMCore/Services/TagCollector/XMLUtils.py +98 -0
- WMCore/Services/TagCollector/__init__.py +0 -0
- WMCore/Services/UUIDLib.py +13 -0
- WMCore/Services/UserFileCache/UserFileCache.py +160 -0
- WMCore/Services/UserFileCache/__init__.py +8 -0
- WMCore/Services/WMAgent/WMAgent.py +63 -0
- WMCore/Services/WMAgent/__init__.py +0 -0
- WMCore/Services/WMArchive/CMSSWMetrics.py +526 -0
- WMCore/Services/WMArchive/DataMap.py +463 -0
- WMCore/Services/WMArchive/WMArchive.py +33 -0
- WMCore/Services/WMArchive/__init__.py +0 -0
- WMCore/Services/WMBS/WMBS.py +97 -0
- WMCore/Services/WMBS/__init__.py +0 -0
- WMCore/Services/WMStats/DataStruct/RequestInfoCollection.py +300 -0
- WMCore/Services/WMStats/DataStruct/__init__.py +0 -0
- WMCore/Services/WMStats/WMStatsPycurl.py +145 -0
- WMCore/Services/WMStats/WMStatsReader.py +445 -0
- WMCore/Services/WMStats/WMStatsWriter.py +273 -0
- WMCore/Services/WMStats/__init__.py +0 -0
- WMCore/Services/WMStatsServer/WMStatsServer.py +134 -0
- WMCore/Services/WMStatsServer/__init__.py +0 -0
- WMCore/Services/WorkQueue/WorkQueue.py +492 -0
- WMCore/Services/WorkQueue/__init__.py +0 -0
- WMCore/Services/__init__.py +8 -0
- WMCore/Services/pycurl_manager.py +574 -0
- WMCore/WMBase.py +50 -0
- WMCore/WMConnectionBase.py +164 -0
- WMCore/WMException.py +183 -0
- WMCore/WMExceptions.py +269 -0
- WMCore/WMFactory.py +76 -0
- WMCore/WMInit.py +377 -0
- WMCore/WMLogging.py +104 -0
- WMCore/WMSpec/ConfigSectionTree.py +442 -0
- WMCore/WMSpec/Persistency.py +135 -0
- WMCore/WMSpec/Steps/BuildMaster.py +87 -0
- WMCore/WMSpec/Steps/BuildTools.py +201 -0
- WMCore/WMSpec/Steps/Builder.py +97 -0
- WMCore/WMSpec/Steps/Diagnostic.py +89 -0
- WMCore/WMSpec/Steps/Emulator.py +62 -0
- WMCore/WMSpec/Steps/ExecuteMaster.py +208 -0
- WMCore/WMSpec/Steps/Executor.py +210 -0
- WMCore/WMSpec/Steps/StepFactory.py +213 -0
- WMCore/WMSpec/Steps/TaskEmulator.py +75 -0
- WMCore/WMSpec/Steps/Template.py +204 -0
- WMCore/WMSpec/Steps/Templates/AlcaHarvest.py +76 -0
- WMCore/WMSpec/Steps/Templates/CMSSW.py +613 -0
- WMCore/WMSpec/Steps/Templates/DQMUpload.py +59 -0
- WMCore/WMSpec/Steps/Templates/DeleteFiles.py +70 -0
- WMCore/WMSpec/Steps/Templates/LogArchive.py +84 -0
- WMCore/WMSpec/Steps/Templates/LogCollect.py +105 -0
- WMCore/WMSpec/Steps/Templates/StageOut.py +105 -0
- WMCore/WMSpec/Steps/Templates/__init__.py +10 -0
- WMCore/WMSpec/Steps/WMExecutionFailure.py +21 -0
- WMCore/WMSpec/Steps/__init__.py +8 -0
- WMCore/WMSpec/Utilities.py +63 -0
- WMCore/WMSpec/WMSpecErrors.py +12 -0
- WMCore/WMSpec/WMStep.py +347 -0
- WMCore/WMSpec/WMTask.py +1997 -0
- WMCore/WMSpec/WMWorkload.py +2288 -0
- WMCore/WMSpec/WMWorkloadTools.py +382 -0
- WMCore/WMSpec/__init__.py +9 -0
- WMCore/WorkQueue/DataLocationMapper.py +273 -0
- WMCore/WorkQueue/DataStructs/ACDCBlock.py +47 -0
- WMCore/WorkQueue/DataStructs/Block.py +48 -0
- WMCore/WorkQueue/DataStructs/CouchWorkQueueElement.py +148 -0
- WMCore/WorkQueue/DataStructs/WorkQueueElement.py +274 -0
- WMCore/WorkQueue/DataStructs/WorkQueueElementResult.py +152 -0
- WMCore/WorkQueue/DataStructs/WorkQueueElementsSummary.py +185 -0
- WMCore/WorkQueue/DataStructs/__init__.py +0 -0
- WMCore/WorkQueue/Policy/End/EndPolicyInterface.py +44 -0
- WMCore/WorkQueue/Policy/End/SingleShot.py +22 -0
- WMCore/WorkQueue/Policy/End/__init__.py +32 -0
- WMCore/WorkQueue/Policy/PolicyInterface.py +17 -0
- WMCore/WorkQueue/Policy/Start/Block.py +258 -0
- WMCore/WorkQueue/Policy/Start/Dataset.py +180 -0
- WMCore/WorkQueue/Policy/Start/MonteCarlo.py +131 -0
- WMCore/WorkQueue/Policy/Start/ResubmitBlock.py +171 -0
- WMCore/WorkQueue/Policy/Start/StartPolicyInterface.py +316 -0
- WMCore/WorkQueue/Policy/Start/__init__.py +34 -0
- WMCore/WorkQueue/Policy/__init__.py +57 -0
- WMCore/WorkQueue/WMBSHelper.py +772 -0
- WMCore/WorkQueue/WorkQueue.py +1237 -0
- WMCore/WorkQueue/WorkQueueBackend.py +750 -0
- WMCore/WorkQueue/WorkQueueBase.py +39 -0
- WMCore/WorkQueue/WorkQueueExceptions.py +44 -0
- WMCore/WorkQueue/WorkQueueReqMgrInterface.py +278 -0
- WMCore/WorkQueue/WorkQueueUtils.py +130 -0
- WMCore/WorkQueue/__init__.py +13 -0
- WMCore/Wrappers/JsonWrapper/JSONThunker.py +342 -0
- WMCore/Wrappers/JsonWrapper/__init__.py +7 -0
- WMCore/Wrappers/__init__.py +6 -0
- WMCore/__init__.py +10 -0
- wmglobalqueue-2.4.5.1.data/data/bin/wmc-dist-patch +15 -0
- wmglobalqueue-2.4.5.1.data/data/bin/wmc-dist-unpatch +8 -0
- wmglobalqueue-2.4.5.1.data/data/bin/wmc-httpd +3 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/.couchapprc +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/README.md +40 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/index.html +264 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/ElementInfoByWorkflow.js +96 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/StuckElementInfo.js +57 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/WorkloadInfoTable.js +80 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/dataTable.js +70 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/js/namespace.js +23 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/_attachments/style/main.css +75 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/couchapp.json +4 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/filters/childQueueFilter.js +13 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/filters/filterDeletedDocs.js +3 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/filters/queueFilter.js +11 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/language +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lib/mustache.js +333 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lib/validate.js +27 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lib/workqueue_utils.js +61 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/elementsDetail.js +28 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/filter.js +86 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/stuckElements.js +38 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/workRestrictions.js +153 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/lists/workflowSummary.js +28 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/rewrites.json +73 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/shows/redirect.js +23 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/shows/status.js +40 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/ElementSummaryByWorkflow.html +27 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/StuckElementSummary.html +26 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/TaskStatus.html +23 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/WorkflowSummary.html +27 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/partials/workqueue-common-lib.html +2 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/partials/yui-lib-remote.html +16 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/templates/partials/yui-lib.html +18 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/updates/in-place.js +50 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/validate_doc_update.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/vendor/couchapp/_attachments/jquery.couch.app.js +235 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/vendor/couchapp/_attachments/jquery.pathbinder.js +173 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activeData/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activeData/reduce.js +2 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activeParentData/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activeParentData/reduce.js +2 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activePileupData/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/activePileupData/reduce.js +2 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/analyticsData/map.js +11 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/analyticsData/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/availableByPriority/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/conflicts/map.js +5 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elements/map.js +5 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByData/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByParent/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByParentData/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByPileupData/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByStatus/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsBySubscription/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByWorkflow/map.js +8 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsByWorkflow/reduce.js +3 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/elementsDetailByWorkflowAndStatus/map.js +26 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobInjectStatusByRequest/map.js +10 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobInjectStatusByRequest/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobStatusByRequest/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobStatusByRequest/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndPriority/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndPriority/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndStatus/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndStatus/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByRequest/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByRequest/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatus/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatus/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatusAndPriority/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatusAndPriority/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/openRequests/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/recent-items/map.js +5 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/siteWhitelistByRequest/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/siteWhitelistByRequest/reduce.js +1 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/specsByWorkflow/map.js +5 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/stuckElements/map.js +38 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsInjectStatusByRequest/map.js +12 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsInjectStatusByRequest/reduce.js +3 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsUrl/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsUrl/reduce.js +2 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsUrlByRequest/map.js +6 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/wmbsUrlByRequest/reduce.js +2 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/workflowSummary/map.js +9 -0
- wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/workflowSummary/reduce.js +10 -0
- wmglobalqueue-2.4.5.1.dist-info/METADATA +26 -0
- wmglobalqueue-2.4.5.1.dist-info/RECORD +347 -0
- wmglobalqueue-2.4.5.1.dist-info/WHEEL +5 -0
- wmglobalqueue-2.4.5.1.dist-info/licenses/LICENSE +202 -0
- wmglobalqueue-2.4.5.1.dist-info/licenses/NOTICE +16 -0
- 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,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 @@
|
|
|
1
|
+
_sum
|
|
@@ -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, 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,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,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
|
+
}
|
wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobInjectStatusByRequest/map.js
ADDED
|
@@ -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
|
+
}
|
wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobInjectStatusByRequest/reduce.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
_sum
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
_stats
|
wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndPriority/reduce.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
_stats
|
wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByChildQueueAndStatus/reduce.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
_stats
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
_sum
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
_stats
|
wmglobalqueue-2.4.5.1.data/data/data/couchapps/WorkQueue/views/jobsByStatusAndPriority/reduce.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
_stats
|