package sos.stacks.webservice;


import sos.spooler.Job_impl;
import sos.spooler.Order;
import sos.spooler.Variable_set;
import sos.spooler.Web_service_operation;
import sos.spooler.Web_service_request;
import sos.spooler.Xslt_stylesheet;

import sos.xml.SOSXMLXPath;


public class JobSchedulerWebServiceShellJobRequest extends Job_impl {

    
    public boolean spooler_process() {

        try {
            String xml_document = "";
            Order order = spooler_task.order();
            Web_service_operation operation = order.web_service_operation();

            if (operation == nullthrow  new Exception"no web service operation available" );
            
            Web_service_request request = operation.request();
            if (request == nullthrow new Exception"no web service request available" );
            spooler_log.debug3"content of web service request:\n" + request.string_content() );

            // should the request be previously transformed ...
            if (spooler_task.params().value("request_stylesheet"!= null && spooler_task.params().value("request_stylesheet").length() 0) {
              Xslt_stylesheet stylesheet = spooler.create_xslt_stylesheet();
              stylesheet.load_file(spooler_task.params().value("request_stylesheet"));
              xml_document = stylesheet.apply_xml(request.string_content());
              spooler_log.debug3"content of request transformation:\n" + xml_document );
            else {
              xml_document = request.string_content();
            }
          
            // Javascript has no XML support, so we use a helper class for XPath expressions
            SOSXMLXPath xpath = new sos.xml.SOSXMLXPath(new StringBuffer(xml_document));
            // add order parameters from request xml element /params
            Variable_set params = spooler.create_variable_set();
            params.set_xmlxpath.selectDocumentText("//params") );
            order.set_payloadparams );

            // altenatively you could add any xml structure of the request to the xml payload of this order
            // order.set_xml_payload( xpath.selectDocumentText("//xml_payload/*") );
       
            spooler_log.info"web service request accepted for order \"" + order.id() "\"" );

            return true;
        catch (Exception e) {
            spooler_log.warn("error occurred processing web service request: " + e.getMessage());
            return false;
        }
    }

}