All Downloads are FREE. Search and download functionalities are using the official Maven repository.

home.lib.jython.workflowlib.TransitionWorkflow.py Maven / Gradle / Ivy

from com.googlecode.fascinator import HarvestClient
from com.googlecode.fascinator.api.storage import PayloadType, StorageException
from com.googlecode.fascinator.common import FascinatorHome, JsonSimpleConfig, \
    JsonObject, JsonSimple
from com.googlecode.fascinator.common.messaging import MessagingServices
from com.googlecode.fascinator.common.storage import StorageUtils
from com.googlecode.fascinator.messaging import TransactionManagerQueueConsumer
from java.io import File, FileInputStream, InputStreamReader
from java.lang import Exception
from java.util import LinkedHashMap
from org.apache.commons.io import IOUtils
from org.json.simple import JSONArray
import os
import shutil
import sys
import time

class TransitionWorkflow:
    def __init__(self):
        self.messaging = MessagingServices.getInstance()
            
    def run(self, context,  oid, fromWorkflowId, fromWorkflowStage, toWorkflowId, toWorkflowStage, pageTitle, label):
        self.log = context["log"]        
        self.storage = context["Services"].getStorage()
        self.object = self.storage.getObject(oid)
        self.workflowMetadata = self.object.getPayload("workflow.metadata")
        self.__tfpackage = None

        if(self.workflowMetadata is not None):
            self.updateWorkFlowMetadata(self.workflowMetadata, toWorkflowId, toWorkflowStage, pageTitle, label)
            self.updatePackageType(self._getTFPackage(), toWorkflowId)
            self.objectMetadata = self.object.getMetadata()            
            self.updateObjectMetadata(self.objectMetadata, toWorkflowId)
            self.object.close()
            self.sendMessage(oid)
        return True

    def sendMessage(self, oid):
        message = JsonObject()
        message.put("oid", oid)
        message.put("task", "reharvest")
        self.messaging.queueMessage(TransactionManagerQueueConsumer.LISTENER_ID, message.toString())
                
    def updateWorkFlowMetadata(self, workflowMetadata, toWorkflowId, toWorkflowStage, pageTitle, label):
        workflowMetaDataJson = JsonSimple(workflowMetadata.open()).getJsonObject()
        workflowMetaDataJson.put("id", toWorkflowId)
        workflowMetaDataJson.put("step", toWorkflowStage)
        workflowMetaDataJson.put("pageTitle", pageTitle)
        workflowMetaDataJson.put("label", label)
        inStream = IOUtils.toInputStream(workflowMetaDataJson.toString(), "UTF-8")
        try:
            StorageUtils.createOrUpdatePayload(self.object, "workflow.metadata", inStream)
        except StorageException:
            print " ERROR updating dataset payload"
    
    def updateObjectMetadata(self, objectMetaData, toWorkflowId):
        packageType, jsonConfigFile = self.__getPackageTypeAndJsonConfigFile(toWorkflowId)
        
        workflowsDir = FascinatorHome.getPathFile("harvest/workflows")
        configFile = File(workflowsDir, jsonConfigFile)
        configObject = StorageUtils.checkHarvestFile(self.storage, configFile);
        if configObject is None:
            oid = StorageUtils.generateOid(configFile);
            configObject = StorageUtils.getDigitalObject(self.storage, oid);
            
        objectMetaData.setProperty("jsonConfigPid", jsonConfigFile)
        objectMetaData.setProperty("jsonConfigOid", configObject.getId())
        
        configJson = JsonSimple(configFile)
        rulesFileName = configJson.getString(None, "indexer","script","rules")
        rulesFile = File(workflowsDir,rulesFileName)
        rulesObject = StorageUtils.checkHarvestFile(self.storage, rulesFile);
        if rulesObject is None:
            oid = StorageUtils.generateOid(rulesFile);
            rulesObject = StorageUtils.getDigitalObject(self.storage, oid);
        
        objectMetaData.setProperty("rulesPid", rulesFileName)
        objectMetaData.setProperty("rulesOid", rulesObject.getId())
        objectMetaData.setProperty("workflowTransitioned", "true")
        objectMetaData.setProperty("date_transitioned", time.strftime("%Y-%m-%dT%H:%M:%SZ", time.localtime()))
        
        
    
    def updatePackageType(self, tfPackage, toWorkflowId):
        tfPackageJson = JsonSimple(tfPackage.open()).getJsonObject()
        tfPackageJson.put("packageType", toWorkflowId)
        
        inStream = IOUtils.toInputStream(tfPackageJson.toString(), "UTF-8")
        try:
            StorageUtils.createOrUpdatePayload(self.object, tfPackage.getId(), inStream)
        except StorageException:
            print " ERROR updating dataset payload"            

    def __getPackageTypeAndJsonConfigFile(self, packageType):
        try:
            types = JsonSimpleConfig().getJsonSimpleMap(["portal", "packageTypes"])
            pt = None
            if types is not None and not types.isEmpty():
                pt = types.get(packageType)
            if pt is None:
                configFile = "packaging-config.json"
            else:
                configFile = pt.getString("packaging-config.json", ["jsonconfig"])
        except Exception, e:
            configFile = "packaging-config.json"
        return (packageType, configFile)
        
        # Retrieve and parse the Fascinator Package from storage
    def _getTFPackage(self):
        if self.__tfpackage is None:
            payload = None
            inStream = None

            # We don't need to worry about close() calls here
            try:
                object = self.object
                sourceId = object.getSourceId()
                payload = None
                if sourceId is None or not sourceId.endswith(".tfpackage"):
                    # The package is not the source... look for it
                    for pid in object.getPayloadIdList():
                        if pid.endswith(".tfpackage"):
                            payload = object.getPayload(pid)
                            payload.setType(PayloadType.Source)
                else:
                    payload = object.getPayload(sourceId)

            except Exception, e:
                self.log.error("Error during package access", e)
                return None

        return payload








© 2015 - 2025 Weber Informatics LLC | Privacy Policy