Skip to main content

Version: 21.11

Fluent Functions Quick Start

This guide is a quick walk-through of creating and deploying a Fluent Function in the Maestro Home Loan example form. The function will be called on a form update, where it will log a message in JM, and also return updated data to the form.

Fluent Functions are implemented as services in JM. Prior to undertaking this exercise, you need to have worked through the App Package Quick Start.

A note on Entities

This exercise includes a step which generates Groovy value object source representing entities. Entities are a feature that help to increase developer productivity in the IDE, and serve to promote good object-oriented code design and re-use in fluent functions.

The general flow of using entities in the development process is:

  • Entity definitions originate automatically in a Maestro form as part of the form design process.
  • Groovy source for entity value objects is generated by the gen-vo Ant task.
  • The generated Groovy source is bundled into the application package and deployed into JM.
  • The Groovy classes can be instantiated in a fluent function by the ObjectMapper utility class from form XML data, similar to the factory pattern.
  • Entities modified by code in the fluent function can be fed back to the form as part of the response data.

Learning outcomes

Upon completion of these step-by-step instructions, you will have:

  • Generated value object source code using the Object Mapper via the gen-vo Ant task.
  • Scaffolded a new service into the project to log messages on a page.
  • Re-deployed the Application Package to your Journey Manager server.

Then, in the Journey Manager Console, you will verify the result by:

  • Rendering the form and navigating between pages.
  • Verifying the log messages have been recorded in JM.

Exercise Steps

We'll be running the Ant targets in this exercise from IntelliJ on Windows. The SDK has been unzipped in the folder C:\Development\SDK\Intellij.

It's assumed that you're using the function and package names as shown in this example. If you do use the same names, you can copy and paste the provided code into the source and configuration files without having to change it.

Scaffold a Fluent Function

Here we scaffold a new Form Update function into our project.

  1. In the Ant Build panel, select the app-scaffold-func target and click the Run icon. Alternatively, you can double-click the app-scaffold-func target to run it.

  2. Provide responses to the prompts as shown.

    • Enter a function name.

    • Enter a Groovy package name.

    • Select Fluent Function as the function type.

    • Select Form Update as the trigger. Form update events are fired by page navigation, providing the form data has changed.

Generate ObjectMapper value objects

Here we generate Groovy source for value objects derived from form seed XML. These value objects are convenient to use by the ObjectMapper in our function code.

  1. In the Ant Build panel, select the gen-vo target and click the Run icon. Alternatively, you can double-click the gen-vo target to run it.

  2. Provide responses to the prompts as shown.

    The value object source code will be generated under the named package folder; in this case com.avoka.vo.applicant.

  3. Locate the package in the Project explorer and open the Applicant.groovy source file to see the generated source.

Edit the Groovy function code

We're going to use the ObjectMapper to instantiate an Applicant value object, and then log it.

  1. In the Project panel, open the Applicant.groovy source file which is located under the com.avoka.vo.applicant package. Applicant.groovy contains the source code for the FormUpdate class.

  2. Insert the code fragments highlighted below, then save the package.

    /home-loan/src/.../Applicant.groovy
    import com.avoka.tm.util.*
    import com.avoka.tm.vo.*
    import javax.servlet.http.*
    import com.avoka.vo.applicant.*

    public class FormUpdate {

    // Injected at runtime
    public Logger logger

    /*
    * Perform fluent function call.
    *
    * returns: FuncResult
    */

    FuncResult invoke(FuncParam param) {

    Applicant applicant = new ObjectMapper()
    .setDoc(param.appDoc)
    .setFormXPath('Applicant')
    .create(Applicant.class)

    logger.info("Applicant:" + applicant)

    FormFuncResult result = new FormFuncResult()

    return result
    }
    }
    note

    The example code above logs personally identifiable information which is not recommended in a live application. Always take care that no sensitive information is written to log files in a production environment.

Reference vo source in service-def.json

We are using value objects generated by the gen-vo Ant target in the service code.

  1. In the Project pane, locate the package containing the FormUpdate source, and open the service-def.json file.

  2. Locate the GroovyScript object in the parameters array.

  3. Insert the two vo source filenames com/avoka/vo/applicant/Applicant.groovy and com/avoka/vo/applicant/Address.groovy into the fileIncludes array as shown below.

  4. Save the changes.

Deploy your project to JM

Here we run the app-deploy Ant target to deploy the Application Package to the configured JM server.

  1. In the Ant Build pane, select the app-deploy target and click the Run icon. Alternatively, you can double-click the app-deploy target to run it.

  2. Press Alt+0 (zero) to display the Messages window and confirm successful deployment to JM.

Your Application Package, including the example form, is now deployed to JM.

Render the form in JM

Here we locate the form in JM and render it.

  1. Login to JM.

  2. Select Forms > Forms.

  3. Enter 'loan' in the search field.

  4. Click Search.

  5. Click the Form Test Render icon.

Generate a Reference Code

To generate a Reference Code, we need to fill in the form and navigate between pages.

  1. First, enter some values, and click Continue. For example:

    Because we have changed the form data, a form update event will be triggered when we click the Continue button, and our function will log a message.

  2. Next, we copy the form reference code so we can lookup the transaction in JM.

    Highlight the Reference Code at top right of the form, and copy it to the clipboard (Ctrl+C).

View the Groovy Service log

Here we look at the Groovy Service Log in Journey Manager to see the log messages from our service.

  1. Login to JM.

  2. Paste the reference code into the JM search field and press Enter.

  3. Click the link in the Results list to go to the Transaction Details page.

  4. Click the Groovy Log tab to see the log entries.

Enhance the Form Function

Here, we make changes to the function code so it can return data into the form.

  1. Go back to the groovy source.

  2. Paste the following code into the code window as shown.

    applicant.address.line1 = "30 Main Street"
    applicant.address.line2 = "Avalon"
    applicant.address.state = "NSW"
    applicant.address.postCode = "2101"

    new ObjectMapper()
    .setFormXPath("Applicant")
    .setObject(applicant)
    .update(param.appDoc);

    FormFuncResult result = new FormFuncResult()
    result.includeFormData = true
    logger.info("Applicant:" + applicant)

  3. Save the code.

  4. Re-run the app-deploy Ant target.

Render and test the new form

Here we render the new form and note the address has been populated when we navigate to the second page.

  1. Render a new form from JM.

  2. Enter some values on the first form page.

  3. Click Continue.

You will see the address has been populated by our function.

View the updated log entry

Here we search for the transaction detail and look at the log entries again.

  1. Copy the form Reference Code to the clipboard.

  2. Paste it into the JM search field and press Enter.

  3. Click the link in the Results list.

  4. Click the Groovy Log tab.

You will see the address has been logged by our modified function.