Quick Start (EJB mode): Creating search rules using the Java API

The following Java code example creates two text patterns that the Output service searches for. The first text pattern is Mortgage. If found, the Output service uses the form design named Mortgage.xdp. The second text pattern is Automobile. If found, the Output service uses the form design named AutomobileLoan.xdp. If neither text pattern is located, the Output service uses the default form design named Loan.xdp. (See Creating Search Rules.)

/* 
    * This Java Quick Start uses the EJB mode and contains the following JAR files 
    * in the class path: 
    * 1. adobe-output-client.jar 
    * 2. adobe-livecycle-client.jar 
    * 3. adobe-usermanager-client.jar 
    * 4. adobe-utilities.jar 
    * 5. jbossall-client.jar (use a different JAR file if the LiveCycle Server is not deployed 
    * on JBoss) 
    * 6. jacorb.jar (use a different JAR file if the LiveCycle Server is not deployed on JBoss) 
    * 7. jnp-client.jar (use a different JAR file if the LiveCycle Server is not deployed on JBoss) 
    *  
    *  The JBoss files must be kept in the jboss\client folder. You can copy the client folder to  
    *  your local development environment and then include the 3 JBoss JAR files in your class path 
    *   
    *  These JAR files are located in the following path: 
    * <install directory>/sdk/client-libs/common 
    *  
    * The adobe-utilities.jar file is located in the following path: 
    * <install directory>/sdk/client-libs/jboss 
    *  
    * The jbossall-client.jar file is located in the following path: 
    * <install directory>/jboss/client 
    *  
    * If you want to invoke a remote LiveCycle Server instance and there is a 
    * firewall between the client application and the server, then it is  
    * recommended that you use the SOAP mode. When using the SOAP mode,  
    * you have to include additional JAR files located in the following  
    * path 
    * <install directory>/sdk/client-libs/thirdparty 
    *  
    * For information about the SOAP  
    * mode and the additional JAR files that need to be included,  
    * see "Setting connection properties" in Programming  
    * with LiveCycle 
    *  
    * For complete details about the location of the LiveCycle JAR files,  
    * see "Including LiveCycle Java library files" in Programming  
    * with LiveCycle 
    */ 
import com.adobe.livecycle.output.client.*; 
import java.util.*; 
import java.io.File; 
import java.io.FileInputStream; 
import com.adobe.idp.Document; 
import com.adobe.idp.dsc.clientsdk.ServiceClientFactory; 
import com.adobe.idp.dsc.clientsdk.ServiceClientFactoryProperties; 
 
public class CreateSearchRules { 
 
    public static void main(String[] args) { 
        try{ 
                                             
            //Set connection properties required to invoke LiveCycle 
            Properties connectionProps = new Properties(); 
            connectionProps.setProperty(ServiceClientFactoryProperties.DSC_DEFAULT_EJB_ENDPOINT, "jnp://localhost:1099"); 
            connectionProps.setProperty(ServiceClientFactoryProperties.DSC_TRANSPORT_PROTOCOL,ServiceClientFactoryProperties.DSC_EJB_PROTOCOL);           
            connectionProps.setProperty(ServiceClientFactoryProperties.DSC_SERVER_TYPE, "JBoss"); 
            connectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_USERNAME, "administrator"); 
            connectionProps.setProperty(ServiceClientFactoryProperties.DSC_CREDENTIAL_PASSWORD, "password"); 
                             
            //Create a ServiceClientFactory object 
            ServiceClientFactory myFactory = ServiceClientFactory.createInstance(connectionProps); 
                 
            //Create an OutputClient object 
            OutputClient outClient = new OutputClient(myFactory);  
                         
            //Reference form data 
            FileInputStream fileInputStream = new FileInputStream("C:\\Adobe\Loan.xml");     
            Document inXMData = new Document (fileInputStream); 
             
            //Define two text patterns 
            Rule mortageRule = new Rule(); 
            mortageRule.setPattern("Mortgage"); 
            mortageRule.setForm("Mortgage.xdp"); 
             
            Rule automobileRule = new Rule(); 
            automobileRule.setPattern("Automobile"); 
            automobileRule.setForm("AutomobileLoan.xdp"); 
             
            //Add the Rules to a List object 
            List<Rule> myList = new ArrayList<Rule>(); 
            myList.add(mortageRule); 
            myList.add(automobileRule); 
                                     
            //Define PDF run-time options which includes Search Rules     
            PDFOutputOptionsSpec outputOptions = new PDFOutputOptionsSpec(); 
            outputOptions.setFileURI("C:\\Adobe\Loan.pdf"); 
            outputOptions.setRules(myList); 
            outputOptions.setLookAhead(900);  
             
            //Define rendering run-time options 
            RenderOptionsSpec pdfOptions = new RenderOptionsSpec();  
            pdfOptions.setCacheEnabled(new Boolean(true)); 
                 
            //Create a PDF document based on multiple form designs         
            OutputResult outputDocument = outClient.generatePDFOutput( 
                TransformationFormat.PDF, 
                "Loan.xdp", 
                "C:\\Adobe", 
                outputOptions, 
                pdfOptions, 
                inXMData 
            ); 
         
            //Write the results of the operation to OutputLog.xml 
            Document resultData = outputDocument.getStatusDoc(); 
            File myFile = new File("C:\\Adobe\OutputLog.xml"); 
            resultData.copyToFile(myFile); 
            } 
        catch (Exception ee) 
                { 
                    ee.printStackTrace(); 
                } 
        } 
}