Flow services

Use Flow services to encapsulate a sequence of services within a single service and manage the flow of data among them, and create complex, advanced integration scenarios involving multiple application endpoints.

Flow services provide you with rich data mapping capabilities, a familiar debugging mechanism, a large collection of built-in services, and more.

Overview

IBM webMethods Integration offers various features that enables you to automate tasks based on specific requirements. However, there are some scenarios where you want to create complex integrations that require advanced data transformation and custom logic implementation. Earlier you could do this by switching to the Flow Editor using the App Switcher and create the required integrations in the Flow Editor.

We have simplified this process by providing you with flow services directly in your IBM webMethods Integration project, thus eliminating the need to access the Flow Editor through the App Switcher. With flow services, you can encapsulate a sequence of services within a single service and manage the flow of data among them, and create complex, advanced integration scenarios involving multiple application endpoints.

In the Flow Editor, you used a graphical drag and drop tool to create integrations. You set up your integrations by plugging blocks together in the workspace and coding concepts were represented as interlocking blocks.

In flow services, you can easily build a flow service by adding steps and selecting the constructs including Connectors, Controls, flow services, and Services from within the steps. The editor is visually enhanced to offer ease of use and is more interactive.

A flow service step is a basic unit of work that IBM webMethods Integration interprets and runs at run time. The steps are the building blocks of a flow service and are shown as rectangular blocks prefixed with step numbers. Steps may be compared to an actual implementation of a service in a programming language, where the business logic or the algorithm is written. IBM webMethods Integration lists steps sequentially from top to bottom and also runs them in that order.

You can simultaneously open five flow services in different tabs in a browser.

Comparing Workflows and Flow services

Workflows and flow services enable you to automate and optimize monotonous tasks based on a set of predefined rules and business logic. These features give you the power to connect apps, devices, and on-premises systems with only clicks and zero code. Although workflows and flow services help you to accomplish the same goal, there are significant differences between both the features.

The following table showcases the differences between workflows and flow services.

Workflows Flow Services
Designed for Citizen developers. No code. Designed for Integration specialists. Low code.
Offers a visual, drag and drop interface to create business use cases. Offers steps and constructs from within the steps to create business use cases.
Offers in-built triggers to automatically trigger workflows when relevant events occur and actions to perform specific tasks. Offers in-built applications and services to perform specific tasks.
Supports executing other flow services and workflows from within a workflow. Supports executing other flow services from within a flow service.
Ideal for scenarios where basic data transformation on application data is required. This means you can execute simple business use cases with workflows. Ideal for scenarios where complex integrations and advanced data transformation are required. This means you can execute simple as well as complex business use cases with flow services.

Migrating Flow Editor Integrations to Flow services

If you are an existing customer and have created integrations in the Flow Editor, you can migrate those integrations to Flow services in IBM webMethods Integration using the Migrate Integrations functionality. You can migrate integrations from a Flow Editor project to the same project in flow services.

How it works

  1. In IBM webMethods Integration, ensure that you have the Developer and Admin roles assigned from the Settings > Roles page.

  2. In IBM webMethods Integration, select the project where you want to migrate the Flow Editor integrations and click the Flow services tab. IBM webMethods Integration displays the number of integrations available for migration.

  3. Click Migrate Integrations.

A dialog box appears displaying the list of integrations that will be migrated. Click OK to continue.

A dialog box appears showing the migration results. Click OK.

All integrations available in the Flow Editor project are migrated and available in Flow services in case of a successful migration. In case of any errors, it is recommended to recreate those integrations in Flow services.

Note
  • After you migrate the integrations, you will not be able to open or edit the same integrations in the Flow Editor.
  • If a Flow Editor integration refers to another integration, both the integrations will be migrated.
  • After migrating flow services, if the pipeline variables used in if or elseif blocks are dropped, the else block will not work properly. In such cases, update the migrated flow service from the user interface and save it.

Core elements, constructs, and components of Flow services

Let us see the core elements, constructs, and components that are used to create and run a flow service.

On the new flow service page, click on the rectangular box as shown below.

By default, the left panel lists the recently used Connectors, Controls, Project services, and Built-in services.

You can type a keyword in the rectangular box and search for the available elements. IBM webMethods Integration filters the data based on what you type in the search box.

Click All to view the categories available on the right panel, which you can use to build the Flow service.

Categories

Displays the following categories:

Connectors

Displays the connectors available to create the Flow service.

Connectors are grouped in the following categories on the flow services panel.

Predefined Connectors

Predefined and configurable connectors. These connectors allow you to connect to the SaaS providers.

Note
A few connectors are deprecated in this release. A deprecated connector displays the Deprecated label just below the connector where ever it appears in the user interface. Deprecated connectors will continue to work as before and are fully supported by IBM. If you are using deprecated connectors in your existing Workflows and/or flow services, they will work as expected. No new feature enhancements will be made for deprecated connectors. If you are creating new Workflows or flow services, it is recommended to use the provided alternative connectors instead of the deprecated connectors. The deprecation is applicable only for Actions. The deprecation is not applicable for Triggers, that is, Triggers are supported for both deprecated and alternative connectors. For the list of triggers, see the documentation for alternative connectors.

REST Connectors

You can define REST Resources and Methods and create custom REST connectors. You can invoke a REST API in a flow service by using a REST connector.

SOAP Connectors

Displays custom SOAP connectors. Custom SOAP connectors enable you to access third party web services hosted in the cloud or on-premises environment. You can also invoke a SOAP API in a flow service by using a SOAP connector.

On-Premises Connectors

On-Premises applications uploaded from on-premises systems.

Flat File Connectors

Displays the Flat File connectors created either manually or from a sample file.

Controls

Controls are the programming constructs in a flow service. This allows you to run a specified sequence based on a field value, try a set of steps, and catch and handle failures. The panel displays conditional expressions, looping structures, and transform pipeline. Conditional expressions perform different computations or actions depending on whether a specified boolean condition evaluates to true or false.

Sequence

Use the Sequence step to build a set of steps that you want to treat as a group. Steps in a group are run in order, one after another.

Conditional Controls

Loops

Loops run a set of steps multiple times based on the block you have chosen. It repeats a sequence of child steps once for each element in an array that you specify. For example, if your pipeline contains an array of purchase-order line items, you could use a Loop to process each line item in the array. Loop requires you to specify an input array that contains the individual elements that are used as input to one or more steps in the Loop. At run time, the Loop runs one pass of the loop for each member in the specified array. For example, if you want to run a Loop for each line item stored in a purchase order, you would use the document list in which the order’s line items are stored as the Loop’s input array.

A Loop takes as input an array field that is in the pipeline. It loops over the members of an input array, executing its child steps each time through the loop. For example, if you have a flow service that takes a string as input and a string list in the pipeline, use Loops to invoke the flow service one time for each string in the string list. You identify a single array field to use as input when you set the properties for the Loop. You can also designate a single field for the output. Loop collects an output value each time it runs through the loop and creates an output array that contains the collected output values.

Note
In case of an infinite loop, there is a default timeout configured in IBM webMethods Integration. If the time taken for execution exceeds this limit, the flow service execution is terminated. Contact your administrator for customizing the default timeout.

Example: Loop through nested arrays in flow services

Given the following nested document structure in JSON, retrieve the node6 element and apply an IF condition to it.

JSON Nested Structure


{
  "node1": {
    "node2": {
      "node3": [
        {
          "node4": {
            "node5": [
              {
                "node6": "Hello"
              }
            ]
          }
        }
      ]
    }
  }
}
  1. In Flow Editor, define the data fields in the signature.

    For more information on defining input and output fields, see Input and Output Field Declaration

  2. In the flow step, add a Repeat for node3.

  3. Inside the node3 loop, add another Repeat for node5.

  4. Add the IF condition, and select node6. Hover over the node and confirm the full path of the node in case of duplicate node names.

Error Handling

Exit

This step exits the entire flow service and signals success or failure as part of the exit.

Switch, Case

Switch allows a variable to be tested for equality against a list of values. Each value is called a case, and the variable being switched on is checked for each case, that is, Switch evaluates a variable and skips to the value that matches the case. For example, if the Switch variable evaluates as “A”, then case “A” is run.

A switch statement can have an optional default case, which must appear at the end of the switch. The default case can be used for performing a task when none of the cases are true. You cannot insert multiple default statements.

You can include case steps that match null or empty switch values. A switch value is considered to be null if the variable does not exist in the pipeline or is explicitly set to null. A switch value is considered to be an empty string if the variable exists in the pipeline but its value is a zero length string. Switch runs the first case that matches the value, and exits the block.

Branch

Branch is a conditional execution of steps and constitutes a group of expressions. Within a Branch, IBM webMethods Integration runs the first expression that evaluates to true. Expressions are the conditions on the pipeline variables.

At run time, Branch evaluates the conditions provided and runs the first expression whose condition is evaluated to true. If none of the expressions are true, the default expression if included, is run.

The following figure is the default template of a Branch construct.

If you want to perform different actions on different values of one or more pipeline variables, use the Branch construct. In the following example, action is a pipeline variable created using the Define input and output fields dialog box.

The Branch contains two conditional expressions and a default expression.

Scenario 1

If the value of action starts with mult, IBM webMethods Integration evaluates the first expression (action = /^mult/) and runs step 3, that is, performs the multiplication operation.

Scenario 2

If the value of action is addition (action == “addition”), then the Branch starts its execution from step 2. As step 2 is evaluated to false, the execution moves to the next expression, that is, step 4. Step 4 is evaluated to true, hence step 5 is run, that is, the addition operation is performed. Remaining expressions in the Branch, if any, are ignored and the execution falls through to the next step after the Branch in the flow service.

Scenario 3

Let us assume that the value of action is subtraction. The Branch then starts its execution from step 2. As IBM webMethods Integration evaluates step 2 to false, the execution moves to the next expression, that is, step 4. IBM webMethods Integration evaluates Step 4 to false, hence evaluates step 6 ($default), that is, runs step 7, which makes the execution exit the flow service.

Note
  • If you are specifying a field in a document or in a document reference, format it as document/documentVariable. For example, if you want to specify a field name, from the document employeeProfile, then format it as employeeProfile/name.

  • If you specify a literal value in an expression, the value you specify must exactly match the run-time value of the pipeline variable. Further, the value must be case sensitive.

  • IBM webMethods Integration runs only the first target step whose expression evaluates to true. If none of the expressions evaluate to true, none of the child steps are invoked, and the execution falls through to the next step in the flow service, if there is no default expression.

  • If you want to prevent the execution from falling through a Branch step when an unmatched value occurs at run time, include a default target step to handle unmatched cases. Branch can have zero to many default expressions. IBM webMethods Integration runs the first sequentially encountered default expression.

  • The default step does not need to be the last step of a Branch but IBM webMethods Integration always evaluates the default step at the end.

Any step other than an expression cannot be a direct child of a Branch step. Further, you cannot add the expression step anywhere outside a Branch. If you are branching on expressions, ensure that the expressions you assign to the target steps are mutually exclusive. In addition, do not use null or empty values when branching on expressions. IBM webMethods Integration ignores such expressions and does not display any errors. You can provide multiple conditions for each expression and can also use regular expressions, for example, /^mult/. The expressions you create can also specify a range of values for the variables.

Specify the value of the variables in the expressions, as mentioned in the following table:

To Match… Specify…
That exact string A string
The string representation of the object’s value.
Example for Boolean object: true
Example for Integer object: 123
A constrained object value
Any string matching the criteria specified by the regular expression.
Example: /^REL/
A regular expression
An empty string A blank field
A null value $null
Any unmatched value (that is, run the step if the value does not match any other label) $default

Transform Pipeline

As systems rarely produce data in the exact format that the other systems need, at times you need to transform data in terms of format, structure, or values of data. Using the Transform Pipeline control in the flow service you can do transformations on data in the Pipeline.

You can insert multiple transformers in a single Transform Pipeline step, to perform multiple data transformations. When multiple transformers are added, the Transform Pipeline step behavior is as follows:

Consequently, the output of one transformer cannot be used as the input to another transform. These characteristics make the Transform Pipeline step different than that of a normal step in a flow service.

Inserting a Transform Pipeline Step in a Flow service

  1. Create a flow service. A flow service step is created initially without any data.

  2. Select Transform Pipeline from the step drop-down list. The Transform Pipeline step is added.

Adding Transformers

  1. Create a flow service. A flow service step is created initially without any data.

  2. Select Transform Pipeline from the step drop-down list.

  3. Click on the flow service step. The Pipeline panel appears.

  4. Click on the Transformers column header. The Select Transformer step is added under the Transformers column.

  5. Select the function from Select Transformer. The input field values are modified based on the selected transformer.

Mapping Pipeline Fields to Transformer Fields

The pipeline fields can be mapped to the service fields of the transformers added.

  1. Go to the Transformer step (for which the transformers have been added) in the Pipeline panel.

  2. Click in the Transformer step. The fields are displayed.

  3. Link the fields as per your requirements.

Note
  • At a time, only one transformer can be expanded. On collapsing, all the existing transformers are visible.
  • You can delete a transformer using the delete icon against each transformer. If a transformer is deleted, the mappings made to its service fields will also be deleted.

Mapping Fields Directly

The Pipeline Input fields can be directly mapped to any of the Pipeline Output fields. This is known as Direct Mapping.

Example

Let’s see how transformers work with the help of an example. In the below example, we will transform the case of a string field label to upper case.

1.Provide a name and description of the new flow service and click the I/O icon.

2.Define an input field Currency Code and click Done.

3.Select Transform Pipeline.

4.Click the pipeline mapping icon and open the pipeline mapping window.

5.On the pipeline mapping window, click the Add New Transformer option.

The Select Transformer panel appears.

6.Click ALL on the transformer panel.

Note
  • You must specify the pipeline input and output variables in the corresponding flow when invoking a flow service in the transform step to ensure visibility of the signature.

  • You cannot use the Controls category within a flow service transform step.

7.Select the toupper service.

8.Click the Expand icon.

9.Map Currency Code to inString and value to Currency Code.

10.Save the flow service and run it. In the Input values dialog box, type usd as the Currency Code.

11.Click Run on the Input values dialog box. The transformer converts the string field usd in lowercase to uppercase.

Note
You can delete a transformer by clicking the delete icon against each transformer. If a transformer is deleted, the mappings made to the service variables are also deleted.

Project Services

Displays the flow services available in the selected project. This enables you to invoke other flow services from the current flow service. The input and output of the referred flow service must be accordingly mapped for a successful execution.

Built-in Services

Displays the service categories. An extensive library of built-in services is available for performing common tasks such as transforming data values, performing simple mathematical operations, and so on.

Service input and output parameters are the names and types of fields that the service requires as input and generates as output and these parameters are collectively referred to as a signature.

Note
Related services are grouped in categories. Click here for information on the service categories, and input parameters, output parameters, and usage notes if any for each service.

Tasks associated with Flow Services

You can perform the following tasks for flow services by clicking the icons available on the flow services panel.

Icons Task/Description
Provide a flow service name and description. The asterisk denotes that the flow service is modified.
Search for text in the flow service, inside the editor, and within the steps.
Debug a flow service and inspect the data flow during the debugging session. For more information, see Debug Flow services.
Run the flow service after you save it. This enables you to test the flow service execution in real time and view the test results.
View the runtime log entries for a selected runtime directly within the Flow Editor.
Define the input and output fields of a flow service. For more information, see Input and Output Fields Declaration.
This option allows you to log business data at the flow service level. You need to first click the I/O icon and define the input and output fields. Then click the Log business data icon and select the defined fields in the Log business data dialog box.
You can choose whether you want to log business data only when errors occur On Failure, or choose Always to always log business data. The default setting is On Failure.
When selecting fields for logging, you can specify the same display name for more than one field, but this is not recommended. Having the same display name might make monitoring the fields at run time difficult.
The business data log appears in the Execution Details page under Business Data.
For more information, see Log Business Data.
Click the Navigator icon to view a summary of the flow service steps, which appear on the right panel. Move the slider available on the navigator panel to move through the flow service. If you move through the main flow service page, the navigator view will automatically move. You can click on a navigator step to go to that step in the flow service.
Click the Default mode to view more spacious, visual representation of the integration flow. Each step or action is displayed with ample space around it, making it easier to visualize and interact with each element.
Click the Compact mode option to display actions and steps in a more condensed format. This mode minimizes the space between elements, allowing more steps to be visible on the screen without scrolling.
Press Ctrl and select a step or multiple steps in the flow service. Then click the delete step(s) icon to delete the selected step or multiple steps in the flow service. You can also delete steps by right-clicking on a step on the flow service editor and selecting the delete option.
Press Ctrl and select a step or multiple steps in the flow service. Then click the move step(s) icon and select the move steps up, down, right, or left options.
You can also move steps by right-clicking on a step on the flow service editor and selecting the available options.
Cut, Copy, Paste, Duplicate, Enable, and Disable steps in the flow service.
You can also right-click on a step on the flow service editor and add a step or a child step for the selected step, cut, copy, and paste steps, copy the selected step(s) and paste the step(s) after the selected step(s) by clicking Duplicate, delete a step, and move steps up, down, right, or left.

Note
You can perform cut, copy, and paste actions within the same flow service or another flow service in the same project. However, if you perform these actions from one flow service to another in a different project, you might encounter deployment errors.
Undo a step action.
Redo a step action.
Whenever you save a flow service, a newer version is added to the Version History with the default commit message. You can also provide a custom commit message by clicking the drop-down arrow beside the Save option and selecting Save with message.
- Whenever you save a flow service, a newer version is added to the Version History with the default commit message. You can also provide a custom commit message by clicking the drop-down arrow beside the Source Control option and selecting Save with message.
-Version History: View the version commit history of the flow service.
Access Help topics or take a tour.
The following options are available:
- Schedule: Define a schedule for the flow service execution. Select Once if you want to schedule the flow service to run just once immediately or run once at a specified date and time.
- Select Recurring if you want to define a recurrence pattern. You can define a recurrence pattern daily, weekly, monthly, and in hours. Select the frequency (Hourly, Daily, Weekly, Monthly) with which the pattern recurs, and then select the options for the frequency. Click the + icon to repeat the execution for daily, weekly, and monthly schedules. Click the delete icon to delete the selected execution time for daily, weekly, and monthly schedules.
- Select Prevent concurrent executions option to skip the next scheduled execution if the previous scheduled execution is still running, except when the previous scheduled execution is running for more than 60 minutes (default). In this case, the next scheduled execution starts even if the previous scheduled execution is running. IBM support if you want to change the 60 minutes default value. If you do not select the Prevent concurrent executions option, the next scheduled execution starts, even if the previous scheduled execution has not yet completed. In the Input Value Set panel, provide inputs to the flow service based on the defined input signature. Click Delete if you want to permanently remove the current recurrence schedule.
Note
Any time stamp displayed in IBM webMethods Integration is based on the time zone you have specified in IBM webMethods iPaaS. All time zones available in IBM webMethods iPaaS are currently not supported in IBM webMethods Integration. If a time zone in IBM webMethods iPaaS is not supported, then the time stamp in IBM webMethods Integration defaults to the Pacific Standard Time (PST) time zone.
You can pause a flow service execution that was scheduled by clicking the Pause option on the Overview page of a flow service.
- Key Shortcuts: View keyboard shortcut keys.
Note
Occasionally, there may be instances where keyboard shortcuts in the Flow Editor coincide with those of the browser. If this occurs, it is advisable to avoid using the shortcuts and instead follow the regular methods to access the editor.

- Execution History: View successful and failed flow service executions, operations, and business data logs.
- Version History: View the version commit history of the flow service.
An account is linked and configured.
Note: For a migrated or imported flow service, the step-level validation might show that the account is not configured. This means that the steps are linked to an account alias but the account does not exist. In such a case, you can create the account inline and refresh the page, or you can go to the Connectors page and create the account with the same name as the alias.
An account is not linked.
A red circle on a step may appear for many error scenarios, for example, if an account is not configured, or the associated action is not selected, or for any invalid constructs.
Map or edit existing pipeline mappings.
Click the ellipsis icon and perform the following tasks:
- Comment: Add a note for the selected step.
- Disable: Disable or deactivate a step. You can enable the step by clicking the enable step icon . You can cut, copy, or delete a step after you disable it.
- Log business data: This option allows you to log business data at the step level.
Note: At the step level, the Log business data option is enabled only for connectors.
In the Log business data dialog box, choose whether you want to log business data only when errors occur On Failure, or choose Always to always log business data. The default setting is On Failure. Expand the Input Fields and Output Fields trees to display the fields available in the signature, and select the check boxes next to the fields you want to log. If you want to define a display name for a field, type the display name beside the field. The display name defaults to the name of the selected field, but it can be modified. When selecting fields for logging, you can have the same display name for more than one field, but this is not recommended. Having the same display name might make monitoring the fields at run time difficult.
The business data log appears in the Execution Details page under Operations > Business Data. See the Log Business Data section for more information.
- Delete: Delete the step.
Click this icon to open the referenced flow service if a flow service references any other flow service.
Indicates count of only the immediate child steps.
Note
Flow services can accommodate a maximum of 300 steps. Exceeding this maximum step limit might lead to performance issues.

Input and Output Fields Declaration

The Define I/O feature allows you to define the input and output fields for a flow service. You can define the input and output fields from the Define input and output fields screen. You can access the screen by clicking the Define I/O icon () from the flow services action bar.

The Define input and output fields screen has two tabs:

You can declare the fields of a flow service in one of the following ways:

Guidelines for Defining Input and Output Fields

Although declaring input and output fields for a flow service is optional, it is strongly recommended that you make it a practice to declare the fields for every flow service that you create due to the following reasons:

Input Fields

Output Fields

Declaring Fields Manually

You can declare fields manually in one of the following ways: - Using Add a new set

Using Add a new set

Here, the instructions are explained for input fields. You can follow the same instructions to add output fields from the Output Fields tab.

  1. Go to the Define input and output fields screen.

  2. Select Add a new set in the Input Fields tab.

  3. Click Add in the Data Fields section. The fields are listed under Data fields.

  4. Enter the details as per your requirements.

  5. Click Done. The input fields are declared.

    Note
    • When you select the Type as String in the Display Type field, select:

      • Text Field if you want the input entered in a text field.

      • Large Editor if you want the input entered in a large text area instead of a text field. This is useful if you expect a large amount of text as input for the field, or you need to have new line characters in the input.

      • In the Pick List field, define the values that will appear as choices when IBM webMethods Integration prompts for input at run time.

      • In the Content Type field, you can define constraints for the field such as, minimum value of a field or maximum length of a string. For example,

      • Password if you want the input entered as a password.

      • Large Editor if you want the input entered in a large text area instead of a text field. This is useful if you expect a large amount of text as input for the field, or you need to have new line characters in the input.

      • In the Pick List field, define the values that will appear as choices when IBM webMethods Integration prompts for input at run time.

      • In the Content Type field, you can define constraints for the field such as, minimum value of a field or maximum length of a string. For example,

      • Avoid using characters like ‘/’ and ‘&’ in field names, as they will cause errors. Use field names that consist only of alphanumeric characters and underscores.

Loading through XML or JSON

Here, the instructions are explained for input fields. You can follow the same instructions to add output fields from the Output Fields tab.

  1. Go to the Define input and output fields screen.

  2. Select Add a new set in the Input Fields tab.

  3. Perform one of the following actions:

    • Load XML - Click Load XML in the Data Fields section to define the content in XML. The Type or paste XML content text box appears.

    • Load JSON - Click Load JSON in the Data Fields section to define content in JSON. The Type or paste JSON content text box appears.

  4. Type the details as per your requirements. Alternatively, you can paste the details from an XML or JSON file.

  5. Perform one of the following actions:

    • Load XML - Click Load XML if you have defined the fields in the XML format.

    • Load JSON - Click Load JSON if you have defined the fields in the JSON format.

    The input fields are defined.

Declaring Fields using Document Reference

You can use a document type to define the input or output fields for a flow service. For example, if there are multiple flow services with identical input fields but different output fields, you can use a document type to define the input fields rather than manually specifying individual input fields for each flow service. When you assign a Document Type to the Input or Output side, you cannot add, modify, or delete the fields on that part of the tab.

You can select Document Type from the Document reference drop-down list. A Document Type can be created using the Document Types option under Project > Configurations > Flow service.

You can create pipeline fields as document references, create document types comprising of document references, and also define the signature of flow services comprising of document references.|

  1. Go to the Define input and output fields screen.

  2. Select Document Reference in the Input Fields tab. The Choose Document Reference drop-down list appears listing all documents available in the project.

  3. Select the document from the Choose Document Reference drop-down list.

  4. Click Done. The input fields are declared.

Input and Output Field Validations

The Input and Output Field Validations feature enables you to validate the input and output fields during runtime. While declaring the input and output fields you can provide constraints such as, minimum value a field can accept, maximum length of a string, and so on. During runtime, IBM webMethods Integration validates the values and if the constraints are not satisfied, then the flow service execution fails.

You can enable this feature using the options Validate input and Validate output in the Input Fields and Output Fields tabs of the Define input and output fields screen.

Value Set

When running a service using IBM webMethods Integration, you frequently need to submit input values. A value set allows you to save these input values. If you need to execute the same flow service again in the future with the same input values, you can use the previously saved value set instead of manually inputting the input values.

Example

In this example, you will learn about defining a value set for a service. Assume, you use a *Slacktest service, to create an integration that posts a user defined message on a specific slack channel.

Let us see how to provide input values to a flow service. We will create a flow service slacktest that posts a user defined message on a specific Slack channel.

Basic Flow

1.Create the flow service.

2.Click the Define IO () icon and define the input fields channel and message.

3.Click the mapping icon () and define the pipeline mapping as shown in the following illustration.

4.Click the Run icon (). The Input values dialog box appears.

Note
If you do not define any input fields in a flow service, then the Input values dialog box does not appear and the flow service executes directly.

5.Specify the input values as general and Hello Team !!! and save the value set as slack_valueset_1.

You can run the flow service without saving the value set too.

Note
If you do not define any input fields in a flow service, then the Input values dialog box does not appear and the flow service executes directly.

5.Specify the input values as general and Hello Team !!! and save the value set as slack_valueset_1.

You can run the flow service without saving the value set too. A value set is a placeholder to store run time input values. You can use the same value set if you want to run the same flow service with the same input values. This is useful when you have multiple input fields. Value sets are stored in your browser’s local storage and the value sets are retained till the local storage is cleared.

6.Click Run.

7.View the result. The values for the input fields channel and message are displayed.

Include Empty Values for String Types

The Include empty values for string types option in flow services ensures that string variables with empty values (“”) are explicitly included in the output or passed downstream in the pipeline. By default, empty strings are omitted, resulting in the absence of those variables in the pipeline.

The Include empty values for string types option is enabled by default, and its setting is not persisted when toggled on or off. You must enable or disable this option based on the desired outcome. Enabling the option saves the string variable with empty values, while disabling it saves the string variable with null values.

Key points to consider when using the Include empty values for string types option in flow services:

Note
The Include empty values for string types setting also applies to map set steps in flow services, ensuring that string fields without provided values are treated as empty strings (“”) instead of null.

Upload Input Values

The Upload Input Values feature allows you to upload a JSON file containing a value set that needs to be provided as input to a service.

When uploading a JSON file, if there is a value set with the same name, the following warning appears:

Note
The JSON file can be a maximum of 200 KB in size. Exceeding this limit may impact the performance of the user interface.

Download Input Values

The Download input values feature allows you to download the input values used in a service as a JSON file. When you click Download input values, the input values are downloaded as a JSON file in the {flowServiceName}-{valueSetName}.json format and saved in the default download folder on your local system.

This downloaded file can be exported or used later based on your requirements.

Pipeline Mapping

The Pipeline feature offers a graphical representation view for all of your data and allows you to map the data between flow service’s user input, and connectors or services. Pipeline is the general term used to refer the data structure in which the input and output values are maintained for each step of a flow service. The pipeline starts with the user defined input to the flow service and collects inputs and outputs from every step to the next step in the flow service. When the flow service executes, pipeline has access to data until the previous step’s output.

Pipeline Panel

The Pipeline panel enables you to map the input and output fields. You can access the Pipeline panel by clicking the mapping icon () on the flow services step. The Pipeline panel appears only when you select any operation of the connector or service and an account must be configured in case of connector. The flow service generates the fields based on the operation and the service or connector selected. You can define the input or output fields in the Define IO section and map them to the service or connector fields.

The Pipeline panel has the following columns:

You can map the fields in the following order:

  1. Pipeline Input fields to Service Input fields

  2. Service Output fields to Pipeline Output fields

    Note
    For easy identification purpose, services are indicated with fn text in the column header and the connector icon is displayed for connectors.

Pipeline Taskbar

You can perform the following actions while mapping the input and output fields in a flow service. The Taskbar is available at the top right-corner of the Pipeline panel.

Name and Icon Description
Recommended Mappings ( ) Recommends mappings based on the pattern of previous mappings. The recommended mappings are represented with dotted lines. For more information, see Smart Mapping.
Show only Mapped () Displays only the mapped fields.
Copy () Copies a field from the Pipeline Input and Pipeline Output sections. This icon is enabled only when a field is selected. For more information, see Copy and Paste Fields.
Clear () Clears all mappings and values set for fields in the pipeline. This icon is enabled always. For more information, see Clear Values.
Delete () Deletes the selected mapping. You can also delete the values set for input and output fields, delete the map between fields, and delete the drop value. This icon is enabled if a particular mapping is selected by clicking on the mapping line.
For more information, see Delete Mappings.
Move () Moves the selected field to either left, right, up, or down in the pipeline. The left and right icons are enabled only when the selected field has a possibility to move to the immediate parental hierarchy (if any). The up and down icons are enabled only when the selected field has a possibility to move one level up or down its sibling field.
Map () Connects service and pipeline fields in the pipeline with a line called a map (link). For more information, see Map Pipeline Fields.
Set Value () Sets the values for input and output fields. For more information, see Set Values.
Drop () Drops a field from the Pipeline Input or Pipeline Output sections. For more information, see Drop Fields.
Map by Condition () Sets a condition on a pipeline map. Only when the condition is satisfied the target field is assigned a value. For more information, see May by Condition.
Expand () Expands the Pipeline panel. For more information, see Expand Mapping Panel.
Toggle Pipeline Panel () Allows you to efficiently manage and inspect pipeline data. Provides a flexible way to control screen space.
Close () Closes the mapping panel and returns to the flow service. This icon is always enabled. Whatever the state of mappings or data manipulations done till that point are saved.
Paste () Pastes the field in the pipeline after a copy field action. For more information, see Copy and Paste Fields.
Add () Adds a field to the pipeline. You can add fields that were not declared as input or output fields (through Define IO) of the flow service. For more information, see Add Fields.
Note
You can also access these actions by right-clicking a field in the pipeline as shown:

Set Values

The Set Values feature allows you to set values for the fields by clicking on the field in the Pipeline panel.

The behavior of the Set Value feature is as follows:

For example, let us see the Adding Integers (AddInts) functionality using the Math service.

  1. Create a flow service. For example, AddingIntegers. A flow service step is created initially without any data.

  2. Select the AddInts operation in the flow service step.

  3. Click on the flow service step. The Pipeline panel appears. Two service input fields num1 and num2 are listed in the Service Input column.

  4. Click any of the fields, for example, num1. The Set Value dialog box appears.

  5. Enter the value in the num1 field.

    Note
    When you paste data equal to or exceeding 0.5 MB in the text box, the system disables editing due to performance limitations. However, you can still use the respective buttons to copy and paste the data and perform editing in an external tool.
  6. Click Save. The value is set and the corresponding field is represented with the SetValue icon. If you export this step, the set value of this field is exported.

  7. Repeat the above steps to set values for the required fields.

Pipeline Variable Substitution

The Perform pipeline variable substitution check box indicates whether you want the application to perform pipeline variable substitution at runtime. If selected, the application replaces the pipeline variable with the runtime value of the variable while running the flow service.

Note
You can assign values of string or string[] fields to other string or string[] fields in the pipeline.

The Perform pipeline variable substitution check box indicates whether you want the application to perform pipeline variable substitution at runtime. If selected, the application replaces the pipeline variable with the runtime value of the variable while running the flow service.

Note
You can assign values of a only string or string[] fields to another string or string[] fields in the pipeline.

Clear Values

The Clear Values feature allows you to reset the field values. If the field is a document or document reference type, Clear All resets the nested fields as well. The default values of different types on Set Value (without giving any input, just opening the Set Value screen and save) and Clear All are as follows:

Field Type On Default Set Value On Clear All
String “(empty)
Boolean False False
Array [] []
Float, Int, Double, Long, Short nothing set
Document, Document Reference An object with all String fields at all levels are set to “, nothing is set for other types. An object with all String fields at all levels are set to “, nothing is set for other types.

Map Pipeline Fields

The Map Pipeline Fields feature allows you to connect service and pipeline fields in the pipeline with a line called a map (link). You can select two input fields and click the Map icon to create a map between them. Creating a map between fields copies the value from one field to another at run time. There are two types of mapping:

Implicit Mapping

Within a flow service, IBM webMethods Integration implicitly maps fields whose names are the same and whose data types are compatible. flow service connects implicitly mapped fields with a dotted line.

Explicit Mapping

You can map input fields from the Pipeline Input column to Service In fields, and also can map the output from the Service Out to a different field in the Pipeline Out column. Explicit Mapping can be achieved in the following ways:

Delete Mappings

The Delete Mappings feature allows you to remove mappings . You can delete each map individually or all mappings at a time.

Search Fields

The Search feature allows you to search fields. When you type field names in the Search text box, IBM webMethods Integration performs a dynamic search across all fields (including nested fields), and displays the resultant fields in the respective panels. Additionally, each column has its own search bar that allows you to search in the respective column.

Expand Mapping Panel

The Expand feature allows you to resize the Pipeline panel. On clicking the Expand icon, the Pipeline panel size increases and you can resize the column widths as per your requirements to view the mappings clearly.

Tip
The Expand Mapping Panel option is useful in scenarios when there are many mappings and the current default column width is not sufficient for clear view of the mappings. You can click Expand to increase the Pipeline panel size and resize the column for viewing the mappings with more clarity.

Note
For any nested structures, you can easily expand or collapse all nodes by clicking the Expand All and Collapse All buttons. The Expand All and Collapse All buttons appear only when there are nested structures in a Transform step.

When any parent node is in expanded mode, then the button name is changed to Collapse All until all nodes are in collapsed state

Copy and Paste Fields

The Copy and Paste feature allows you to copy any field and paste in the pipeline. Depending on the context, you can either paste the field or the field path. For example, if you copy a field and paste the field in the Set Value dialog box, the field path is pasted. Alternatively, you can use keyboard shortcuts Ctrl+C to copy and Ctrl+V to paste fields. You can perform the copy and paste actions in the following ways:

Note
  • To copy any field name in the pipeline panel, you right-click the field and select Copy field name from the displayed menu. The complete path of the field is copied. You could use this option if you would like to extract field names only.

  • You cannot copy or paste flow steps or fields between flow services, deploy anywhere flow services, and API Flows.

Drop Fields

The Drop feature allows you to remove fields from a pipeline that are no longer used by the subsequent steps. You can drop fields from only the Pipeline Input and Pipeline Out columns.

By dropping the unwanted fields you can reduce the size of the pipeline at run time. Also, the length and complexity of the Pipeline Input and Pipeline Out columns is reduced, thus making the pipeline panel much easier to use when you are working with a complex flow service. If any output field is dropped, then that particular field is not sent as Pipeline Input to the next step. This way you can restrict the flow of fields from one step to another.

For easy identification purpose, the Drop icon appears after a field is dropped. For example, .

You cannot drop a field in the following scenarios:

Add Fields

The Add Fields feature allows you to add fields to a pipeline.

Map by Condition

The Map by Condition feature allows you to define conditions for the maps (links) drawn between fields in a pipeline. A condition consists of one or more expressions that allows you to:

For example, map the fields BuyersTotal and OrderTotal only if BuyersTotal has a value, that is, Not Null.

During runtime, the application runs all conditional mappings and assigns a value to the target field only when the condition is true. Otherwise, the application ignores the mapping. In scenarios where the fields are mandatary and the conditions are not satisfied, you might observe flow service runtime failure issues.

You can map multiple source fields to the same target field if the mappings to the target have conditions. In some scenarios, where you have mapped multiple source fields to a single target field, at most, only one of the conditions you define can be true at run time. If more than one condition to the same target field evaluates to true, then the result is not definite because the order in which the conditions are run is not guaranteed.

You can define conditions for a map using the Condition Editor screen. The Condition Editor screen can be accessed by selecting the map and clicking the Map by Condition () icon on the Pipeline panel or by double-clicking the map.

The Condition Editor screen functionality is similar to that of the Expression Editor screen. For more information about the Condition Editor screen description, see Expression Editor.

Points to Consider when Defining Conditions for Maps

The condition expression given for the map behaves similar to the flow service containing a Branch condition. For more information on Branch steps, see Branch.

Adding Conditions to a Map

Example

Assume that there is a flow service CentimetertoMeterConversion that converts the values provided by you from centimeters to meters. If the meter value is zero, then a custom message is logged. The flow service includes the following:

Let us modify the logic of the flow service such that it converts only specific values instead of all values based on the following conditions:

Before you Begin

Basic Flow

  1. Go to the CentimetertoMeterConversion flow service.

  2. Select the centimeters to num1 map and click from the pipeline tool bar. The Condition Editor screen appears.

    By default, the first field is selected and displayed in the editor.

  3. Ensure that the Enable Condition during execution check box is selected. Otherwise, the condition is not considered during runtime.

  4. Define the conditions. For more information on how to define conditions and sub conditions, see Creating Complex Expressions.

    As per the example, the condition minValue > 1 and maxValue < 9999 is defined for the selected mapping as shown in the following iluustration:

  5. Click Save. The condition is added to the map and the icon is added to indicate that the map has a condition defined.

  6. Map the default pipeline Input field to num1.

  7. Define condition for the Default pipeline Input field.

    Note
    To remove a condition from a map:
    1. Select the map and click the Map By Condition icon. The Condition Editor appears.
    2. Click Remove Condition.
  8. Click Run. The results are displayed based on the values you provide.

Default Pipeline Mapping Rules and Behavior

Before you start mapping fields, it is recommended to go through the mapping guidelines to avoid runtime issues due to incorrect mappings.

Note
  • Mapping between a multidimensional data type (Target) and any single dimensional data type (Source), then the Target field is assigned to the specified element of the Source field. For rules to know whether mapping occurs at runtime, see the tables in the Default Pipeline Mapping Rules and Behaviour section.
    • Single Dimension Data Types - String, Short, Long, Integer, Float, Double, Boolean, Byte Array (b[]), Big Decimal, Big Integer, Object
    • Multi Dimension Data Types - String [], Short [], Long [], Integer [],Float [], Double [], Boolean [], Big Decimal [], Big Integer [], Object[]
    • Document, Document References can be mapped only with Document, Document References And arrays of these (Document [], Document Reference[]).

Indexed Mapping

The Indexed Mapping feature allows you to map array fields and specify which element in the array you want to map. Few examples are:

The mapping between array indexes can be performed using the Indexed Mapping dialog box. The Indexed Mapping dialog box automatically appears when you map array fields in the Pipeline panel.

Note
Index mapping for the Document and Document Reference data types are not supported.

The Indexed Mapping dialog box has the following options:

Note
  • If you have not mapped:

    • any indexes and the Map specific elements in an array option is selected, then the parent fields are automatically mapped.
    • any one of the target index with the source index, then that index element is mapped to the parent.
  • If you have mapped multiple source indexes to a single target, then the result is not definite because the order in which the mappings are run is not guaranteed.

  • If you want to add or delete a row index, you can use the Add and Delete buttons in the Indexed Mapping dialog box. To delete a single index entry, use the Delete button adjacent to the index entry row. You cannot modify any existing mappings that are indexed.

Guidelines for Mapping Array Fields

Default Pipeline Rules for Mapping Array Fields

When you create maps between scalar and array fields, you can specify which element of the array field you want to map to or from. Scalar fields are those that hold a single value, such as String and Object. Array fields are those that hold multiple values, such as String List and Object List. For example, you can map a String to the second element of a String List.

If you do not specify which element in the array that you want to map to or from, the application uses the default rules in pipeline to determine the value of the target field. The following table lists the default pipeline rules considered for mapping to and from array fields:

Field 1 - Field 2 Behavior
A scalar field - An array field that is empty (the field does not have a defined length) The map defines the length of the array field; that is, it contains one element and has length of one. The first (and only) element in the array is assigned the value of the scalar field.
A scalar field - An array field with a defined length The length of the array is preserved and each element of the array is assigned the value of the scalar field.
An array field - A scalar field The scalar field is assigned the first element in the array.
An array field - An array field that does not have a defined length The map defines the length of the target array field; that is, it will be the same length as the source array field. The elements in the target array field are assigned the values of the corresponding elements in the source array field.
An array field - An array field that has a defined length The length of the source array field must equal the length of the target array field. If the lengths do not match, the map does not occur. If the lengths are equal, the elements in the target array field are assigned the values of the corresponding elements in the source array field.

Smart Mapping

IBM leverages the collective intelligence of the IBM webMethods Integration community to suggest which fields should be mapped in a data map by learning from the mappings you create.

Smart mapping provides you with recommendations while mapping the pipeline data and utilizes a series of algorithms to determine the likely accuracy of a given suggestion, enabling you to toggle between high, medium, and low levels of mapping confidence. A Machine Learning (ML) algorithm is applied to provide the suggestions. The ML algorithm learns from the mappings you create and provides suggestions automatically to map similar fields. The algorithm benefits from having more data from more number of users.

Smart mapping is anonymous and does not store any customer-specific information or actual data of any kind and is available to only those tenants who provide their consent to share their mapping information. Individual fields contained within the records are indexed. Specifically, the field names and their hierarchy are indexed, as well as the mapping relationships between them.

After providing consent, if you have the relevant role permissions, you can choose to opt-out of smart mapping. Your maps will not be indexed, that is, if you opt out of smart mapping, you will not be able to see or utilize any mapping suggestions and your maps will no longer be indexed. However, as the index is anonymous, any maps and profiles indexed during the opt-in period will remain in the database. Further, the data collected is confined to that particular data center where the tenant resides.

Mapping recommendations are not tenant specific, so mapping inputs from one tenant maybe used to make recommendations for another tenant. When you do the mapping, the data collected does not reflect immediately as a recommendation for another user as the information is recorded and processed in our database only at specified intervals.

Note
For trial tenants, the mapping data is collected by default. Further, for trial tenants and for the Free Forever Edition, smart mapping is always enabled and cannot be changed. For paid tenants, only an Administrator has the permission to enable or disable smart mapping.

The following information is not indexed:

How it works

  1. To provide your consent to share the mapping information, from the IBM webMethods Integration navigation bar, click on the profile icon located at the top-right corner of the home page, and select Settings > Preferences.

  2. On the Configure Tenant Preferences page, select the Publish integration mappings to recommendations engine option and click Save to enable smart mapping. This provides you mapping recommendations whenever you do mapping. By enabling this option, you are also providing us your consent to collect your mapping information. For trial tenants and for the Free Forever Edition, this option is always enabled by default and cannot be changed.

  3. Select a project and then the flow service for which you want to do smart mapping.

  4. On the pipeline mapping screen, select Recommend Mappings to see the recommended mappings. If you select the Show only mapped option, the Recommend mappings option is automatically cleared.
    When the screen is initially loaded, only high recommendations appear by default.

  5. Drag the recommendation accuracy slider to view the mapping recommendations and filter the recommendations based on their recommendation accuracy. The recommendation accuracy or confidence number appears when you hover the pointer over a mapping and is the level of mapping confidence of that specific recommendation.

    Based on the level of mapping confidence, the recommendations are grouped into High, Medium, and Low categories:

    • Mappings have the highest probability
    • Mappings have medium probability
    • Mappings have the least probability

    You can select more than one category by moving the slider. In the following example, mappings that have medium and high probability are displayed.

  6. Select a mapping and click Accept to hard map it. You can select one or more recommendations and accept only those recommendations (Selected (x)), or you can accept all the recommendations that appear on the screen (All shown (x)). The accepted recommendation behaves like an actual mapping.

  7. To unmap a hard mapping, select the hard mapping and then click the delete icon available on the pipeline action bar. Once the hard mapping is deleted, the recommendations appear again. To hard map the recommendations again, click Accept and select the desired option.

    Note
    If you are an Administrator of a paid tenant, and have cleared the Publish Integration Mappings to Recommendations Engine option, IBM webMethods Integration displays a message to inform you whether you want to enable the smart mapping feature. If you select Yes, the Predict Mappings option appears in the pipeline mapping screen.

Expression Editor

The Expression Editor is an interface that allows you to define complex expressions (conditions) using the conditional controls such as If, Else If, While, and Do Until. A complex expression is formed by combining simple conditions (rules) with logical operators AND and OR or negating these conditions with logical negation operator NOT.

You can access Expression Editor by clicking the Expression () icon on the Flow service step. The Expression icon appears only when you select a conditional construct control in the Flow service step.

Components of Expression Editor

Expression Editor consists of two sections:

Expression View

The Expression View section displays the conditions defined. Additionally, when you hover the mouse pointer on operator of the condition, the condition’s scope is highlighted for easy reference as shown in the following illustration:

Expression Builder

The Expression Builder section allows you to create complex conditions by defining rules. By default, a rule step is displayed to start with the condition definition. A rule step consists of Left Operand, Operator, and Right Operand to define a condition. The operands list the fields available in the Pipeline. You can group multiple rules to define sub conditions.

Expression Builder contains the following controls that aid you in defining the complex conditions:

At any time you can either modify or delete a part or whole of the complex condition using these controls.

When you hover on the operands, the complete path of the operand appears.

Creating Complex Expressions

Example

Let us create a complex expression for checking the vaccination slot availability with the following conditions:

Before you Begin

Basic Flow

  1. Go to Flow services.

  2. Select the project where you want to create the new flow service. You can also create a new project.

  3. Click to create a flow service. The Start Creating the Flow service screen appears.

  4. Provide a name for the flow service. For example, GetVaccinationSlotStatus and an optional description for the new flow service.

  5. Select a conditional control in the flow service step. For example, If.

  6. Click the Expression () icon on the conditional flow service step. The Expression Editor screen appears.

  7. Perform the following steps to define a rule:

    1. Select a left operand.

    2. Select an operator.

    3. Select a right operand.

    The rule is defined. As per the example, the rule 1 - Location is Washington is defined as follows:

  8. [Optional] Click or Add Rule. A new rule step is added.

  9. Repeat the above steps to define more rules as per your requirement.

  10. Select the operator (group-level) from the And drop-down list to conjunct the previous and new rules. As per the example, rule 2 - Zipcode is 20010 is defined and both are combined with an And operator as follows:

  11. Perform the following steps to define a group:

    1. Click Add Group. A new rule step appears and is grouped under a separate block.

    2. Select the operands and operator to define the rule.

    3. [Optional] Click or Add Rule (group-level). A new rule step is added to the group.

    4. [Optional] Select the operator from the And drop-down list (group-level) to conjunct the previous and new rules in the group.

    5. Repeat the above steps to define all rules in the group. The sub condition is defined.

    As per the example, group 1 - Vaccine can be either Pfizer, Moderna, or Sputnik, group 2 - Age is less than or equal to 45 and slot exists are defined as follows. The groups and other rules are combined with an And operator.

  12. Define the rule 3 - Venue is Howard University Hospital as per the example. The expression created is as follows:

  13. [Optional] Perform the following steps to remove a rule or rule group:

    • Rule - Click adjacent to the rule that must be deleted. The rule is deleted from the complex condition.

    • Rule Group - Click Remove Group in the group that must be deleted. The rule group is deleted from the complex condition.

    Tip
    You can use the keys Ctrl+Z and Ctrl+Y to undo and redo the delete actions.
  14. [Optional] Perform the following steps to negate a rule or rule group:

    • Rule - Click adjacent to the rule that must be negated. The rule is deleted from the complex condition.

    • Rule Group - Click Negate Group in the group that must be negated. The rule group is deleted from the complex condition. The button is renamed as Remove Negation and allows you to remove the negation for that group.

  15. Click on the Expression Editor screen. The condition is added to the flow service step. You can click the down and up arrows in the flow service step to view and hide the complete expression.

The complex condition is created and you can proceed with the other flow service steps.

Creating Flow services

See the following examples to learn how to create flow services. Click here for information on how to manage roles and project permissions.

Get leads from Salesforce CRM and create corresponding customer leads in Microsoft Dynamics 365 CRM

Summary

Get leads from Salesforce CRM and create corresponding customer leads in Microsoft Dynamics 365 CRM.

Before you begin

Basic Flow

  1. Select the project where you want to create the new Flow service. You can also create a new project.

  2. Click the Flow services tab and on the Flow services page, click the icon.

  3. Provide a name, for example, SalesforceToMSDynamics365CRM, and an optional description for the new flow service.

  4. Type Salesforce in the search box and select Salesforce CRM.

    Tip
    In a flow service step, you can perform search in one of the following ways:
    - Alias-based search: Type a keyword and the matching results are displayed. List of supported keywords for alias-based search are as follows:
    - map: Transform pipeline - iteration/loop: While, Do Until, Repeat, Repeat for Count, Repeat-Input-Output - selection/condition: If, Else, If Else, Else If, Switch, Branch, Case - jump: Break, Exit - exception: Try, Catch, Finally, Try Catch, Try Finally, Try Catch Finally
    - Restricted scope search: Type a keyword followed by a pipe symbol or space or tab to search within a specific scope, for example, to search within flow services, type fs|. List of supported keywords for restricted scope search are as follows:
    - ctrl: Controls - con: Connectors - fs: Flow services - svc: Services
  5. Select the queryleads operation.

  6. Select the SalesforceCRM_1 account. You can also create or configure an account inline.

  7. Click the icon to add a new step.

  8. Type repeat, select Repeat to create a repeat step, and then select the /Lead option.

  9. Select Microsoft Dynamics 365 CRM and then select the associated createLead action.

  10. Select the msdynamics_1 account. You can also create or configure an account inline.

  11. Click the mapping icon to map the input and output fields.

  12. Click the Pipeline Input fields (FirstName and LastName) and drag it to the service input (firstname and lastname). The service output is automatically mapped to the Pipeline Output by a dotted line.

  13. Save the flow service and run it by clicking the Run icon.

  14. View the flow service execution results for a successful run. The lead ID generated is acf4f843-2970-ea11-a811-000d3a4da920.

    Note
    If a value is null for a field or if the datatype is unknown, then the obj (object) icon is displayed.

  15. Download the results.

16.You can also view the previous flow service execution results.

Note
By default, all flow service execution results are retained for 30 days. You can optionally specify the number of days (up to 30 days) for which you would like to retain the flow service execution logs by clicking the Modify Retention Period link available at Monitor > Execution Results > Flow service Execution. Once the retention period is over, the flow service execution logs are deleted automatically.

Get attendees from Concur and create contacts in Salesforce CRM

Summary

Get attendees from Concur and create contacts in Salesforce CRM.

Before you begin

Basic Flow

  1. Select the project where you want to create the new flow service. You can also create a new project.

  2. Click the Flow services tab and on the Flow services page, click the icon.

  3. Provide a name, for example, ConcurAttendeeToSalesforce, and an optional description for the new flow service.

  4. Type Concur in the search box, select Concur, and then in the Type to choose action field, select Add Custom Operation.

  5. Do the steps as shown in the following images to create the GetConcurAttendees custom operation.

  6. Select GetConcurAttendees, click the icon, and select the Concur_1 account. You can also create this account inline.

  7. Click the icon to add a new step.

  8. Type repeat, select Repeat to create a repeat step, and then select the /item option.

  9. Select Salesforce CRM and then select the associated createcontact action.

  10. Select the SalesforceCRM_1 account. You can also create or configure this account inline.

  11. Click the mapping icon to map the input and output fields.

  12. Map the input and output fields as shown below. Double-click the OtherCity and OtherCountry fields and set the required input values. You can also select the field and click the Set Value icon . The service output is automatically mapped to the Pipeline Output by a dotted line.

  13. Save the flow service and click Run.

  14. View the flow service execution results.

Retrieve files stored in Amazon Simple Storage Service (S3) bucket and log the content of the files

Summary

Retrieve files stored in Amazon Simple Storage Service (S3) bucket and log the content of the files.

Before you begin

Note
Click here for information on how to manage roles and project permissions.

Basic Flow

1.Select the project where you want to create the new flow service. You can also create a new project.

2.Click the Flow services tab and on the Flow services page, click the icon.

3.Provide a name, for example, AmazonS3, and an optional description for the new flow service.

4.Type Amazon Simple Storage Service (S3) in the search box, select it, and then select the action or operation, getBucket.

5.Select the AmazonSimpleStorageServiceS3_1 account. You can also create or configure an account inline.

6.Click the mapping icon to set a value for getbucketinput.

7.Expand getBucketInput and click bucketName.

8.Type softwareagbucketaws as the value for bucketName.

9.Click the icon to add a new step. Then type repeat to select the Repeat step and select the /content option.

10.Select Amazon Simple Storage Service (S3) and choose the getObject action to retrieve the object from the specified bucket.

11.Click the mapping icon to map the input and output fields.

12.As shown below, click the pipeline input fields (name and key) and drag it to the service input (bucketName and objectName). The service output (getObjectOutput) is automatically mapped to the pipeline output by a dotted line.

.

13.Click the + icon to add a new step as shown below.

14.Select the Flow function and then select the logCustomMessage service. You can also type logCustomMessage and select it. This logs a message, which you can view in the flow service execution results screen.

15.Map the input (stream) to message. This step logs the contents of the files in the bucket.

16.Save the Flow service and click Run.

17.You can also view the execution result in the Monitor > Flow service Execution page. Click the execution result name link to view the execution details.

Creating Custom Operations in Flow services

IBM webMethods Integration provides predefined connectors, which contain SaaS provider-specific information that enables you to connect to a particular SaaS provider. Further, each connector uses an account to connect to the provider’s back end and perform operations. Each connector comes with a predefined set of operations. You can also create your own custom operations while creating a flow service.

Let us see how to create a custom operation while creating a flow service and then use that custom operation to create a Salesforce CRM back end account.

1.After you log in, select a project or create a new project where you want to create the flow service.

2.Click the Flow services tab and on the Flow services page, click the icon.

3.Provide a name SalesforceCreateAccountCustom and description of the new flow service.

4.Type Salesforce in the search box, select Salesforce CRM, and then select Add Custom Operation.

5.On the Connect to account page, select the supported Authentication type and the Salesforce CRM account created from the drop-down list. Provide a name and description of the custom operation.

6.Select the create operation.

Note that for REST-based connectors, after selecting the operation, you can click Headers to add input Headers, if required. IBM webMethods Integration displays the default HTTP transport headers for the operation, along with their default values. At run time, while processing the headers, IBM webMethods Integration substitutes the values as necessary. In order to customize the headers, do the following:

a. Click + Add to add a custom Header.

b. Click the icon to specify the header name and an optional default value for the header variable. If the variable is null in the input pipeline, this value will be used at run time. If the variable already has an existing default value defined, this value will overwrite the existing value at run time.

c. If headers appear in the signature, select Active to activate the headers in the signature.

d. To delete a custom header that you have added, click Delete.

Note
You cannot delete the required headers.

You can also customize the parameters for REST-based connectors after selecting the operation, by clicking the Parameter option. Review the operation parameter details. IBM webMethods Integration displays the parameter Name and Description, the Data Type used to represent the kind of information the parameter can hold, the parameterization Type of the request, and the default value needed to access the operation. To specify a default value for the parameter, click the icon and then type or paste the default value. The default value is used at run time. You cannot add or delete request parameters. You can only modify the default value of a parameter. All parameters appear in the signature.

Now let us go back to our example.

7. After you select the create operation, click Next, and then select the Business Object Account. Business Objects appear only for certain connectors and operations.

8.Select the data fields and confirm the action to create the custom operation. Data fields appear only for certain connectors and operations.

9.On the Flow service editor, click the icon to define the input and output fields.

10.Create two Input Fields, AccountName and CityName.

11.Click to edit the flow service mapping. Only fields selected earlier are shown in the input panel.

12.Save the flow service and click Run. Provide the custom field values in the AccountName and CityName fields, for example, Software

As the results show, the Software account is created.

Support for Multipart Request Body

IBM webMethods Integration supports the multipart/form-data media type using which you can embed binary data such as files into the request body. Though application/x-www-form-urlencoded is a more natural way of encoding, it becomes inefficient for encoding binary data or text containing non-ASCII characters. The media type multipart/form-data is the preferred media type for request payloads that contain files, non-ASCII, and binary data.

For example, if you want to create a user as well as upload a photo, the request has to be a multipart request where one part is an image file while the other part is a JSON request body. Further, uploading the CRM individual contact data to Salesforce is time consuming, so using the MIME/Multipart attachments capability, you can upload the csv/json file containing multiple contacts data into Salesforce in a single run.

For some connectors and operations, for example, for SalesforceR Bulk v2 Data Loader, DocuWare, Google Drive, Amazon S3, and FreshService, IBM webMethods Integration supports multipart request body.

Example of a multipart request

A multipart/form-data request body contains a series of parts separated by a boundary delimiter, constructed using Carriage Return Line Feed (CRLF), “–”, and also the value of the boundary parameters. The boundary delimiter must not appear inside any of the encapsulated parts.

Each part has the Name, Type, Content-Type, and Part ID fields.

--BOUNDARY


Content-Type: application/json


Content-Disposition: form-data; name="job"


{


"object":"Contact",


"contentType":"CSV",


"operation":"insert"


}


--BOUNDARY


Content-Type: text/csv


Content-Disposition: form-data; name="content"; filename="content"


(Content of your CSV file)


--BOUNDARY

Part Configuration

While adding a custom action, for example, for the Freshservice Create Child Ticket With Attachments operation, you can click Attachments to view the list of all the configured parts to be sent to the service provider. You can send a multipart/form-data payload which contains either a file, or text, or a document type.

The parts to be sent to the service provider appear in the input signature. All options including the Add option to add a custom part are disabled if the resource is not of type multipart/form-data. Currently, multipart/form-data payload is supported only at the request level, that is, only in the input signature.

Example to create a ticket with attachments (multipart data) in Freshservice

Before you begin

Basic Flow

  1. Select the project where you want to create the new flow service. You can also create a new project.
  2. Click the Flow services tab and on the Flow services page, click the icon.

  3. Provide a name for the flow service, for example, CreateTicketWithAttachment, and an optional description for the new flow service.

  4. Upload a file from the FTP server to Freshservice. Select the File Transfer Protocol (FTP/FTPS) connector, the getFile operation, and the FTPS_4 account.

  5. Let us upload the hello.txt file available on FTP server in Freshservice. Click Set Value for remoteFile and select the same file in the Set Value - remoteFile dialog box. Click Save.

  6. Select the Freshservice connector. As you are creating a ticket with an attachment, select the createTIcketWithAttachment operation and the account as Freshservice_1.

  7. Click the Edit Mapping icon. Under Pipeline Input, map contentStream to value.

  8. Set the following values on the mapping screen:

    • Set the value for filename as hello.txt.
    • Set the value for email as abc@xxxx.com.
    • Set the value for subject as create ticket.
    • Set the value for description as create ticket with attachment.
    • Set the value for priority as 1.
    • Set the value for status as 2.
    • Set the value for requester_id as 27000450816. This is the agent ID in Freshservice.
    • Set the value for phone as 123456789.
    • Set the value for source as test.
  9. Save and run the flow service.

  10. Go to Freshservice, click Tickets, and check that the ticket is generated.

Create bulk accounts in Salesforce using a multipart predefined operation

For some connectors and operations, for example, for the Salesforce R Bulk v2 Data Loader connector and createAndUploadDataUsingMultipart predefined operation, IBM webMethods Integration supports multipart request body.

Before you begin

Basic Flow

1.Select the project where you want to create the new flow service. You can also create a new project.

2.Click the Flow services tab and on the Flow services page, click the icon.

3.Provide a name and an optional description for the new flow service.

4.Type IO in the search box, select IO, and then select the stringToStream service.

5.Click the mapping icon to map the input and output fields.

6.Set the below value for string:

7.Set the value for encoding as UTF-8.

8.Click the icon to add a new step.

9.Select the Salesforce(R) Bulk v2 Data Loader connector and the createAndUploadDataUsingMultipart predefined operation. Select the SFBulkV2_02Apr account.

10.Click the mapping icon to map the input and output fields.

11.Map inputStream to value. The service output is automatically mapped to the Pipeline Output by a dotted line.

12.Set values for fileroot as shown below:

13.For fileRoot1, set values for name as content, contentType as text/csv, type as FILE, and filename as content.

14.Save the flow service and run it by clicking the Run icon.

15.View the flow service execution results for a successful run.

Built-in Services

IBM webMethods Integration has an extensive library of services for performing common integration tasks such as transforming data values, performing simple mathematical operations, and so on.

Services are invoked at run time. While creating a flow service, you can sequence services and manage the flow of data among them.

Related services are grouped in categories. Input and output parameters are the names and types of fields that the service requires as input and generates as output and these parameters are collectively referred to as a signature.

Service Category Description
Alert Use the Alert services to notify users when predefined conditions, such as password expiry, license key updates, rule violations, or service errors, are met, ensuring timely awareness and response to critical system events.
B2B Utils Use the B2B Utils services to perform generateResponse, constructSubmitInput, parseContent operations in IBM webMethods Integration.
Compress Use Compress services to compress the data before sending the HTTP request and decompress it after receiving the HTTP response.
Date Use Date services to generate and format date values.
Datetime Use Datetime services to build or increment a date/time. The services in datetime provide more explicit timezone processing than similar services in the Date category.
Document Use Document services to perform operations on documents.
E2E Monitoring Use the End-to-End Monitoring services to do the operations specific to IBM webMethods End-to-End Monitoring like setting custom transaction ID.
Flat File Use Flat File services to convert data bytes, data stream, and data string to a document and vice versa.
Flow Use flow services to perform utility-type tasks.
Hashtable Use Hashtable services to create, update, and obtain information about the hashtable.
IO Use IO services to convert data between byte[ ], characters, and InputStream representations. These services are used for reading and writing bytes, characters, and streamed data to the file system. These services behave like the corresponding methods in the java.io.InputStream class. These services can be invoked only by other services. Streams cannot be passed between clients and the server, so these services will not execute if they are invoked from a client.
JSON Use JSON services to convert JSON content into a document and to convert a document into JSON content.
List Use List services to retrieve, replace, or add elements in an Object List, Document List, or String List, including converting String Lists to Document Lists.
Math Use Math services to perform mathematical operations on string-based numeric values. Services that operate on integer values use Java’s long data type (64-bit, two’s complement). Services that operate on float values use Java’s double data type (64-bit IEEE 754). If extremely precise calculations are critical to your application, you should write your own Java services to perform math functions.
MIME Use MIME services to create MIME messages and extract information from MIME messages.
Schema Use Schema services to validate objects and to validate the pipeline.
Storage Use Storage services to insert, retrieve, update, and remove entries from a data store.
String Use String services to perform string manipulation and substitution operations.
Transaction Use Transaction services only in conjunction with the Database Application operations. These services are applicable when the Database Application account is of type Transactional.
Utils Use Utility services to generate a random Universally Unique Identifier (UUID) or to generate a message digest for a given message.
XML Use XML services to convert a document to XML content and XML content to a document.
Reference Data Use Reference Data services to upload reference data that defines the set of permissible values to be used by other data fields.
JWT Use JSON Web Token(JWT) for securely exchanging information as a JSON object between parties.
SMIME Use smime services to create digitally signed and/or encrypted MIME messages.
Security Use security services to control which client certificates are sent to other services and digitally sign data and process digital signatures. You can also use the service to store and retrieve outbound passwords to access secure resources.
Keystore
Pkcs7 Creates a PKCS7 Data object.
Document Use document services to perform operations on documents in the pipeline.
String Use string services to perform string manipulation and substitution operations.
Note
When deploying a flow service in a multi-instance setup, the service is synchronized across both instances but operates on only one instance during execution. For example, if the flow service includes an alert.emit service, it exists in both instances but functions only within one instance at a time.

Alert services

Use the Alert services to notify users when predefined conditions, such as password expiry, license key updates, rule violations, or service errors, are met, ensuring timely awareness and response to critical system events.

The following Alert services are available:

Service Description
emit Performs an alert when a pre-configured condition is met.
channels Gets all alert channels in the system. Channels help classify alerts and let you subscribe to a specific type of alert.
countAll Gets the count of all alerts in the system, read and unread, or a subset of alerts that meet the filter criteria.
fetchAll Fetch all alerts in the system, including read and unread, or a subset based on filter criteria.
getSettings Gets the settings of the system notifier.
setSettings Updates the settings of the system notifier.
deregisterChannel Deregisters a registered custom channel.
getChannel Gets the details of a specific channel.
registerChannel Registers a custom channel.
updateChannel Updates the settings of a channel.
severities Lists the pre-defined severities that you can associate with an alert channel. The severity associated with an alert lets you assess the relative impact of a business event on the system.

emit

Generates an alert when a pre-configured condition is met. For example, User or Master Password Expiry, License Key Update, Enterprise Gateway Rule Violation, Service Error, and so on. This service is invoked by IBM webMethods Integration components to raise alerts.

Input Parameters

channelID: Integer. Identifier of the channel associated with the alert.

severity: String. Severity associated with the alert channel.

subject: String. Subject of the alert message.

contentType: String. Type of information in the alert. For example, text/plain.

content: String. Content of an alert. For example, Alert {0} Message Size Limit filter failed.\nClient IP Address: {1}\n Request URL : {2}\n Date & Time : {3} content

Output Parameters

alertId: Long. A unique identifier assigned to each alert emitted.

channels

Gets all alert channels in the system. Channels help classify alerts and let you subscribe to a specific type of alert.

Input Parameters

None.

Output Parameters

Channels: Document List. The list of alert channels in IBM webMethods Integration. By default, there are 13 channels. All channels have the following keys:

Usage Notes

The default channels, events when alerts are raised for a channel, and the corresponding severity are described in the following table:

Channel ID Channel Name Events Severity
1 Service Error Service execution errors.
Note
By default, service error notifications are disabled.
Error
2 Server Error Server errors such as HTTP 404.
Note
By default, server error notifications are disabled.
Error
3 Password Management A user password expires.
A user password is about to expire.
Default administrator password is not changed.
Critical
Warning
4 License Management IBM webMethods Integration license expires.
IBM webMethods Integration license is about to expire.
Critical
Warning
5 Certificate Management A security certificate is about to expire. Warning
6 Account Locking Multiple login attempt failures that result in a locked account.
A locked account is unlocked.
Critical
Information
8 Authentication Login failure limit is reached. Error
9 Package Management Package subscription (Delivery)
Package subscription (Release)
Note
By default, package management notifications are disabled.
Information
10 Threat Protection Enterprise Gateway deny rule violation.
Enterprise Gateway allow rule violation.
Critical
Warning
11 Metering Log Errors connecting to the Metering agent server. Error
12 User Management User management related alerts Warning
13 Master Password A master password expires.
Default master password is not changed.
Warning
14 Hybrid Connections Tenant connection disconnected
Tenant connection restored
Account disconnected
Account restored
Error
Information
Error
Information

countAll

Gets the count of all alerts in the system, read and unread, or a subset of alerts that meet the filter criteria.

Input Parameters

Output Parameters

Usage Notes

To get the count of all alerts in the system, read and unread, do not specify the filter criteria as inputs.

fetchAll

Fetch all alerts in the system, including read and unread, or a subset based on filter criteria.

Input Parameters

The default is timestamp.

Output Parameters

Usage Notes To fetch all read and unread alerts in the system, do not specify the filter criteria as inputs. The number of notifications on a page is identified by pageSize and the current page is identified by pageNumber.

getSettings

Gets the settings of the system notifier.

Input Parameters
None.

Output Parameters

setSettings

Updates the settings of the system notifier.

Input Parameters

Output Parameters

message: String. Indicates whether the system notifier settings are updated or not.

Usage Notes

Based on the value of the retentionPeriodInDays parameter, a purge job clears the alerts stored in the database.

deregisterChannel

Deregisters a registered custom channel.

Input Parameters

channelId Integer: Identifier of the channel that you want to deregister.

Output Parameters

Usage Notes

Channel IDs for custom channels are generated by the system and cannot be modified. The first custom channel gets 1001 as the channel ID and subsequent custom channels have consecutive numbers. Once a custom channel is deregistered, the channel ID is no longer available for a new custom channel until IBM webMethods Integration is restarted.

Deregistering a channel also deletes all the alerts for that channel.

getChannel

Gets the details of a specific channel.

Input Parameters

channelId Integer: Identifier of the channel that you want to retrieve.

Output Parameters

registerChannel

Registers a custom channel.

Input Parameters

The default value is true for custom channels as well as system channels other than Service Error and Server Error.

The default value is true for custom channels as well as system channels other than Service Error and Server Error.

Output Parameters

Usage Notes
For custom channels, channel IDs are generated by the system and cannot be modified. The first custom channel gets 1001 as the channel ID and subsequent custom channels have consecutive numbers. Once a custom channel is deregistered, the channel ID is no longer available for a new custom channel until IBM webMethods Integration is restarted.

updateChannel

Updates the settings of a channel.

Output Parameters

message: String. Indicateswhether the channel is successfully updated or not.

Usage Notes

Invoke the alert:updateChannel service to ignore a notification of a specific type or restore an ignored notification from IBM webMethods Integration Administrator.

severities

Lists the pre-defined severities that you can associate with an alert channel. The severity associated with an alert lets you assess the relative impact of a business event on the system.

Input Parameters None.

Output Parameters

B2B Utils services

generateResponse

Generates a response for the processing rule Call an integration action.

Note
generateResponse does not support large document.

Input Parameters

Output Parameters

constructSubmitInput

Prepare the necessary input used for submitting the business documents to IBM webMethods B2B product instance.

Input Parameters

Configuring an AS4 body

Document. To configure an AS4 body document. This is optional.

Configuring AS4 attachments [ ]

Document List. To configure AS4 attachments. This is optional.

Configuring AS4 params

Document. A document that provides parameters on how IBM webMethods B2B recognizes and processes a AS4 document. Configure AS4 params.

Configuring an RNIF body

Document. To configure an RNIF body document.

Configuring an RNIF attachments [ ]

Document List. To Configure a list of attachments to be use in RNIF message. This is optional.

Configuring an RNIF params

Document. A document that provides parameters on how IBM webMethods B2B recognizes and processes a RNIF document. Configure RNIF params.

Output Parameters

Output of constructSubmitInput operation is the input parameters for submit operation. See Submit.

parseContent

Parses request content passed by the processing rule Call an integration action as bytes or string data type. For more information, see Call an integration.

Note
parseContent does not support large document.

Input Parameters

Output Parameters

Compress Services

Use Compress services to compress the data before sending the HTTP request and decompress it after receiving the HTTP response.

The following Compress services are available:

Service Description
compressData Performs compression of data.
decompressData Performs decompression of data.

compressData

Compresses the data before sending the HTTP request using any of the specified compression schemes.

Input Parameters

Output Parameters

decompressData

Decompresses the data based on the response header of the HTTP response.

Input Parameters

Output Parameters

Date Services

Use Date services to generate and format date values.

Pattern String Symbols - Many of the Date services require you to specify pattern strings describing the data’s current format and/or the format to which you want it converted. For services that require a pattern string, use the symbols in the following table to describe the format of your data. For example, to describe a date in the January 15, 1999 format, you would use the pattern string MMMMM dd, yyyy. To describe the format 01/15/99, you would use the pattern string MM/dd/yy.

Symbol Meaning Presentation Example
G era designator Text AD
y year Number 1996 or 96
M month in year Text or Number July or Jul or 07
d day in month Number 10
h hour in am/pm (1-12) Number 12
H hour in day (0-23) Number 0
m minute in hour Number 30
s second in minute Number 55
S millisecond Number 978
E day in week Text Tuesday or Tue
D day in year Number 189
F day of week in month Number 2 (2nd Wed in July)
w week in year Number 27
W week in month Number 2
a am/pm marker Text PM
k hour in day (1-24) Number 24
K hour in am/pm (0-11) Number 0
z time zone Text Pacific Standard Time or PST or GMT-08:00
Z RFC 822 time zone (JVM 1.4 or later) Number -0800 (offset from GMT/UT)
escape for text Delimiter
’ ‘ single quote Literal '

Time Zones - When working with date services, you can specify time zones. The Earth is divided into 24 standard time zones, one for every 15 degrees of longitude. Using the time zone including Greenwich, England (known as Greenwich Mean Time, or GMT) as the starting point, the time is increased by an hour for each time zone east of Greenwich and decreases by an hour for each time zone west of Greenwich. The time difference between a time zone and the time zone including Greenwich, England (GMT) is referred to as the raw offset.

The following table identifies the different time zones for the Earth and the raw offset for each zone from Greenwich, England. The effects of daylight savings time are ignored in this table.

Note
Greenwich Mean Time (GMT) is also known as Universal Time (UT).
ID Raw Offset Name
MIT -11 Midway Islands Time
HST -10 Hawaii Standard Time
AST -9 Alaska Standard Time
PST -8 Pacific Standard Time
PNT -7 Phoenix Standard Time
MST -7 Mountain Standard Time
CST -6 Central Standard Time
EST -5 Eastern Standard Time
IET -5 Indiana Eastern Standard Time
PRT -4 Puerto Rico and U.S. Virgin Islands Time
CNT -3.5 Canada Newfoundland Time
AGT -3 Argentina Standard Time
BET -3 Brazil Eastern Time
GMT 0 Greenwich Mean Time
ECT +1 European Central Time
CAT +2 Central Africa Time
EET +2 Eastern European Time
ART +2 (Arabic) Egypt Standard Time
EAT +3 Eastern African Time
MET +3.5 Middle East Time
NET +4 Near East Time
PLT +5 Pakistan Lahore Time
IST +5.5 India Standard Time
BST +6 Bangladesh Standard Time
VST +7 Vietnam Standard Time
CTT +8 China Taiwan Time
JST +9 Japan Standard Time
ACT +9.5 Australian Central Time
AET +10 Australian Eastern Time
SST +11 Solomon Standard Time
NST +12 New Zealand Standard Time

Examples - You can specify timezone input parameters in the following formats:

The following Date services are available:

Service Description
calculateDateDifference Calculates the difference between two dates and returns the result as seconds, minutes, hours, and days.
compareDates Compares two dates and returns the result as integer.
currentNanoTime Returns the current value of the running Java Virtual Machine’s high-resolution time source, in nanoseconds.
dateBuild Builds a date String using the specified pattern and the specified date services.
dateTimeBuild Builds a date/time string using the specified pattern and the specified date services.
dateTimeFormat Converts date/time (represented as a String) string from one format to another.
elapsedNanoTime Calculates the time elapsed between the current time and the given time, in nanoseconds.
formatDate Formats a Date object as a string.
getCurrentDate Returns the current date as a Date object.
getCurrentDateString Returns the current date as a String in a specified format.
incrementDate Increments a date by a specified period.

calculateDateDifference

Calculates the difference between two dates and returns the result as seconds, minutes, hours, and days.

Input Parameters

Output Parameters

Usage Notes

Each output value represents the same date difference, but in a different scale. Do not add these values together. Make sure your subsequent flow service steps use the correct output, depending on the scale required.

compareDates

Compares two dates and returns the result as an integer.

Input Parameters

Output Parameters

Usage Notes

If the formats specified in the startDatePattern and endDatePattern parameters are different, IBM webMethods Integration takes the units that are not specified in the startDate and endDate values as 0.

That is, if the startDatePattern is yyyyMMdd HH:mm and the startDate is 20151030 11:11 and if the endDatePattern is yyyyMMdd HH:mm:ss.SSSand the endDate is 20151030 11:11:55:111, then the compareDates service considers start date to be before the end date and will return the result as -1.

To calculate the difference between two dates, use the calculateDateDifference service.

currentNanoTime

Returns the current value of the running Java Virtual Machine’s high-resolution time source, in nanoseconds. This method can only be used to measure elapsed time and is not related to any other notion of system or wall-clock time. The value returned represents nanoseconds since some fixed but arbitrary origin time (perhaps in the future, so values may be negative). Use this service in-conjunction with elapsedNanoTime service.

Input Parameters

None.

Output Parameters

dateBuild

Builds a date String using the specified pattern and the specified date services.

Input Parameters

Output Parameters

dateTimeBuild

Builds a date/time string using the specified pattern and the specified date services.

Input Parameters

Output Parameters

dateTimeFormat

Converts date/time (represented as a String) string from one format to another.

Input Parameters

Output Parameters

Usage Notes

As described in the “Notes on Invalid Dates” section, if the pattern yy is used for the year, dateTimeFormat uses a 50-year moving window to interpret the value of the year.

If currentPattern does not contain a time zone, the value is assumed to be in the default time zone.

If newPattern contains a time zone, the default time zone is used.

elapsedNanoTime

Calculates the time elapsed between the current time and the given time, in nanoseconds.

Input Parameters

Output Parameters

formatDate

Formats a Date object as a string.

Input Parameters

Output Parameters

getCurrentDate

Returns the current date as a Date object.

Input Parameters

None.

Output Parameters

getCurrentDateString

Returns the current date as a String in a specified format.

Input Parameters

Output Parameters

incrementDate

Increments a date by a specified amount of time.

Input Parameters

Output Parameters

Usage Notes

The addYears, addMonths, addDays, addHours, addMinutes, addSeconds, and addMilliSeconds input parameters can take positive or negative values. For example, If startDate is 10/10/2001, startDatePattern is MM/dd/yyyy, addYears is 1, and addMonths is -1, endDate will be 09/10/2002.

If you specify only the startDate, startDatePattern, and endDatePattern input parameters and do not specify any of the optional input parameters to increment the period, the incrementDate service just converts the format of startDate from startDatePattern to endDatePattern and returns it as endDate.

The format of the date specified in the startDate parameter must match the format specified in the startDatePattern and the format of the date specified in the endDate parameter must match the endDatePattern format.

Datetime Services

Use Datetime services to build or increment a date/time. The services in datetime provide more explicit timezone processing than similar services in the date category.

Providing Time Zones

You can specify timezone input parameters to the datetime services in the following formats:

The following Datetime services are available:

Service Description
build Builds a date/time string using the specified pattern and the supplied date/time elements.
increment Increments or decrements a date and time by a specified amount of time.

build

Builds a date/time string using the specified pattern and the supplied date/time elements.

Input Parameters

Output Parameters

Usage Notes

The build service replaces the date:dateBuild and date:dateTimeBuild services which are deprecated.

If you specify a parameter that does not exist in the supplied pattern, the service ignores that parameter.

If you do not specify a timezone, useSystemTimeZone is set to false, and the pattern includes a time zone, the service ends with an exception.

If a time zone is provided as input to the service either in the timezone parameter or by setting useSystemTimeZone to true, the build service calculates the date/time starting with a “zoned” date/time. The resulting values can differ when daylight savings time transitions are in effect. If no time zone is provided as input to the service either by not specifying timezone or by setting useSystemTimeZone to false, then the build service calculates the date/time starting with an “unzoned” date/time.

The build service is similar to date:dateBuild and date:dateTimeBuild, however, the build service allows the building of a date/time that does not include a time zone. Furthermore, the build service assembles a date/time using each of the provided parameters. Consequently the build service can build a date/time with a value that would be invalid in the current time zone, such as a date/time that would fall into the gap of a daylight saving time transition. This is unlike the date:dateBuild and date:dateTimeBuild services which build a local java.util.Date object that uses the timezone of the machine running IBM webMethods Integration. The date:dateBuild and date:dateTimeBuild service then applies the offset between the local timezone and the specified timezone.

increment

Increments or decrements a date and time by a specified amount of time.

Input Parameters

Output Parameters

Usage Notes

The increment service replaces the date:incrementDate service which is deprecated.

The increment service can be used to decrement a date and time by specifying negative numbers. The addYears , addMonths , addDays , addHours , addMinutes , addSeconds , and addMilliSeconds input parameters can take positive or negative values.

The service ends with an exception if the format of the date specified in the startDate parameter does not match the format specified in the startDatePattern.

If endDatePattern includes a time zone, such as “z”, then the input string and startDatePattern must also have time zone fields, or timeZone must be set, or useSystemTimeZone must be true. Otherwise the service ends with an error.

If you specify only the startDate, startDatePattern, and endDatePattern input parameters and do not specify any of the optional input parameters to increment the period, the increment service just converts the format of startDate from startDatePattern to endDatePattern and returns it as endDate.

If you specify a value for timezone, the service ignores the useSystemTimeZone parameter value.

If you specify a value for timezone and the startDate includes a time zone, then the service uses the supplied timezone to convert the startDate time zone.

If you do not specify a value for timezone and the startDate includes a time zone, then the service uses the time zone in the startDate and ignores the useSystemTimeZone parameter.

If you do not specify a value for timezone, the startDate does not include a time zone, and useSystemTimeZone parameter is true, then the service uses the system time zone.

If startDate does not include a time zone, you do not specify a value for timezone, and useSystemTimeZone is false, the resulting endDate will not include a time zone.

The increment service is similar to date:incrementDate, however, the increment service provides more specific handling of time zones. To match the behavior of date:incrementDate, set useSameInstant to true.

Document Services

Use Document services to perform operations on documents.

The following Document services are available:

Service Description
bytesToDocument Converts an array of bytes to a document.
deleteDocuments Deletes the specified documents from a set of documents.
documentListToDocument Constructs a document from a document list by generating key/value pairs from the values of two elements that you specify in the document list.
documentToBytes Converts a document to an array of bytes.
documentToDocumentList Expands the contents of a document into a list of documents.
Each key/value pair in the source document is transformed to a single document containing two keys (whose names you specify). These two keys will contain the key name and value of the original pair.
findDocuments Searches a set of documents for entries matching a set of Criteria.
groupDocuments Groups a set of documents based on specified criteria.
insertDocument Inserts a new document in a set of documents at a specified position.
removeNullFields Removes null fields from a given document.
searchDocuments Searches a set of documents for entries matching a set of Criteria.
sortDocuments Sorts a set of input documents based on the specified sortCriteria.

bytesToDocument

Converts an array of bytes to a document. This service can only be used with byte arrays created by executing the documentToBytes service.

Input Parameters

Output Parameters

Usage Notes

Use this service with the documentToBytes service, which converts a document into a byte array. You can pass the resulting byte array to the bytesToDocument service to convert it back into the original document.

In order for the document-to-bytes-to-document conversion to work, the entire content of the document must be serializable. Every object in the document must be of a data type known to IBM webMethods Integration, or it must support the java.io.Serializable interface.

If IBM webMethods Integration encounters an unknown object in the document that does not support the java.io.Serializable interface, that object’s value will be lost. It will be replaced with a string containing the object’s class name.

deleteDocuments

Deletes the specified documents from a set of documents.

Input Parameters

Output Parameters

Usage Notes

The deleteDocuments service returns an error if the indices parameter value is less than zero or more than the number of documents in the documents input parameter.

documentListToDocument

Constructs a document from a document list by generating key/value pairs from the values of two elements that you specify in the document list.

Input Parameters

Output Parameters

Usage Notes

The following example illustrates how the documentListToDocument service would convert a document list that contains three documents to a single document containing three key/value pairs. When you use the documentListToDocument service, you specify which two elements from the source list are to be transformed into the keys and values in the output document. In the following example, the values from the pName elements in the source list are transformed into key names, and the values from the pValue elements are transformed into the values for these keys.

A documentList containing these three documents:

Key Value
pName cx_timeout
pValue 1000
Key Value
pName cx_max
pValue 2500
Key Value
pName cx_min
pValue 10

Would be converted to a document containing these three keys:

Key Value
cx_timeout 1000
cx_max 2500
cx_min 10

documentToBytes

Converts a document to an array of bytes.

Input Parameters

Output Parameters

Usage Notes

Use the documentToBytes service with the bytesToDocument service, which converts the byte array created by this service back into the original document.

The documentToBytes service is useful when you want to write a document to a file, an input stream, or a cache.

In order for the document-to-bytes-to-document conversion to work, the entire content of the document must be serializable. Every object in the document must be of a data type known to IBM webMethods Integration, or it must support the java.io.Serializable interface. If IBM webMethods Integration encounters an unknown object in the document that does not support the java.io.Serializable interface, that object’s value will be lost. IBM webMethods Integration will replace it with a string containing the object’s class name.

documentToDocumentList

Expands the contents of a document into a list of documents.

Each key/value pair in the source document is transformed to a single document containing two keys (whose names you specify). These two keys will contain the key name and value of the original pair.

Input Parameters

Output Parameters

Usage Notes

The following example shows how a document containing three keys would be converted to a document list containing three documents. In this example, the names pName and pValue are specified as names for the two new keys in the document list.

A document containing these three keys:

Key Value
cx_timeout 1000
cx_max 2500
cx_min 10

Would be converted to a document list containing these three documents:

Key Value
pName cx_timeout
pValue 1000
Key Value
pName cx_max
pValue 2500
Key Value
pName cx_min
pValue 10

findDocuments

Searches a set of documents for entries matching a set of criteria.

Input Parameters

Output Parameters

groupDocuments

Groups a set of documents based on specified criteria.

Input Parameters

Output Parameters

Usage Notes

The following example illustrates how to specify the values for the groupCriteria parameter:

key compareStringsAs pattern
name string
age numeric
birthdate datetime yyyy-MM-dd

The input documents will be grouped based on name, age, and birth date.

insertDocument

Inserts a new document in a set of documents at a specified position.

Input Parameters

Output Parameters

removeNullFields

Removes null fields from a given document. Optionally, by specifying trimStringFields and removeEmptyStringFields, you can trim leading and trailing spaces in a string field, and after trimming the fields, if the string field length is zero, they can be removed. For array fields, it reduces the size of the array by the number of null fields. After removing all the null fields, if the size is zero, the array field is removed from the given document.

Note
Use this operation carefully as it is a destruction operation and removes the fields from the given document. For trimming string fields, a space character is defined as any character whose codepoint is less than or equal to U+0020 (the space character).

Input Parameters

Output Parameters

searchDocuments

Searches a set of documents for entries matching a set of Criteria.

Input Parameters

Output Parameters

Usage Notes

For example, if you want to search a set of documents for documents where BirthDate is 10th January 2008, the values for the searchCriteria parameter would be:

key value compareStringsAs pattern
Birthdate 2008-01-10 datetime yyyy-MM-dd

sortDocuments

Sorts a set of input documents based on the specified sortCriteria.

Input Parameters

Output Parameters

Usage Notes

For example, if you want to sort a set of documents based on name, age, and then on birth date, the values for sortCriteria parameter would be:

key order compareStringsAs pattern
Name ascending string  
Age descending numeric  
Birthdate ascending datetime yyyy-MM-dd

Flat File Services

Use Flat File services to convert data bytes, data stream, and data string to a document and vice versa.

The following Flat File services are available:

Service Description
delimitedDataBytesToDocument Converts delimited data bytes (byte array) to a document.
delimitedDataStreamToDocument Converts delimited data stream to a document.
delimitedDataStringToDocument Converts delimited data string to a document.
documentToDelimitedDataBytes Converts a document to delimited data bytes (byte array object).
documentToDelimitedDataStream Converts a document to a delimited data stream.
documentToDelimitedDataString Converts a document to a delimited data string.

delimitedDataBytesToDocument

Converts delimited data bytes (byte array) to a document.

Input Parameters

Output Parameters

delimitedDataStreamToDocument

Converts delimited data stream to a document. The permissible size of the content stream is based on your tenancy.

Input Parameters

Output Parameters

delimitedDataStringToDocument

Converts delimited data string to a document.

Input Parameters

Output Parameters

documentToDelimitedDataBytes

Converts a document to delimited data bytes (byte array object).

Input Parameters

Output Parameters

documentToDelimitedDataStream

Converts a document to a delimited data stream.

Input Parameters

Output Parameters

documentToDelimitedDataString

Converts a document to a delimited data string.

Input Parameters

Output Parameters

Flow Services

Use flow services to perform utility-type tasks.

The following flow services are available:

Service Description
clearPipeline Removes all fields from the pipeline. You may optionally specify fields that should not be cleared by this service.
countProcessedDocuments Counts the number of documents processed by a flow service. Details about the processed documents can be viewed in the Execution Results screen.
getHTTPRequest Gets information about the HTTP request, received by IBM webMethods Integration.
getLastError Obtains detailed information about the last error that was trapped within a flow service.
getLastFailureCaught Returns information about the last failure that was caught by a CATCH step.
getSessionInfo Obtains detailed information about the current logged-in user session. Also provides the current flow service name and the execution result reference identifier.
getRetryCount Retrieves the retry count and the maximum retry count for a service.
logCustomMessage Logs a message, which can be viewed in the Execution Results screen.
setCustomContextID Associates a custom value with an auditing context. You can use the custom value to search for flow service executions based on the custom ID in the IBM webMethods Integration Monitor screen.
setHTTPResponse Sets the HTTP response information to be returned by IBM webMethods Integration.
sleep Causes the currently executing flow service to pause for the specified number of seconds.
throwExceptionForRetry Throws an ISRuntimeException and instructs the to re-execute a service using the original service input.

clearPipeline

Removes all fields from the pipeline. You may optionally specify fields that should not be cleared by this service.

Input Parameters

Output Parameters

None.

countProcessedDocuments

Counts the number of documents processed by a flow service. Details about the processed documents can be viewed in the Execution Results screen.

Input Parameters

Output Parameters

None.

Usage Notes

To increment the number of documents processed by a list, use the sizeOfList service in the List service category.

getHTTPRequest

Retrieves information about the HTTP request, received by IBM webMethods Integration.

Input Parameters

None.

Output Parameters

getLastError

Obtains detailed information about the last error that was trapped within a flow service.

Input Parameters

None.

Output Parameters

Usage Notes

You can use this service in the catch section of the try-catch block. Each execution of a flow service or a service (whether the flow service or the service succeeds or fails) updates the value returned by getLastError. Consequently, getLastError itself resets the value of lastError. Therefore, if the results of getLastError will be used as input to subsequent flow services, map the value of lastError to a variable in the pipeline.

If a map has multiple transformers, then a subsequent call to getLastError will return the error associated with the last failed transformer in the map, even if it is followed by successful transformers.

getLastFailureCaught

Returns information about the last failure that was caught by a CATCH step.

Input Parameters

None.

Output Parameters

Usage Notes

If a CATCH step can handle multiple failures, use the getLastFailureCaught service to determine which failure the step caught.

You can rethrow a caught failure by using the getLastFailureCaught service to determine the failure caught by the CATCH step, then use an EXIT step that is configured to signal failure to rethrow the failure. getLastFailureCaught need not be executed within a CATCH step. The service returns the caught failure any time after it has been invoked.

getSessionInfo

Obtains detailed information about the current logged-in user session. Also provides the current flow service execution result reference identifier.

Input Parameters

None.

Output Parameters


​ - CustomContextID: String - Returns the current flow service execution context ID. You can set the context ID in a flow service by using the setCustomContextID service available under the Flow category. ​
​ - integrationName: String - The name of the flow service. If flow service A has a referenced flow service B, and if the getSessionInfo service is called in flow service B, then integrationName will be A but if flow service B is executed independently, then integrationName will be B. ​
​ - executionResultReference: String - Returns the current flow service execution result reference identifier. For example, you can pass the identifier to an on-premises operation and trace the flow service execution.

getRetryCount

Retrieves the retry count and the maximum retry count for a flow service.

The retry count indicates the number of times the IBM webMethods Integration system has re-executed a flow service. For example, a retry count of 1 indicates that the IBM webMethods Integration system tried to execute the flow service twice (the initial attempt and then one retry).

The maximum retry count indicates the maximum number of times the IBM webMethods Integration system can re-execute the flow service if it continues to fail because of a transient error.

Input Parameters

None.

Output Parameters

Usage Notes

Although the getRetryCount service can be invoked at any point in a flow service, the getRetryCount service retrieves retry information for the flow service when invoked by a subscriber. The getRetryCount service does not retrieve retry information for a nested flow service (a flow service that is invoked by another flow service).

The maximum number of times IBM webMethods Integration retries a flow service depends on the retry properties set in the subscriber that invokes the flow service.

logCustomMessage

Logs a message, which can be viewed in the Execution Results screen.

Input Parameters

Output Parameters

None.

Note
Starting from IBM webMethods Integration 11.0.10 release, new tenants are subject to the maximum size limit of 1 MB for custom log messages.

setCustomContextID

Associates a custom value with an auditing context. This custom value can be used to search for flow service executions in the Monitor screen.

Input Parameters

Output Parameters

None.

Usage Notes

setHTTPResponse

Sets the HTTP response information to be returned by IBM webMethods Integration.

Input Parameters

Output Parameters

None.

Note
When working with a flow service, always set the responseString parameter in the setHTTPResponse service as the last step. This is so because the flow service does not run in debug mode as the setHTTPResponse service stops it when the responseString parameter is set. However, the setHTTPResponse service can be used at any step in a flow service if responseString is not being set.

sleep

Causes the currently executing flow service to pause for the specified number of seconds.

Input Parameters

Output Parameters

None.

throwExceptionForRetry

Throws an exception and instructs IBM webMethods Integration to re-execute the flow service using the original service input.

Input Parameters

Output Parameters

None.

Usage Notes

Use the throwExceptionForRetry service to handle transient errors that might occur during flow service execution. A transient error is an error that arises from a condition that might be resolved quickly, such as the unavailability of a resource due to network issues or failure to connect to a database. The flow service might execute successfully if IBM webMethods Integration waits and then retries the flow service. If a transient error occurs, the flow service can catch this error and invoke throwExceptionForRetry to instruct the to retry the service.

The throwExceptionForRetry service must be used for transient errors only.

Only top-level services or subscribers can be retried. That is, a service can be retried only when it is invoked directly by a client request or by a subscriber. The service cannot be retried when it is invoked by another flow service (that is, when it is a nested flow service).

You can invoke the getRetryCount service to retrieve the current retry count and the maximum specified retry attempts.

Hashtable Services

Use Hashtable services to create, update, and obtain information about the hashtable.

The following Hashtable services are available:

Service Description
containsKey Checks for the existence of a hashtable element.
createHashtable Creates a hashtable object.
get Gets the value for a specified key in the hashtable.
listKeys Lists all the keys stored in the hashtable.
put Adds a key/value pair in the hashtable.
remove Removes a key/value pair from the hashtable.
size Gets the number of elements in the hashtable.

containsKey

Checks for the existence of a hashtable element.

Input Parameters

Output Parameters

createHashtable

Creates a hashtable object.

Input Parameters

None.

Output Parameters

get

Gets the value for a specified key in the hashtable.

Input Parameters

Output Parameters

listKeys

Lists all the keys stored in the hashtable.

Input Parameters

Output Parameters

put

Adds a key/value pair in the hashtable.

Input Parameters

Output Parameters

remove

Removes a key/value pair from the hashtable.

Input Parameters

Output Parameters

size

Gets the number of elements in the hashtable.

Input Parameters

Output Parameters

IO Services

Use IO services to convert data between byte[ ], characters, and InputStream representations. These services are used for reading and writing bytes, characters, and streamed data to the file system and behave like the corresponding methods in the java.io.InputStream class. These services can be invoked only by other services. Streams cannot be passed between clients and the server, so these services will not run if they are invoked from a client.

The following IO services are available:

Service Description
bytesToStream Converts a byte[ ] to java.io.ByteArrayInputStream.
close Closes an InputStream or a reader object and releases the resources.
createByteArray Creates a byte array of the specified length.
mark Marks the current position in the InputStream or reader object.
markSupported Enables you to test whether your InputStream or reader object supports the mark and reset operations.
read Reads a specified number of bytes from the InputStream and stores them into a buffer.
readAsString Reads the data from a reader object and converts it to a string.
reset Repositions the InputStream or the reader object to the position at the time the mark service was last invoked on the stream.
skip Skips over and discards the specified number of bytes or characters from the input stream or a reader object.
streamToBytes Creates a byte[ ] from data that is read from an InputStream.
streamToReader Converts a java.io.InputStream to a java.io.Reader object.
streamToString Creates a string from data that is read from an InputStream.
stringToReader Converts a string object to a String Reader object.
stringToStream Converts a string to a binary stream.

bytesToStream

Converts a byte[ ] to java.io.ByteArrayInputStream.

Input Parameters

Output Parameters

Usage Notes

This service constructs stream from the byte array using the constructor ByteArrayInputStream(byte[ ]). This constructor does not make a copy of the byte array, so any changes to bytes will be reflected in the data read from the stream.

close

Closes an InputStream or a reader object and releases the resources.

Input Parameters

Note
You can use either inputStream or reader to specify the input object. If both the input parameters are provided, then both the objects will be closed.

Output Parameters

None.

Usage Notes

If the InputStream is already closed, invoking this service has no effect. However, leaving an InputStream open may cause errors that may not be recoverable. Use the close service to explicitly close the input stream when a service leaves it open.

createByteArray

Creates a byte array of the specified length.

Input Parameters

Output Parameters

Usage Notes

The read service reads data from an InputStream into a byte array. You can use this service to create the byte array. Invoking this service is the equivalent of the Java code new byte[length].

mark

Marks the current position in the InputStream or reader object. A subsequent call to reset repositions this stream at the last marked position. Marking and respositioning the input stream allows subsequent service calls to re-read the same bytes.

Input Parameters

Note
You can use either stream or reader to specify the input object. If both stream and reader input parameters are provided, then both the objects will be marked.

Output Parameters

Usage Notes

If the InputStream does not support the mark operation, invoking this service has no effect.

Either of the optional input parameters, stream or reader, is required.

markSupported

Enables you to test whether your InputStream or reader object supports the mark and reset operations.

Input Parameters

Output Parameters

Usage Notes

Either of the input parameters, stream or reader, is required.

read

Reads a specified number of bytes from the InputStream and stores them into a buffer.

Input Parameters

Output Parameters

readAsString

Reads the data from a reader object and returns the contents as a string.

Input Parameters

Output Parameters

Usage Notes

The readAsString service does not automatically close the reader object. To close the reader, use the close service.

readerToString

Reads the data from a reader object and converts it to a string.

Input Parameters

Output Parameters

Usage Notes

The readerToString service does not automatically close the reader object. To close the reader, use the close service.

reset

Repositions the InputStream or the reader object to the position at the time the mark service was last invoked on the stream.

Input Parameters

Output Parameters

Usage Notes

If the InputStream does not support the reset operation, invoking this service has no effect.

Either of the input parameters, stream or reader, is required.

skip

Skips over and discards the specified number of bytes or characters from the input stream or a reader object.

Input Parameters

Note
You can use either stream or reader to specify the input object. If both stream and reader input parameters are provided, then the stream and reader object data will be skipped.

Output Parameters

Usage Notes

The Skip service uses the Java methodskip, which might skip some smaller number of bytes, possibly zero (0). This happens due to conditions such as reaching the end of file before n bytes have been skipped. For more information about the skip method, see the Java documentation on the InputStream class.

Either of the optional input parameters, stream or reader, is required.

If both stream and reader input parameters are specified and if an exception occurs during the stream object usage, then the operations are not performed on the reader object also.

streamToBytes

Creates a byte[ ] from data that is read from an InputStream.

Input Parameters

Output Parameters

Usage Notes

This service reads all of the bytes from stream until the end of file is reached, and then it closes the InputStream.

streamToReader

Converts a java.io.InputStream to a java.io.Reader object.

Input Parameters

Output Parameters

streamToString

Creates a string from data that is read from an InputStream.

Input Parameters

Output Parameters

stringToReader

Converts a string object to a StringReader object.

Input Parameters

Output Parameters

stringToStream

Converts a string to a binary stream.

Input Parameters

Output Parameters

JSON Services

Use JSON services to convert JSON content into a document and to convert a document into JSON content.

The following JSON services are available:

Service Description
closeArrayIterator Closes the iteration. The iterator object used in an iteration cannot be reused after this service runs.
documentToJSONBytes Converts a document to JSON bytes (byte array).
documentToJSONStream Converts a document to a JSON stream.
documentToJSONString Converts a document to a JSON string.
getArrayIterator Returns a batch iterator object.
getNextBatch Gets the next batch of array elements by parsing the array paths in the iterator object returned by the getArrayIterator service.
jsonBytesToDocument Converts JSON content in bytes (byte array) to a document.
jsonStreamToDocument Converts content from the JSON content stream to a document.
jsonStringToDocument Converts content from the JSON string to a document.

closeArrayIterator

Closes the iteration. The iterator object used in an iteration cannot be reused after this service runs.

Input Parameters

Output Parameters

None.

documentToJSONBytes

Converts a document to JSON bytes (byte array).

Input Parameters

Output Parameters

documentToJSONStream

Converts a document to a JSON stream.

Input Parameters

Output Parameters

documentToJSONString

Converts a document to a JSON string.

Input Parameters

Output Parameters

getArrayIterator

Returns a batch iterator object.

Input Parameters




"topping": [{ 
            "toppingA": [{ 
                    "toppingA1": ["None71", "Glazed82"] 
... 
                }]}]
                
Note
This parameter must have only array paths. You must not enter individual array elements or other fields.
Array paths must follow the JSON pointer syntax.

Output Parameters

Usage Notes

None.

getNextBatch

Gets the next batch of array elements by parsing the array paths in the iterator object returned by the getArrayIterator service. This service returns the array elements in batches based on the batch size provided in the input. The batch size can vary across invocations of this service. A batch is a set of elements that can be retrieved from an array path at once, based on the batch size. To retrieve the remaining elements in the array path or elements from the next array path in the iterator, invoke the service in a loop until there are no more array paths to iterate.

Input Parameters

Output Parameters

Usage Notes

The getNextBatch service completes the retrieval of elements from one array in the iterator and starts retrieving from the next array that matches in the subsequent iteration. This is explained in the following example:

Suppose you want the service to parse a JSON file with 2 arrays, for example, A and B with 6 and 2 elements each. Set the batchSize input parameter to 5 and invoke the service in a loop until the service returns the hasNext parameter as false. In the first batch of the output, the first 5 elements of the array A are returned and in the next batch, only the last element of the array A is returned, even though the batch size is 5. At this point, the hasNext parameter is true because array B is not parsed yet. In the next batch, the service returns both the elements of array B. Since there are no more elements left either in the array A or B, the hasNext parameter becomes false.

Guidelines

jsonBytesToDocument

Converts JSON content in bytes (byte array) to a document.

Input Parameters

Output Parameters

jsonStreamToDocument

Converts content from the JSON content stream to a document. The permissible size of the content stream is based on your tenancy.

Input Parameters

Output Parameters

jsonStringToDocument

Converts content from the JSON content string to a document.

Input Parameters

Output Parameters

List Services

Use List services to retrieve, replace, or add elements in an Object List, Document List, or String List, including converting String Lists to Document Lists.

The following List services are available:

Service Description
addItemToVector Adds an item or a list of items to a java.util.Vector object.
appendToDocumentList Adds documents to a document list.
appendToStringList Adds Strings to a String list.
sizeOfList Returns the number of elements in a list.
stringListToDocumentList Converts a String list to a document list.
vectorToArray Converts a java.util.Vector object to an array.

addItemToVector

Adds an item or a list of items to a java.util.Vector object.

Input Parameters

Note
You can use either item or itemList to specify the input object. If both item and itemList input parameters are specified, the item as well as the list of items will be added to the vector object.

Output Parameters

Usage Notes

Either of the optional input parameters, item or itemList, is required.

appendToDocumentList

Adds documents to a document list.

Input Parameters

Output Parameters

Usage Notes

The documents contained in fromList and fromItem are not actually appended as entries to toList. Instead, references to the documents in fromList and fromItem are appended as entries to toList. Consequently, any changes made to the documents in fromList and fromItem also affect the resulting toList.

appendToStringList

Adds Strings to a String list.

Input Parameters

Output Parameters

Usage Notes

The Strings contained in fromList and fromItem are not actually appended as entries to toList. Instead, references to the Strings in fromList and fromItem are appended as entries to toList. Consequently, any changes made to the Strings in fromList and fromItem also affect the resulting toList.

sizeOfList

Returns the number of elements in a list.

Input Parameters

Output Parameters

Usage Notes

For example, if fromList consists of:

The result would be:

stringListToDocumentList

Converts a String list to a document list.

Input Parameters

Output Parameters

Usage Notes

Creates a document list containing one document for each element in the fromList. Each document will contain a single String element named key.

vectorToArray

Converts a java.util.Vector object to an array.

Input Parameters

Output Parameters

Math Services

Use Math services to perform mathematical operations on string-based numeric values. Services that operate on integer values use Java’s long data type (64-bit, two’s complement). Services that operate on float values use Java’s double data type (64-bit IEEE 754). If extremely precise calculations are critical to your application, you should write your own Java services to perform math functions.

The following Math services are available:

Service Description
absoluteValue Returns the absolute value of the input number.
addFloatList Adds a list of floating point numbers (represented in a string list) and returns the sum.
addFloats Adds one floating point number (represented as a String) to another and returns the sum.
addIntList Adds a list of integers (represented in a String list) and returns the sum.
addInts Adds one integer (represented as a String) to another and returns the sum.
addObjects Adds one java.lang.Number object to another and returns the sum.
divideFloats Divides one floating point number (represented as a String) by another (num1/num2) and returns the quotient.
divideInts Divides one integer (represented as a String) by another (num1/num2) and returns the quotient.
divideObjects Divides one java.lang.Number object by another (num1/num2) and returns the quotient.
max Returns the largest number from a list of numbers.
min Returns the smallest number from a list of numbers.
multiplyFloatList Multiplies a list of floating point numbers (represented in a String list) and returns the product.
multiplyFloats Multiples one floating point number (represented as String) by another and returns the product.
multiplyIntList Multiplies a list of integers (represented in a String list) and returns the product.
multiplyInts Multiplies one integer (represented as a String) by another and returns the product.
multiplyObjects Multiplies one java.lang.Number object by another and returns the product.
randomDouble Returns the next pseudorandom, uniformly distributed double between 0.0 and 1.0.
roundNumber Returns a rounded number.
subtractFloats Subtracts one floating point number (represented as a String) from another and returns the difference.
subtractInts Subtracts one integer (represented as a String) from another and returns the difference.
subtractObjects Subtracts one java.lang.Number object from another and returns the difference.
toNumber Converts a string to numeric data type.

absoluteValue

Returns the absolute value of the input number.

Input Parameters

Output Parameters

addFloatList

Adds a list of floating point numbers (represented in a string list) and returns the sum.

Input Parameters

Output Parameters

Usage Notes

Make sure the strings that are passed to the service in numList are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

addFloats

Adds one floating point number (represented as a String) to another and returns the sum.

Input Parameters

Output Parameters

Usage Notes

Make sure the strings that are passed to the service in num1andnum2 are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

addIntList

Adds a list of integers (represented in a String list) and returns the sum.

Input Parameters

Output Parameters

Usage Notes

Make sure the strings that are passed to the service in numList are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

addInts

Adds one integer (represented as a String) to another and returns the sum.

Input Parameters

Output Parameters

Usage Notes

Ensure that the result of your calculation is less than 64 bits in width (the maximum width for the long data type). If the result exceeds this limit, it will generate a data overflow.

Ensure that the strings that are passed to the service in num1andnum2 are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

addObjects

Adds one java.lang.Number object to another and returns the sum.

Input Parameters

Output Parameters

Usage Notes

This service accepts the following sub-classes of java.lang.Number: java.lang.Byte, java.lang.Double, java.lang.Float, java.lang.Integer, java.lang.Long, java.lang.Short.

This service applies the following rules for binary numeric promotion to the operands in order:

These promotion rules mirror the Java rules for numeric promotion of numeric types.

divideFloats

Divides one floating point number (represented as a String) by another (num1/num2) and returns the quotient.

Input Parameters

Output Parameters

Usage Notes

Make sure the strings that are passed to the service in num1andnum2 are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

divideInts

Divides one integer (represented as a String) by another (num1/num2) and returns the quotient.

Input Parameters

Output Parameters

Usage Notes

Make sure the strings that are passed to the service in num1andnum2 are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

divideObjects

Divides one java.lang.Number object by another (num1/num2) and returns the quotient.

Input Parameters

Output Parameters

Usage Notes

This service accepts the following sub-classes of java.lang.Number: java.lang.Byte, java.lang.Double, java.lang.Float, java.lang.Integer, java.lang.Long, java.lang.Short.

This service applies the following rules for binary numeric promotion to the operands in order:

These promotion rules mirror the Java rules for numeric promotion of numeric types.

max

Returns the largest number from a list of numbers.

Input Parameters

Output Parameters

min

Returns the smallest number from a list of numbers.

Input Parameters

Output Parameters

multiplyFloatList

Multiplies a list of floating point numbers (represented in a String list) and returns the product.

Input Parameters

Output Parameters

Usage Notes

Make sure the strings that are passed to the service in numList are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

multiplyFloats

Multiples one floating point number (represented as String) by another and returns the product.

Input Parameters

Output Parameters

Usage Notes

Make sure the strings that are passed to the service in num1andnum2 are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

multiplyIntList

Multiplies a list of integers (represented in a String list) and returns the product.

Input Parameters

Output Parameters

Usage Notes

Make sure the result of your calculation is less than 64 bits in width (the maximum width for the long data type). If the result exceeds this limit, it will generate a data overflow.

Make sure the strings that are passed to the service in numList are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

multiplyInts

Multiplies one integer (represented as a String) by another and returns the product.

Input Parameters

Output Parameters

Usage Notes

Make sure the result of your calculation is less than 64 bits in width (the maximum width for the long data type). If the result exceeds this limit, it will generate a data overflow.

Make sure the strings that are passed to the service in num1andnum2 are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

multiplyObjects

Multiplies one java.lang.Number object by another and returns the product.

Input Parameters

Output Parameters

Usage Notes

This service accepts the following sub-classes of java.lang.Number: java.lang.Byte, java.lang.Double, java.lang.Float, java.lang.Integer, java.lang.Long, java.lang.Short.

This service applies the following rules for binary numeric promotion to the operands in order:

These promotion rules mirror the Java rules for numeric promotion of numeric types.

randomDouble

Returns the next pseudorandom, uniformly distributed double between 0.0 and 1.0.

Random number generators are often referred to as pseudorandom number generators because the numbers produced tend to repeat themselves over time.

Input Parameters

Output Parameters

roundNumber

Returns a rounded number.

Input Parameters

Output Parameters

subtractFloats

Subtracts one floating point number (represented as a String) from another and returns the difference.

Input Parameters

Output Parameters

Usage Notes

Make sure the strings that are passed to the service in num1andnum2 are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

subtractInts

Subtracts one integer (represented as a String) from another and returns the difference.

Input Parameters

Output Parameters

Usage Notes

Make sure the result of your calculation is less than 64 bits in width (the maximum width for the long data type). If the result exceeds this limit, it will generate a data overflow.

Make sure the strings that are passed to the service in num1 andnum2 are in a locale-neutral format (that is, using the pattern -####.##). Passing locally formatted strings may result in unexpected results. For example, calling addFloats in a German locale with the arguments 1,23 and 2,34 will result in the value 357, not 3.57 or 3,57.

subtractObjects

Subtracts one java.lang.Number object from another and returns the difference.

Input Parameters

Output Parameters

Usage Notes

This service accepts the following sub-classes of java.lang.Number: java.lang.Byte, java.lang.Double, java.lang.Float, java.lang.Integer, java.lang.Long, java.lang.Short.

This service applies the following rules for binary numeric promotion to the operands. The following rules are applied in order:

These promotion rules mirror the Java rules for numeric promotion of numeric types.

toNumber

Converts a string to numeric data type.

Input Parameters

Output Parameters

MIME Services

Use MIME services to create MIME messages and extract information from MIME messages.

The following MIME services are available:

Service Function
addBodyPart Adds a body part (header fields and content) to a specified MIME object.
addMimeHeader Adds one or more header fields to a specified MIME object.
createMimeData Creates a MIME object.
getBodyPartContent Retrieves the content (payload) from the specified MIME object.
getBodyPartHeader Returns the list of header fields for the specified body part.
getContentType Returns the value of the Content-Type message header from the specified MIME object.
getEnvelopeStream Generates an InputStream representation of a MIME message from a specified MIME object.
getMimeHeader Returns the list of message headers from a specified MIME object.
getNumParts Returns the number of body parts in the specified MIME object.
getPrimaryContentType Returns the top-level portion of a MIME object’s Content-Type value.
getSubContentType Returns the sub-type portion of a MIME object’s Content-Type value.
mergeHeaderAndBody Concatenates the contents of the header and body mapped to the input.
releaseBodyPartReferenceInTSpace Release a body part from the Tspace.

addBodyPart

Adds a body part (header fields and content) to a specified MIME object.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

The way in which the contenttype and encoding parameters are applied depends on whether the finished message is single-part or multipart.

For single-part messages:

For multipart messages:

addMimeHeader

Adds one or more header fields to a specified MIME object.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

If you add MIME headers before you add multiple body parts, the header fields will be added to each of the body parts. If you do not want this behavior, either drop mimeHeader from the pipeline immediately after you execute addMimeHeader, or invoke addMimeHeader after you’ve added all body parts to the MIME object.

Be aware that the contenttype and encoding parameters used by the addBodyPart service will override any Content-Type or Content-Transfer-Encoding settings in mimeData. Moreover, in certain cases, the getEnvelopeStream will override these settings when it generates a multipart message. For information about how the Content-Type or Content-Transfer-Encoding headers are derived at run time, see the Usage Notes under addBodyPart.

createMimeData

Creates a MIME object.

If no input parameter is passed to this service, the service creates an empty MIME object. Otherwise, the service creates a MIME object containing the elements (header fields and content) from the MIME message in input.

Input Parameters

Output Parameters

Usage Notes

All of the other MIME services operate on the mimeData IData object produced by this service. They do not operate directly on MIME message streams.

Important
You can examine the contents of mimeData during testing and debugging. However, because the internal structure of mimeData is subject to change without notice, do not explicitly set or map data to/from these elements in your service. To manipulate or access the contents of mimeData, use only the MIME services that is provided.

getBodyPartContent

Retrieves the content (payload) from the specified MIME object.

You use this service for both single-part and multi-part messages.

To retrieve content from a multi-part message, you set the index (to select the part by index number) or contentID (to select the part by contentID value) parameter to specify the body part whose content you want to retrieve. To get the content from a single-part message, you omit the index and contentID parameters or set index to 0.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

If you omit index or contentID when retrieving content from a multi-part message, getBodyPartContent returns the payload from the first body part. If you use index or contentID to select a body part that does not exist in mimeData, content will be null.

getBodyPartHeader

Returns the list of header fields for the specified body part.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

If you omit index or contentID, getBodyPartHeader returns the message headers from the first body part. If you use index or contentID to select a body part that does not exist in mimeData, content will be null.

getContentType

Returns the value of the Content-Type message header from the specified MIME object.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

getEnvelopeStream

Generates an InputStream representation of a MIME message from a specified MIME object.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

If you omit index or contentID, getEnvelopeStream generates the MIME message from the entire contents of the mimeData. If you use index or contentID to select a body part that does not exist in mimeData, content will be null.

getEnvelopeStream automatically inserts the MIME-Version and Message-ID message headers into the MIME message it puts into envStream.

getMimeHeader

Returns the list of message headers from a specified MIME object.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

getNumParts

Returns the number of body parts in the specified MIME object.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

getPrimaryContentType

Returns the top-level portion of a MIME object’s Content-Type value.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

getSubContentType

Returns the sub-type portion of a MIME object’s Content-Type value.

Input Parameters

Output Parameters

Usage Notes

This service operates on the MIME object (mimeData) produced by createMimeData.

mergeHeaderAndBody

Concatenates the contents of the header and body mapped to the input.

You can use this service to reassemble the message into its original form so that it can be used as input to the createMimeData service (or any other service that requires the entire http response as an InputStream).

Input Parameters

Output Parameters

Usage Notes

Use this service to merge the Headers and Body to get the original MIME message.

releaseBodyPartReferenceInTSpace

This service enables you to free up space in the Tspace by releasing body parts stored in it by the pub.mime:addBodyPart service. You need to provide a reference to the body part to be released.

Input Parameters

mimeData: Document. MIME object whose reference you want to release from the Tspace. (This IData object is produced by pub.mime:createMimeData.)

index: String. Optional. Index number of the body part whose content you want to release (if you want to release the content from a specific body part). The first body part is index number zero. Note: If contentID is specified, index is ignored.

contentID: String. Optional. Value of the Content-ID header field of the body part that you want to release (if you want to release the payload from a specific body part).

Output Parameters

releasedReferenceInTSpace: Boolean. Returns true if the reference was released and false if not.

Usage Notes

Before invoking this service, ensure that the body part has a reference in the Tspace.

Schema Services

Use Schema services to validate objects and to validate the pipeline.

The following Schema services are available:

Service Description
validate Validates an object using an IS document type or a schema.
validatePipeline Validates the pipeline against a document type.

validate

Validates an object using an IS document type, XML document type, or an IS schema. .

Input Parameters

Output Parameters

Usage Notes

validatePipeline

Validates the pipeline against a document type.

Input Parameters

Output Parameters

Storage Services

Use Storage services to insert, retrieve, update, and remove entries from a data store.

When using the storage services, keep in mind that the short-term store is not intended to be used as a general-purpose storage engine. Rather, it is primarily provided to support shared storage of application resources and transient data in IBM webMethods Integration. It is recommended not to use the short-term store to process high volumes, large data records, or to permanently archive records.

Note
User specific data which may be considered as personal data will be stored and retained till the retention period defined in Execution Results.

These services are a tool for maintaining state information in the short-term store. It is up to the developer of the flow service to make sure that the flow service keeps track of its state and correctly handles restarts.

Locking Considerations

The following sections describe in general how the storage services handle locking requests.

Entry Locking

To maintain data integrity, the short-term store uses locking to ensure that multiple threads do not modify the same entry at the same time. For insertions and removals, the short-term store sets and releases the lock. For updates, the client must set and release the lock. Using locking improperly, that is, creating a lock but not releasing it, can cause deadlocks in the short-term store.

The following guidelines can help you avoid short-term store deadlocks:

Data Store Locking

When a storage service locks an entry, the service also implicitly locks the data store in which the entry resides. This behavior prevents another thread from deleting the entire data store and the entries it contains while your thread is working with the entry. When the locked entry is unlocked, the implicit lock on the data store is also released.

Be careful when explicitly unlocking data stores. Consider the following example:

  1. User_A locks an item. This creates two locks: an explicit lock on the entry, and an implicit lock on the data store.

  2. User_A later unlocks the data store explicitly while still holding the lock on the entry.

  3. User_B locks, then deletes the data store, including the entry locked by User_A in the first step.

When User_A explicitly unlocked the data store in step 2, User_B was able to delete the entry the User_A was working with.

Automatic Promotion to Exclusive Lock

If a storage service tries to acquire an exclusive lock on an object, but finds a shared lock from the same thread already in place on the object, the service will try to promote the lock to an exclusive lock.

If a storage service that requires an exclusive lock encounters a shared or exclusive lock held by another thread, it will wait until the object becomes available. If the object remains locked for the period specified by the waitlength parameter passed by the service, the service will fail.

Sample Flow service for Checkpoint Restart

The following diagram shows how to create checkpoint restarts into your flow services. It explains the logic of a flow service and shows where the various storage services are used to achieve checkpoint restarts.

The following Storage services are available:

Service Description
add Inserts a new entry into a data store.
deleteStore Deletes a data store and all its contents. Any data in the data store is deleted. If the data store does not exist, the service takes no action.
get Retrieves a value from a data store and locks the entry and the data store on behalf of the thread that invoked the service.
keys Obtains a list of all the keys in a data store.
lock Locks an entry and/or data store on behalf of the thread invoking this service.
put Inserts or updates an entry in a data store. If the key does not exist in the data store, the entry is inserted.
remove Removes an entry from a data store.
unlock Unlocks an entry or a data store.

add

Inserts a new entry into a data store.

If the key already exists in the data store, the service does nothing.

Input Parameters

Output Parameters

deleteStore

Deletes a data store and all its contents. Any data in the data store is deleted. If the data store does not exist, the service takes no action.

Input Parameters

Output Parameters

Usage Notes

This service obtains an exclusive lock on the data store, but no locks on the individual entries in the data store. If this service finds a shared lock from the same thread on the data store, the service will automatically promote the lock to an exclusive lock. The exclusive lock prevents other threads from acquiring locks on the data store or entries within the data store during the delete operation.

get

Retrieves a value from a data store and locks the entry and the data store on behalf of the thread that invoked the service.

Important
This service does not automatically release the lock on the data store or entry after performing the get operation, so you need to ensure that the lock is released by calling the put or unlock services. If you do not release the lock, IBM webMethods Integration will release the lock at the end of the flow service execution.

Input Parameters

Output Parameters

Usage Notes

keys

Obtains a list of all the keys in a data store.

Input Parameters

Output Parameters

lock

Locks an entry and/or data store on behalf of the thread invoking this service.

Important
When you lock an entry or data store using this service, you must release the lock by using a put or an explicit unlock. If you do not release the lock, IBM webMethods Integration will release the lock at the end of the flow service execution. Further, be careful when releasing locks with the unlock service. If you release a lock on a data store, another thread can obtain a lock on the data store and delete it, and the entries it contains, even if your thread still has locks on one or more of the entries.

Input Parameters

Output Parameters

None.

Usage Notes

put

Inserts or updates an entry in a data store. If the key does not exist in the data store, the entry is inserted.

If the requested entry is not currently locked by the thread that invoked this service, the put service will automatically attempt to lock the entry for the duration of the put operation.

The service obtains an exclusive lock on the entry and a shared lock on the data store. If the service finds a shared lock from the same thread on the entry, the service will automatically promote the shared lock to an exclusive lock.

This service releases the lock when the put operation has completed.

Input Parameters

Output Parameters

Usage Notes

When storing and retrieving the flow state in the short-term store for checkpoint restart purposes, ensure that the value of key is unique to the transaction.

remove

Removes an entry from a data store. This service obtains an exclusive lock on the entry and a shared lock on the data store.

Input Parameters

Output Parameters

unlock

Unlocks an entry or a data store.

When a flow service retrieves an entry using the get service, the entry is locked to prevent modification by other users before the flow service completes. The entry remains locked until the lock owner invokes a put service. To unlock a service without using the put service, use the unlock service.

In addition, if a flow service uses the lock service to lock an entry or data store, you must use the unlock or put service to release the lock.

Important
Be careful when releasing locks with this service. If you release a lock on a data store, another thread can obtain a lock on the data store and delete it, and the entries it contains, even if the original thread still has locks on one or more of the entries.

Input Parameters

Output Parameters

None.

String Services

Use String services to perform string manipulation and substitution operations.

The following String services are available:

Service Description
base64Decode Decodes a Base-64 encoded string into a sequence of bytes.
base64Encode Converts a sequence of bytes into a Base64-encoded String.
bytesToString Converts a sequence of bytes to a String.
compareStrings Performs a case-sensitive comparison of two strings, and indicates whether the strings are identical.
concat Concatenates two strings.
fuzzyMatch A given string is not exactly matched against a set of strings. If the match is above similarityThreshold, it returns the matchedValue. If more than one string has not exactly matched, then the first matched string is returned.
HTMLDecode Replaces HTML character entities with native characters.
HTMLEncode Replaces HTML-sensitive characters with equivalent HTML character entities.
indexOf Returns the index of the first occurrence of a sequence of characters in a string.
isAlphanumeric Determines whether a string consists entirely of alphanumeric characters (in the ranges A–Z, a–z, or 0–9).
isDate Determines whether a string follows a specified date pattern.
isNullEmptyOrWhitespace Determines if a string is null, empty, or only whitespace.
isNullOrBlank Checks a string for a null or a blank value.
isNumber Determines whether the contents of a string can be converted to a float value.
length Returns the length of a string.
lookupDictionary Looks up a given key in a hash table and returns the string to which that key is mapped.
lookupTable Locates a key in a String Table and returns the string to which that key is mapped.
makeString Builds a single string by concatenating the elements of a String List.
messageFormat Formats an array of strings into a given message pattern.
numericFormat Formats a number into a given numeric pattern.
objectToString Converts an object to string representation using the Java toString() method of the object.
padLeft Pads a string to a specified length by adding pad characters to the beginning of the string.
padRight Pads a string to a specified length by adding pad characters to the end of the string.
replace Replaces all occurrences of a specified substring with a substitute string.
stringToBytes Converts a string to a byte array.
substitutePipelineVariables Replaces a pipeline variable with its corresponding value.
substring Returns a substring of a given string.
tokenize Tokenizes a string using specified delimiter characters and generates a String List from the resulting tokens.
toLower Converts all characters in a given string to lowercase.
toUpper Converts all characters in a given string to uppercase.
trim Trims leading and trailing white space from a given string.
URLDecode Decodes a URL-encoded string.
URLEncode URL-encodes a string.

base64Decode

Decodes a Base-64 encoded string into a sequence of bytes.

Input Parameters

Output Parameters

base64Encode

Converts a sequence of bytes into a Base64-encoded String.

Input Parameters

Output Parameters

Usage Notes

By default, the base64Encode service inserts line breaks after 76 characters of data, which is not the canonical lexical form expected by implementations such as MTOM. You can use the useNewLine parameter to remove the line breaks.

bytesToString

Converts a sequence of bytes to a String.

Input Parameters

Output Parameters

compareStrings

Performs a case-sensitive comparison of two strings and indicates whether the strings are identical.

Input Parameters

Output Parameters

concat

Concatenates two strings.

Input Parameters

Output Parameters

fuzzyMatch

A given string is not exactly matched against a set of strings. If the match is above similarityThreshold, it returns the matchedValue. If more than one string has not exactly matched, then the first matched string is returned.

Input Parameters

Output Parameters

Usage Notes

Search the web for more information about Levenshtein and JaroWinkler algorithms.

HTMLDecode

Replaces HTML character entities with native characters.

Specifically, this service:

Replaces this HTML character entity… With…
&gt; >
&lt; <
&amp; &
&quot; "

Input Parameters

Output Parameters

HTMLEncode

Replaces HTML-sensitive characters with equivalent HTML character entities.

Specifically, this service:

Replaces this native language character… With…
> &gt;
< &lt;
& &amp;
" &quot;
&#39

These translations are useful when displaying text in an HTML context.

Input Parameters

Output Parameters

indexOf

Returns the index of the first occurrence of a sequence of characters in a string.

Input Parameters

Output Parameters

isAlphanumeric

Determines whether a string consists entirely of alphanumeric characters (in the ranges A–Z, a–z, or 0–9).

Input Parameters

Output Parameters

The service returns false if inString is not specified.

isDate

Determines whether a string follows a specified date pattern.

Input Parameters

Output Parameters

The service returns false if inString is not specified.

Usage Notes

The service returns an error if both inString and pattern are not specified.

You can specify any random string (for example, 111212) as both inString and pattern. The service returns true if the same user-defined string is specified as both inString and pattern. This is because the java.text.SimpleDateFormat class parses the user-defined input string and pattern to a valid date when the particular input values are identical.

isNullEmptyOrWhitespace

Determines if a string is null, empty, or only whitespace.

Input Parameters

Output Parameters

Examples

Service with inString = “ \t\n\r\n” and ifPresent = true, returns true

Service with inString=” \t\n\r\n” and ifPresent = false, returns true

Service with inString = “abcd” and ifPresent = true, returns false

Service with inString = “abcd” and ifPresent = false, returns false

Service with ifPresent = true, returns true

Service with ifPresent = false, throws an exception.

Usage Notes

string:isNullEmptyOrWhitespace replaces string:isNullOrBlank which is deprecated.

isNullOrBlank

Checks a string for a null or a blank value.

Input Parameters

Output Parameters

isNumber

Determines whether the contents of a string can be converted to a float value.

Input Parameters

Output Parameters

The service returns false if inString is not specified.

length

Returns the length of a string.

Input Parameters

Output Parameters

lookupDictionary

Looks up a given key in a hash table and returns the string to which that key is mapped.

Input Parameters

Output Parameters

lookupTable

Locates a key in a String Table and returns the string to which that key is mapped.

Input Parameters

Output Parameters

makeString

Builds a single string by concatenating the elements of a String List.

Input Parameters

Output Parameters

messageFormat

Formats an array of strings into a given message pattern.

Input Parameters

Output Parameters

numericFormat

Formats a number into a given numeric pattern.

Input Parameters

Output Parameters

objectToString

Converts an object to string representation using the Java toString() method of the object.

Input Parameters

Output Parameters

padLeft

Pads a string to a specified length by adding pad characters to the beginning of the string.

Input Parameters

Output Parameters

Usage Notes

If padString is longer than one character and does not fit exactly into the resulting string, the beginning of padString is aligned with the beginning of the resulting string. For example, suppose inString equals shipped and padString equals x9y.

If length equals… Then value will contain…
7 shipped
10 x9yshipped
12 x9x9yshipped

If inString is longer than length characters, only the last length characters from inString are returned. For example, if inString equals acct1234 and length equals 4, value will contain 1234.

padRight

Pads a string to a specified length by adding pad characters to the end of the string.

Input Parameters

Output Parameters

Usage Notes

If padString is longer than one character and does not fit exactly into the resulting string, the end of padString is aligned with the end of the resulting string. For example, suppose inString equals shipped and padString equals x9y.

If length equals… Then value will contain…
7 shipped
10 shippedx9y
12 shippedx9y9y

If inString is longer than length characters, only the first length characters from inString are returned. For example, if inString equals 1234acct and length equals 4, value will contain 1234.

replace

Replaces all occurrences of a specified substring with a substitute string.

Input Parameters

Output Parameters

stringToBytes

Converts a string to a byte array.

Input Parameters

Output Parameters

substitutePipelineVariables

Replaces a pipeline variable with its corresponding value.

Input Parameters

Output Parameters

Usage Notes

The service returns an error if inString is not specified.

If inString does not contain any variable between the % symbols, or contains a value other than the pipeline variable between the % symbols, the service does not perform any variable substitution from the pipeline.

If you want to include the % symbol in the output, you can specify it as \% in inString. To specify the value of the pipeline variable as a percentage in the output, append \% after the variable name in inString. For example, suppose a pipeline variable revenueIncreasePercent has a value of 100.

If inString equals… Then value will contain…
%revenueIncreasePercent%\% 100%

The service cannot be used for substitution of global variables.

substring

Returns a substring of a given string.

Input Parameters

Output Parameters

tokenize

Tokenizes a string using specified delimiter characters and generates a String List from the resulting tokens.

This service does not return delimiters as tokens.

Input Parameters

Output Parameters

toLower

Converts all characters in a given string to lowercase.

Input Parameters

Output Parameters

toUpper

Converts all characters in a given string to uppercase.

Input Parameters

Output Parameters

trim

Trims leading and trailing white space from a given string.

Input Parameters

Output Parameters

URLDecode

Decodes a URL-encoded string.

Input Parameters

Output Parameters

URLEncode

URL-encodes a string.

Encodes characters the same way that data posted from a WWW form is encoded, that is, the application/x-www-form-urlencoded MIME type.

Input Parameters

Output Parameters

Transaction Services

Use Transaction services only in conjunction with Database Connector operations. These services are applicable when the Database Connector account is of type Transactional.

The following Transaction services are available:

Service Description
commit Commits an explicit transaction.
rollback Rolls back an explicit transaction.
setTimeout Manually sets a transaction timeout interval for implicit and explicit transactions.
start Starts an explicit transaction.

commit

Commits an explicit transaction.

Input Parameters

Output Parameters

None.

Usage Notes

This service must be used in conjunction with the Transaction:start service. If the transactionName parameter was not provided in a prior call to Transaction:start, a run-time error will be returned.

rollback

Rolls back an explicit transaction.

Input Parameters

Output Parameters

None.

Usage Notes

This service must be used in conjunction with the Transaction:start service. If the given transactionName parameter was not provided in a prior call to Transaction:start, a run-time error will be returned.

setTimeout

Manually sets a transaction timeout interval for implicit and explicit transactions.

Input Parameters

Output Parameters

None.

Usage Notes

You must call this service before you call the Transaction:start service. If the execution of a transaction takes longer than the transaction timeout interval, all transacted operations are rolled back.

start

Starts an explicit transaction.

Input Parameters

Output Parameters

Usage Notes

This service is intended for use with the Transaction:commit or Transaction:rollback service. The transactionName value returned by a call to this service can be provided to Transaction:commit (to commit the transaction) or Transaction:rollback (to roll back the transaction).

Utils Services

Contains utility services.

The following Utils services are available:

Service Description
generateUUID Generates a random Universally Unique Identifier (UUID).
createMessageDigest Generates a message digest for a given message.
deepClone Clones an object using the default Java serialization mechanism.
transcode Transcodes data from one encoding to another.

generateUUID

Generates a random Universally Unique Identifier (UUID).

Input Parameters

None

Output Parameters

createMessageDigest

Generates a message digest for a given message.

Input Parameters

Output Parameters

deepClone

Clones an object using the default Java serialization mechanism.

Input Parameters

Output Parameters

transcode

Transcodes data from one encoding to another.

Input Parameters

Specify one of the following:

Output Parameters

Key Description
string String. Conditional. Transcoded contents of inputData as a String. The utils:transcode service string returns this output parameter if the input data was supplied in inputData/string or outputAs was set to string.
bytes byte[ ]. Conditional. Transcoded contents of inputData as a byte[]. The utils:transcode service bytes returns this output parameter if the input data was supplied in inputData/bytes or outputAs was set to bytes.

XML Services

Use XML services to convert a document to XML content and XML content to a document.

The following XML services are available:

Service Description
documentToXMLBytes Converts a document to XML content bytes, as a byte array object.
documentToXMLStream Converts a document to XML stream, as a java.io.InputStream object.
documentToXMLString Converts a document to XML content string.
getXMLNodeType Returns information about an XML node.
queryXMLNode Queries an XML node.
xmlBytesToDocument Converts XML content bytes (byte array) to a document.
xmlNodeToDocument Converts an XML node to a document.
xmlStreamToDocument Converts an XML content stream to a document.
xmlStringToDocument Converts an XML string to a document.
xmlStringToXMLNode Converts a String, byte[ ], or InputStream containing an XML document to an XML node.
getXMLNodeIterator Creates and retrieves a NodeIterator.
getNextXMLNode Retrieves the next XML node from a NodeIterator.
freeXMLNode Frees the resources allocated to a given XML node.

documentToXMLBytes

Converts a document to XML content bytes, as a byte array object. This service will recurse through a given document and build an XML representation from the elements within it. Key names are turned into XML elements, and the key values are turned into the contents of those elements.

Input Parameters

Key Description
systemID String Optional. System identifier for the DTD, if any.
publicID String Optional. Public identifier for the DTD, if any.
rootNSPrefix String Optional. Namespace prefix of the rootLocalName, if any.
rootLocalName String Optional. Local name (excluding the namespace prefix) of the root element.

Output Parameters

documentToXMLStream

Converts a document to xml stream, as a java.io.InputStream object. This service will recurse through a given document and build an XML representation from the elements within it. Key names are turned into XML elements and the key values are turned into contents of those elements.

Input Parameters

Key Description
systemID String Optional. System identifier for the DTD, if any.
publicID String Optional. Public identifier for the DTD, if any.
rootNSPrefix String Optional. Namespace prefix of the rootLocalName, if any.
rootLocalName String Optional. Local name (excluding the namespace prefix) of the root element.

Output Parameters

documentToXMLString

Converts a document to xml content string. This service will recurse through a given document and build an XML representation from the elements within it. Key names are turned into XML elements, and the key values are turned into the contents of those elements.

Input Parameters

Key Description
systemID String Optional. System identifier for the DTD, if any.
publicID String Optional. Public identifier for the DTD, if any.
rootNSPrefix String Optional. Namespace prefix of the rootLocalName, if any.
rootLocalName String Optional. Local name (excluding the namespace prefix) of the root element.

Output Parameters

getXMLNodeType

Returns information about an XML node.

Input Parameters

Output Parameters

queryXMLNode

Queries an XML node.

The fields parameter specifies how data is extracted from the node to produce an output variable. This output variable is called a “binding,” because the fields parameter binds a certain part of the document to a particular output variable. At run time, this service must include at least one fields entry. The service must include at least one entry in fields. The result of each query you specify in fields is returned in a variable whose name and type you specify.

Input Parameters

Output Parameters

Usage Notes

If queryXMLNode fails, it throws an exception. Common reasons for queryXMLNode to fail include:

xmlBytesToDocument

Converts XML content bytes (byte array) to a document. This service transforms each element and attribute in XML content bytes to an element in a Document.

Input Parameters

Output Parameters

xmlNodeToDocument

Converts an XML node to a document.

This service transforms each element and attribute in the XML node to an element in a Document.

Notes:

Input Parameters

Output Parameters

xmlStreamToDocument

Converts an XML content stream to a document. This service transforms each element and attribute in the XML content stream to an element in a Document.

Input Parameters

Output Parameters

xmlStringToDocument

Converts an XML string to a document. This service transforms each element and attribute in the XML string to an element in a Document.

Input Parameters

Output Parameters

xmlStringToXMLNode

Converts a String, byte[ ], or InputStream containing an XML document to an XML node.

An XML node is a representation of an XML document that can be consumed by IBM webMethods Integration.

Input Parameters

Output Parameters

Usage Notes

getXMLNodeIterator

Creates and retrieves a NodeIterator.

A NodeIterator iterates over the element node descendants of an XML node and returns the element nodes that satisfy the given criteria. The client application or flow service uses the service getNextXMLNode to get each node in turn. NodeIterators can only be created for XML nodes (not for HTML nodes).

getXMLNodeIterator is useful for loading and parsing documents on demand. NodeIterators are also useful for promptly delivering relevant information as it becomes available in the document, rather than waiting for the entire document to load initially. This service is particularly intended for handling large documents or documents that load gradually.

NodeIterator provides a moving-window mode in which the only node resident in memory is the last node returned by getNextXMLNode. In this mode, when getNextXMLNode is called, all nodes preceding the newly returned node become invalid, including those previously returned by getNextXMLNode. The client must fully complete processing preceding nodes before advancing the window by calling getNextXMLNode again. In moving-window mode, the document consumes at least enough memory to hold the most recently returned node.

The moving-window mode allows the server to process multi-megabyte XML documents using very little memory. This mode may only be used on a node that represents an entire XML document and not on any descendant node.

Input Parameters

Output Parameters

Iterator: NodeIterator for use with the service getNextXMLNode.

getNextXMLNode

Retrieves the next XML node from a NodeIterator.

Input Parameters

Iterator: NodeIterator from which to retrieve the next node.

Output Parameters

Next Document Conditional. The requested node. It is null when the NodeIterator has no more nodes to return. Otherwise, next will contain the following:

Following are the service descriptions: - next: String Element type name of the node. If the element belongs to a namespace and the namespace was declared at the time the NodeIterator was constructed, name will have the prefix declared for that namespace. If the namespace is not declared, name will use prefix that occurs in the XML. - node: XML node identified by the input criteria used to originally generate the NodeIterator.

It is possible that all calls to getNextXMLNode on a given NodeIterator will yield the same document instance, with varying values for the instance’s entries. Therefore, applications should assume that each call to getNextXMLNode invalidates the document returned by the previous call. This approach maximizes server speed and minimizes resource usage.

Usage Notes

A NodeIterator is acquired via the service getXMLNodeIterator. The output of that service is a document containing the element type name of the node and the node itself. The instance of this document is only valid until the next getNextXMLNode call on the same NodeIterator, because getNextXMLNode uses the same document object for each call.

freeXMLNode

Frees the resources allocated to a given XML node.

You can optionally invoke this service when using a NodeIterator to iterate over an XML node, and you decide to halt the processing of the node before reaching the end. By explicitly calling freeXMLNode, you immediately release the resources associated with the node. While it is not mandatory to call this service upon completing the processing of an XML node with a NodeIterator, doing so can enhance server performance. Note that once you have freed an XML node using this service, the node becomes unstable and should not be utilized by any subsequent processes.

Input Parameters

rootNode: XML node whose resources you want to release. Specify the same type of input that you supplied to getXMLNodeIterator.

Output Parameters

None.

E2E Monitoring Services

setCustomTransactionId

You can specify a custom transaction ID as part of your IBM webMethods Integration Flow services. This persists as part of your transaction trace stored in End-to-End Monitoring. A custom transaction ID allows you to reference or search a transaction based on your own identifier such as order ID or shipping reference.

Use this function to set the custom transaction ID in End-to-End Monitoring. You can use this function multiple times in the same Flow Service or associated child services. Using this function appends the values with delimiter commas and sets it to End-to-End Monitoring custom transaction ID. After setting the custom transaction ID, you can use any of these values to search for the transaction in End-to-End Monitoring, and to create Deep Link URLs.

Input Parameters

e2eTransactionId: String - Custom transaction ID that uniquely identifies the End-to-End Monitoring transaction.

Output Parameters

None.

Note
1024 characters is the maximum length of the values this function can set in End-to-End Monitoring, including the delimiter commas. New values do not get appended on exceeding this maximum length.

setCustomTransactionIds

You can specify a custom transaction ID as part of your IBM webMethods Integration Flow services. This persists as part of your transaction trace stored in End-to-End Monitoring. A custom transaction ID allows you to reference or search a transaction based on your own identifier such as order ID or shipping reference.

Use this function to set the custom transaction ID in End-to-End Monitoring as an array of key value pairs. You can use this function to set multiple key value pairs in a single call as it accepts an array input. You can use this function multiple times in the same Flow Service or associated child services. Using this function equates the keys to the values with the equal to (=) character, and appends the multiple key value pairs with delimiter commas and sets them to End-to-End Monitoring custom transaction ID. After setting the custom transaction ID, you can use any of these values to search for the transaction in End-to-End Monitoring, and to create Deep Link URLs.

Input Parameters

e2emTransactionIds: Document List - Custom transaction IDs as key-value pairs that uniquely identify the End-to-End Monitoring transaction.

Output Parameters

None.

Note
  • 1024 characters is the maximum length of the values this function can set in End-to-End Monitoring, including the delimiter commas, keys, values and equal to (=) characters. New values do not get appended on exceeding this maximum length.
  • You can search for the key or the value in End-to-End Monitoring user interface. However, you cannot search for key-value pairs in the key=value format as End-to-End Monitoring filters do not support special characters. In contrast, deep link URLs support key-value pairs.

JWT

JSON Web Token (JWT) is an open standard (RFC 7519) that defines a compact and self-contained way for securely exchanging information as a JSON object between parties.

The following JWT services are available:

Following are the service descriptions:

extractClaimsFromJWT

This service returns specific claim details that you want to extract from a JWT. You can request a specific claim using the input parameter claims.

Input Parameters

jwt: String. The token from which you want to extract claims.

truststoreAlias: String. Alias of the truststore that contains the list of certificates, which server uses to verify the JWT before extracting the claims.

certAlias: String. Alias that identifies a trusted certificate within a truststore.

claims: String[]. List of claims to be extracted.

Output Parameters

message: String. Indicates whether the claims are successfully extracted or not. A success message or an error message followed by the details of claims extracted are displayed.

claimsDetails: Document. The service returns an array or a list of name and value pair for each claim.

Usage Notes

generateSignedJWT

Generates a signed JWT from server.

Input Parameters

algorithm: String. The cryptographic algorithm used to sign a JWT. Supported algorithms are: - RS512 - RS384 - RS256

keyStoreAlias: String. Alias of the keystore containing private key required to sign a JWT.

keyAlias: String. Alias of the private key used to sign a JWT.

allowWeakKey: Boolean. Indicates whether an RSA key shorter than 2048 bits in a cryptographic algorithm is allowed or not.

A value of:
- true allows an RSA key shorter than 2048 bits in a cryptographic algorithm.
- false does not allow an RSA key shorter than 2048 bits in a cryptographic algorithm. This is the default.

subject: String. Optional. Identifies the principal, which is the subject of the JWT.

issuer: String. Optional. Specifies the name of the JWT token issuer.

audience: String []. Optional. Specifies the intended recipients of the token.

expirationTime: String. Optional. Identifies the time on or after which the JWT must not be accepted for processing. The expiration date or time must be equal to or later than the current date or time. The required date format is “dd/MM/yyyy HH:mm:ss”.

notBeforeTime: String. Optional. Identifies the time before which the JWT must not be accepted for processing. The not-before date or time must be equal to or earlier than the current date or time. The required date format is “dd/MM/yyyy HH:mm:ss”.

addIssuedAtTimeClaim: Boolean. Indicates whether issuedAtTime (iat) claim is added to the generated signed JWT or not.

A value of:
- true indicates that the issuedAtTime (iat) claim is added to the generated signed JWT.
- false indicates that the issuedAtTime (iat) claim is not added to the generated signed JWT. This is the default.

jwtId: String. Optional. A unique identifier for the JWT. The value is a case-sensitive string.

customClaims: Document List. Optional. A list of custom claims. Each claim has 3 parts:“name”, “value”, and “type”.

- name: String. Name of the claim.
- value: String[]. The array to provide one or more values for a custom claim.
- type: String. Any valid JSON data type except null. Supported valid JSON data types are: String, Boolean, Number, JSONArray and JSONObject.

Output Parameters

jwt: String. Signed JWT.

Usage Notes

verifyJWT

WmPublic. Verifies the signature in a JWT, the token expiration time, and the not-before time. The expirationTime identifies the time, on or after which the JWT is not accepted for processing. The expiration date or time must be equal or later than to the current date or time.

The notBeforeTime identifies the time before which the JWT is not accepted for processing. The not-before date or time must be equal to or earlier than the current date or time.

Input Parameters

jwt: String. The token to be verified.

truststoreAlias: String. Alias of the truststore that contains the list of certificates, which server uses to verify the JWT.

certAlias: String. Alias that identifies a particular trusted certificate within a truststore.

Output Parameters

isJWTverified: Boolean. Indicates whether the JWT is verified or not. A value of: - true indicates that the JWT is verified. - false indicates that the JWT is not verified.

message: String. Success message if verified or a failed message with reason.

SMIME

Create digitally signed and/or encrypted MIME messages. You also use the services in this folder to process signed and encrypted MIME messages that are passed into the pipeline.

Following are the service descriptions:

- createCertsOnlyData: Generates a PKCS #7 certs-only S/MIME entity from an array of certificates.

- createEncryptedData: Encrypts a MIME message.

- processCertsOnlyData: Extracts the certificates from a PKCS #7 certs-only S/MIME entity.

- processSignedData: Verifies the signature from a signed S/MIME entity and extracts the message from it.

createCertsOnlyData

Generates a PKCS #7 certs-only S/MIME entity from an array of certificates. This service can be used to develop mechanisms for transmitting certificates and certificate chains to other parties.

Input Parameters

certificates: byte[ ][ ] The certificates that are to be encapsulated within the S/MIME entity. Each byte[ ] represents a single certificate.

Output Parameters

SMimeEnvStream: java.io.InputStream S/MIME entity.

createEncryptedData

Encrypts a MIME message.

Input Parameters

envStream: java.io.InputStream MIME message that you want to encrypt (for example, the output produced by getEnvelopeStream service under MIME group).

recipientCerts: byte[ ][ ] The X.509 certificates of the recipients for whom this message will be encrypted. Each element in the list represents a certificate for a single recipient in the form of a byte[ ].

Note
When you have multiple recipients, createEncryptedData creates a single message that is encrypted for all recipients. It does not create a separate message for each recipient.

encryptionAlg: String Optional. Code specifying the encryption algorithm to use. Must be TripleDES (default), DES, or RC2.

keyLength: String Optional. Length of the encryption key for RC2 encryption. Must be 40, 64, or 128 (default). This parameter is ignored if encryptionAlg is not RC2.

Output Parameters

SMimeEnvStream: java.io.InputStream The encrypted MIME message.

processCertsOnlyData

WmPublic. Extracts the certificates from a PKCS #7 certs-only S/MIME entity.

Input Parameters

SMimeEnvStream: java.io.InputStream The certs-only S/MIME entity.

Output Parameters

certificates: byte[ ][ ] The extracted certificates. Each element in the list contains one of the extracted certificates represented as a byte[ ].

processSignedData

Verifies the signature from a signed S/MIME entity and extracts the message from it.

Input Parameters

SMimeEnvStream: java.io.InputStream Signed MIME entity (for example, the output produced by createSignedData from SMIME).

signerCertChain: byte[ ][ ] Optional. Certificate chain of the party that signed the message, where each byte[ ] represents a single certificate in the chain. Certificates must appear in hierarchical order, starting with the signer’s certificate in element 0. The following shows how the elements of a complete chain would appear for a certificate that was issued through two intermediate CAs:

Element Contents
0 Signer’s certificate.
1 Intermediary CA Certificate.
2 Intermediary CA Certificate.
3 Root CA Certificate.
Note
If the signer included the certificate chain with the digital signature, you do not need to supply signerCertChain.

Output Parameters

mimeData: Document MIME object containing the extracted MIME entity.

contentDigest: String Message digest (base64-encoded) that was recalculated by processSignedData.

signerCert: java.security.cert.X509Certificate Signer’s X.509 certificate.

encrypted: String Conditional. Flag indicating whether the extracted MIME entity is encrypted. A value of: - true indicates that the MIME entity is encrypted. - false indicates that the MIME entity is not encrypted.

signed: String Conditional. Flag indicating whether the extracted MIME entity is signed. A value of:
- true indicates that the MIME entity is signed. - false indicates that the MIME entity is not signed.

certsOnly: String Conditional. Flag indicating whether the extracted MIME entity is a certs-only entity. A value of: - true indicates that the MIME entity is a certs-only entity. - false indicates that the MIME entity is not a certs-only entity.

stream: java.io.InputStream Conditional. Extracted MIME entity.

verify: String Flag indicating whether the signature was successfully processed. Success indicates that the signature was successfully verified with the supplied public key. A value of: - true indicates that signature processing was successful. -false indicates that signature processing failed. The signature could not be verified because an errorCode 1, 2, 3, or 4 occurred.

trusted: String Flag indicating whether the signer certificate is trusted or not. A value of: - true indicates that the signer certificate is trusted. - false indicates that the signer certificate is not trusted.

errorCode: String Conditional. Number indicating the kind of error that occurred while processing the signature. See errorMessage for possible values. If no error occurred, errorCode will not be returned.

errorMessage: String Conditional. Textual error message indicating what kind of error occurred while processing the signature. Error codes and messages are as follows:

errorCode errorMessage
1 Invalid signer certificate file information.
2 Certificate at index ‘i’ is not in recognizable format.
3 Invalid certificate input at index ‘i’.
4 Signature cannot be verified.
5 Expired certificate chain.
6 Error in certificate chain.
7 Untrusted certificate

Usage Notes

Important
You can examine the contents of mimeData during testing and debugging. However, because the internal structure of mimeData is subject to change without notice, do not explicitly set or map data to/from these elements in your service. To manipulate or access the contents of mimeData, use only the MIME services that server provides.

createSignedData

WmPublic. Creates signed S/MIME data.

Input Parameters

envStream: java.io.InputStream MIME message that you want to sign (for example,the output produced by pub.mime:getEnvelopeStream).

keyStoreAlias: String Alias of the keystore.

keyAlias: String Alias of the private key of interest in the keystore.

explicit: String Optional. Flag indicating whether an implicit or explicit signature is generated. Set to: - True to generate an explicit (detached) signature. This is the default. - False to generate an implicit signature.

signingAlg: String Optional. The signing algorithm to use to sign the S/MIME messages.
Set to:
- SHA1
- SHA224
- SHA256
- SHA384
- SHA512
The default is SHA1.

Note
  • If you do not set this parameter, server uses SHA1 algorithm to sign the incoming messages.

Output Parameters

SMimeEnvStream: java.io.InputStream The signed MIME stream.

processEncryptedData

Decrypts an encrypted S/MIME message.

Input Parameters

SMimeEnvStream: java.io.InputStream The encrypted S/MIME stream.

keyStoreAlias: String Alias of the keystore containing the decryption key.

keyAlias: String Alias of the key used for decryption.

Output Parameters

mimeData: Document The decrypted MIME message.

contentDigest: String Message digest of the encrypted content, base64-encoded. (Some sites return this digest to the sender to acknowledge their receipt of the message.

encrypted: String Flag indicating whether the MIME entity passed in to the service was encrypted. A value of: - True indicates that the MIME entity was encrypted. - False indicates that the MIME entity was not encrypted.

signed: String Flag indicating whether the MIME entity passed in to the service was signed. A value of: - True indicates that the MIME entity is signed. - False indicates that the MIME entity is not signed.

certsOnly: String Flag indicating whether the MIME entity passed in to the servicen contained only digital certificates. A value of: - True indicates that the MIME entity is a certs-only entity. - False indicates that the MIME entity is not a certs-only entity.

stream: java.io.InputStream The decrypted MIME entity.

Document

Perform operations on documents in the pipeline.

documentToXMLValues: Converts a document (IData object) to a String by encoding it in the webMethods XMLValues format.

XMLValuesToDocument: Decodes a String containing an XMLValues-encoded document and produces a document (IData object).

documentToXMLValues

WmPublic. Converts a document (IData object) to a String by encoding it in the webMethods XMLValues format.

Input Parameters

document: Document Document (IData object) to convert. This document can contain any number of other fields, lists, and other documents.

Output Parameters

xmlvalues: String String representation of the document parameter, encoded in the webMethods XMLValues format.

Usage Notes

XMLValuesToDocument

Decodes a String containing an XMLValues-encoded document and produces a document.

Input Parameters

xmlvalues: String An XMLValues encoding of a document.

Important
This String must contain XMLValues encoding of a document. No other encoding format is accepted.

Output Parameters

document: Document Document result of the decoding of xmlvalues.

pkcs7

sign

Creates a PKCS7 signed Data object.

Input Parameters

signerInfo: Document List Information about a single signer of the signed data object. Each signerInfo requires either a certificate chain and a private key or a key alias that references them.
- keyStoreAlias: String Name of the keystore alias.
- keyAlias: String Alias of the private key.
- hashAlgorithm: String The algorithm to use when computing the digest of the provided data. Specify:
- MD5 (the default)
- SHA-1
- SHA-256
- SHA-384
- SHA-512

data: byte[ ] Optional. Data in the form of a byte array to be digitally signed.

Note
If both data and dataAsStream are provided, dataAsStream takes precedence.

dataAsStream: java.io.InputStream Optional. Data in the form of an input stream to be digitally signed.

Note
If both data and dataAsStream are provided, dataAsStream takes precedence.

detachedSignature: String Flag specifying whether to generate a detached signature. A detached signature does not include the data that was signed.
Set to:
- true to generate a detached signature.
- false to generate an implicit signature (one that includes the signed data). This is the default.

Output Parameters

signature: byte[ ] Conditional. Signature generated in the form of a byte array from the supplied data. This is a DER-encoded representation of the SignedData object as specified in PKCS#7. signature is returned when the input parameter data is provided.

signatureAsStream: java.io.OutputStream Conditional. Signature generated in the form of an output stream from the supplied data. signatureAsStream is returned when the input parameter dataAsStream is provided.

verify

Verifies signed data.

Input Parameters

data: Document. Signed data that you want to verify. The data must be in one of the following formats. If multiple input parameters are supplied for data, the service throws an exception stating that only one parameter must be passed.

- string: String. Optional. The signed string that you want to verify.
- stream: java.io.InputStream. Optional. The signed stream data that you want to verify.
- bytes: byte[ ]. Optional. The signed byte array that you want to verify.

loadAs: String. Optional. The format in which the service returns the output.
Set to:
- bytes to return the output as a byte array. This is the default.
- stream to return the output as a stream object.
- string to return the output as a string.

publicKey: Document. The signer’s public key required to verify the signed data.

Provide publicKeyBytes, publicKeyString.

- publicKeyBytes: Object List. Optional. One or more public key files as byte arrays.

Note
Public key files have a .asc extension.


- publicKeyString: String List. Optional. One or more public keys as strings.

Output Parameters

stream: java.io.OutputStream. Conditional. Verified data as an output stream. Returned when the loadAs input parameter is set to stream.

bytes: byte[ ]. Conditional. Verified data in bytes. Returned when the loadAs input parameter is set to bytes.

string: String. Conditional. Verified data as a string. Returned when the loadAs input parameter is set to string.

verified: Boolean. Indicates whether the signature associated with the data is valid or not.

A value of:
- true indicates that the signed data is verified.
- false indicates that the signed data is not verified.

status: String. Indicates whether the data is successfully verified or not. If successful, status is success. Otherwise, status contains failure along with an error message.

Usage Notes

Note
Authentication keys in the .ecc format are not supported.

String

Perform string manipulation and substitution operations.

isNullEmptyOrWhitespace

Determines if a string is null, empty, or only whitespace.

Input Parameters

inString: String Optional. String to be checked.

ifPresent: Boolean Optional.
- If the value is set to true, the service checks whether inString is present or not, and only then proceeds with validation of the input.
- If the value is set to false, the service throws an exception when inString is absent. Else, the service proceeds to validate the input.

Output Parameters

isNullEmptyOrWhitespace: String Indicates whether inString is null, empty, or only whitespace.
- true indicates that inString has a null value, is empty, or is only whitespace.
- false indicates that inString is not null, not empty, or is not only whitespace.

Examples:
Service with inString = “ \t\n\r\n” and ifPresent = true, returnstrue
Service with inString=” \t\n\r\n” and ifPresent = false, returnstrue
Service with inString = “abcd” and ifPresent = true, returns false
Service with inString = “abcd” and ifPresent = false, returns false
Service with ifPresent = true, returns true
Service with ifPresent = false, throws an exception.

Usage Notes

isNullEmptyOrWhitespace replaces isNullOrBlank which is deprecated.

lookupTable

Locates a key in a String Table and returns the string to which that key is mapped.

Input Parameters

lookupTable: String [ ] [ ] A multi-row, multi-column string table in which to search.

keyColumnIndex: String Index of the “key” column. Default is 0.

valueColumnIndex: String Index of the “value” column. Default is 1.

key: String Key to locate.

Note
The key is case sensitive.

ignoreCase: String Optional. Flag indicating whether to perform a case-sensitive or case-insensitive search. Set to: - true to perform a case-insensitive search. - false to perform a case-sensitive search. This is the default.

useRegex: String Optional. Flag indicating whether the values in the table are to be interpreted as regular expressions.

Note
The regular expressions in the table should not include slashes. Fo example, use hello., not /hello./. Set to: - true to interpret the key column values in the table as regular expressions. - false to interpret the key column values in the table as literal values(that is, not regular expressions). This is the default.

Output Parameters

value: String First value in the “value” column whose key matches key. If no match is found, this parameter is null.

Keystore

keystore:getCertificate

Returns the trusted certificate, stored in a truststore, that corresponds to the certificate’s alias.

Input Parameters

trustStoreAlias: String Alias for the truststore containing the certificate.

certAlias: String Alias identifying a particular trusted certificatewithin a truststore.

Output Parameters

certificate: byte[ ] A byte array containing the trusted certificate.

getTrustedCertificates

Returns the trusted certificates located in a specified truststore.

Input Parameters

trustStoreAlias: String Name of the truststore alias.

Output Parameters

certificates: byte[ ] [ ] Trusted certificates, as a list of byte arrays.

security

Control which client certificates are sent to other services and digitally sign data and process digital signatures. You can also use the elements to store and retrieve outbound passwords to access secure resources.

generateHashValue

Returns the hashed value for a string input.

Input Parameters

inputString: String. The string that you want to convert to a hash value.

hashAlgorithm: String. Optional. The algorithm to generate the hash value. Select one of the following:
- MD5 - SHA256 - SHA384 - SHA512 The default value is SHA256.

saltValue: byte[ ]. Optional. A random value that you can prefix to the input string before hashing.

Note
To use a salt value in this service, run the generateSalt service and map the generated salt value to this parameter.

Output Parameters

hashedValue: String. Hashed value of the input string.

status: String. Indicates whether the inputString is successfully hashed or not. If successful, status is success. Otherwise, status contains failure along with an error message.

Usage Notes

generateSalt

Creates a salt value.

Input Parameters

None.

Output Parameters

saltValue: byte[ ]. Salt value to be used for hashing purposes.

status: String. Indicates whether a salt value is generated or not. If successful, status is success. Otherwise, status contains failure along with an error message.

Usage Notes

Use the saltValue output of this service as input to the generateHashValue service.

decryptAndVerify

Decrypts the encrypted data and verifies the associated digital signature.

Input Parameters

securityProvider: String Optional. The type of security provider. The valid values are: PGP (Pretty Good Privacy), JCE-KBE (Java Cryptography Extension-Key Based Encryption). The default value is PGP

data: Document The data that you want to decrypt and verify must be in one of the following formats. If multiple input parameters are supplied for data, the service throws an exception stating that only one parameter must be passed.


- string: String. Optional. The string that you want to decrypt and verify.
- stream: java.io.InputStream Optional. The stream data that you want to decrypt and verify.
- bytes: byte[ ] Optional. The byte array that you want to decrypt and verify.

loadAs: String. Optional The format in which the service returns the output.
Set to:
- bytes to return the output as a byte array. This is the default.
- stream to return the output as a stream object.
- string to return the output as a string.

secretKey: Document The secret key to extract the private key required to decrypt the data.

For PGP, provide secretKeyBytes,secretKeyString.
ForJCE-KBE, provide secretKeyBytes or keyStoreAlias. If you provide keyStoreAlias, you must provide keyAlias. Otherwise, the service throws an exception.
- secretKeyBytes: byte[ ] Optional. The secret key file in bytes.Note: Secret key files have a .asc extension for PGP.
- secretKeyString: String Optional. The secret key as a string.
- secretKeyPassphrase: String Password required to extract the private key from the secret key. This is the password provided while generating the secret key. This parameter is specific to PGP.
- keyStoreAlias: String Optional. Applies only to JCE. The keystore alias that contains the private key used for decryption.
- keyAlias: String Optional. Applies only to JCE. The private key alias in the keystore specified by the keyStoreAlias parameter that is used for decryption.

Note
This parameter is required only when you use keyStoreAlias.

publicKey: Document The public key required to verify the digital signature associated with the data.For PGP, provide publicKeyBytes, publicKeyString.
For JCE-KBE, provide publicKeyBytes, publicKeyString.
- publicKeyBytes: Object List Optional. One or more public key files as byte arrays for PGP. JCE supports only a single public key file.

Note
Public key files have a .asc extension.
- publicKeyString: String List Optional. One or more public keys as strings for PGP. JCE supports only a single public key string.
- truststoreAlias: String Optional. Applies only to JCE. The alias for the truststore containing the public key and certificate.
Note
This parameter is applicable only for JCE.
- certAlias: String Optional. Applies only to JCE. The alias identifying a particular trusted certificate within a truststore.
Note
This parameter is applicable only for JCE and is required only when you use truststoreAlias.

signingAlgorithm: String The signing algorithm to use.
For PGP, select one of the following:
- SHA256
- SHA384
- SHA512
The default value is SHA256 for PGP.

For JCE, select one of the following:
- RSA
- SHA256withRSA
- SHA512withRSA
- SHA3-256withRSA
- SHA3-384withRSA
- SHA3-512withRSA

Note
  • If the secret key for signing the data is of the DSA (Digital Signature Algorithm) key type, this service does not support the MD5 signing algorithm. This is applicable only for PGP.

cipher: String Optional. Applies only to JCE. The cipher for decryption.
Select one of the following:
- RSA
- RSA/ECB/PKCS1Padding
- RSA/ECB/OAEPWithSHA-1AndMGF1Padding
- RSA/ECB/OAEPWithSHA-256AndMGF1Padding
- RSA/ECB/OAEPWithSHA-512AndMGF1Padding
- RSA/ECB/OAEPPadding
The default value is RSA.

Output Parameters

stream: java.io.OutputStream Conditional. Decrypted and verified data as an output stream. Returned when the loadAs input parameter is set to stream.

bytes: byte[ ] Conditional. Decrypted and verified data as bytes. Returned when the loadAs input parameter is set to bytes.

string: String Conditional. Decrypted and verified data as a string. Returned when the loadAs input parameter is set to string.

verified: Boolean Indicates whether the signature associated with the data is verified or not.
A value of:
- true indicates that the signed data is verified.
- false indicates that the signed data is not verified.

status: String Indicates whether the data is successfully decrypted and verified. If successful, status is success. Otherwise, status contains failure along with an error message.

Usage Notes

Note
Authentication keys in the .ecc format are not supported.

decrypt

Decrypts the encrypted data and returns plain data as a stream object or a byte array.

Input Parameters

data: Document The data that you want to decrypt must be in one of the following formats. If multiple input parameters are supplied for data, the service throws an exception stating that only one parameter must be passed.
- string String. Optional. The string that you want to decrypt.
- stream java.io.InputStream. Optional. The stream data that you want to decrypt.
- bytes byte[ ]. Optional. The byte array that you want to decrypt.

loadAs: String Optional. The format in which the service returns the output. Set to:
- bytes to return the output as a byte array. This is the default.
- stream to return the output as a stream object.
- string to return the output as a string.

secretKey: Document The secret key to extract the private key required to decrypt the data.
For PGP, provide secretKeyBytes, secretKeyString.
For JCE-KBE, provide secretKeyBytes, secretKeyString, or keyStoreAlias. If you provide keyStoreAlias, you must provide keyAlias. Otherwise, the service throws an exception.
- secretKeyBytes byte[ ] Optional. The secret key file in bytes.

 
    Note
    Secret key files have a .asc extension for PGP.

 

 - secretKeyString String Optional. The secret key as a string.<br>
 - secretKey Passphrase String Password required to extract the private key from the secret key. This is the password provided while generating the secret key.<br>
 - keyStoreAlias String Optional. Applies only to JCE. The keystore alias that contains the private key used for decryption.<br>
 - keyAlias String Optional. Applies only to JCE. The private key alias in the keystore specified by the keyStoreAlias parameter that is used for decryption.<br>

 
    Note
    This parameter is required only when you use keyStoreAlias.

Output Parameters

stream: java.io.OutputStream Conditional. Decrypted data as an output stream. Returned when the loadAs input parameter is set to stream.

bytes: byte[ ] Conditional. Decrypted data as bytes. Returned when the loadAs input parameter is set to bytes.

string: String Conditional. Decrypted data as a string. Returned when the loadAs input parameter is set to string.

status: String Indicates whether the data is successfully decrypted or not. If successful, status is success. Otherwise, status contains failure along with an error message.

Usage Notes

Prerequisites to use the decrypt service:

Decryption works as follows:
1. The external system sends the data encrypted with server’s public key.
2. The server receives the data and passes it to the pub.security:decrypt service.
3. The decrypt service uses the private key to decrypt the data.
4. The service returns the decrypted data.

For JCE, the service supports a maximum data size that depends on the key size.

encrypt

Converts plain data to encrypted data.

Input Parameters

securityProvider: String Optional. The type of security provider.
The valid values are:
- PGP (Pretty Good Privacy)
- JCE-KBE (Java Cryptography Extension-Key Based Encryption)
The default value is PGP.
data: Document Data that you want to encrypt. The data must be in one of the following formats. If multiple input parameters are supplied for data, the service throws an exception stating that only one parameter must be passed.
- string: String Optional. The string that you want to encrypt.
- stream: java.io.InputStream Optional. The stream data that you want to encrypt.
- bytes: byte[ ] Optional. The byte array that you want to encrypt.

loadAs: String Optional. The format in which the service returns the output.
Set to:
- bytes to return the output as a byte array. This is the default.
- stream to return the output as a stream object.
- string to return the output as a string.

publicKey: Document The public key required to encrypt the data.
For PGP, provide publicKeyBytes, publicKeyString, or publicKeyRingFile.
For JCE-KBE, provide publicKeyBytes, publicKeyString, or truststoreAlias. If you provide truststoreAlias, you must also provide certAlias. Otherwise, the service throws an exception.
Following are the key descriptions:
- publicKeyBytes: Object List Optional. One or more public key files as byte arrays for PGP. JCE supports only a single public key file.

Note
Public key files have a .asc extension for PGP.
- publicKeyString: String List Optional. One or more public keys as strings for PGP. JCE supports only a single public key string.
- truststoreAlias: String Optional. Applies only to JCE. The alias for the truststore containing the public key and certificate.
- certAlias: String Optional. Applies only to JCE. The alias identifying a particular trusted certificate within a truststore.
Note
This parameter is required only when you use truststoreAlias.

encryption Algorithm: String The key encryption algorithm to use. For PGP, select one of the following symmetric key encryption algorithms: - AES_192 - AES_256 - BLOWFISH - IDEA - TRIPLE_DES - TWOFISH The default value is AES_256. For JCE, select RSA (asymmetric key encryption algorithm).

cipher: String Optional. Applies only to JCE. The cipher for encryption. Select one of the following: - RSA - RSA/ECB/PKCS1Padding - RSA/ECB/OAEPWithSHA-1AndMGF1Padding - RSA/ECB/OAEPWithSHA-256AndMGF1Padding - RSA/ECB/OAEPWithSHA-512AndMGF1Padding - RSA/ECB/OAEPPadding The default value is RSA.

Output Parameters

stream: java.io.OutputStream Conditional. Encrypted data as an output stream. Returned when the loadAs input parameter is set to stream.

bytes: byte[ ] Conditional. Encrypted data as bytes. Returned when the loadAs input parameter is set to bytes.

string: String Conditional. Encrypted data as a string in the ASCII-armored format. Returned when the loadAs input parameter is set to string.

status: String Indicates whether the data is successfully encrypted or not. If successful, status is success. Otherwise, status contains failure along with an error message.

Usage Notes

For PGP, consider the following points:
- Before encrypted data is exchanged between server and an external system, the external system must share its public key. The service accepts multiple public keys to encrypt the same data for many users.
- The public key is passed to the encrypt service, which returns the encrypted data to server.
- To encrypt the data for multiple users, provide the users’ public keys to the service as a list of byte arrays, strings.
- Authentication keys used in this service must be in the PGP format and generated using the RSA encryption algorithm.

Note
Authentication keys in the .ecc format are not supported for PGP.

For JCE, consider the following points: - You can encrypt the data for a single user only. Provide the public key to the service as a list of byte array, string, or truststoreAlias. If you provide truststoreAlias, you must also provide certAlias. - The service supports a maximum data size that depends on the key size.

sign

Adds a digital signature to data.

Input Parameters

securityProvider String Optional. The type of security provider.
The valid values are:
- PGP (Pretty Good Privacy)
- JCE-KBE (Java Cryptography Extension-Key Based Encryption)
The default value is PGP.

data: Document Data that you want to sign. The data must be in one of the following formats. If multiple input parameters are supplied for data, the service throws an exception stating that only one parameter must be passed.
- string: String Optional. The string that you want to sign.
- stream: java.io.InputStream Optional. The stream data that you want to sign.
- bytes: byte[ ] Optional. The byte array that you want to sign.

loadAs: String Optional. The format in which the service returns the output.
Set to:
- bytes to return the output as a byte array. This is the default.
- stream to return the output as a stream object.
- string to return the output as a string.

secretKey: Document The secret key required to sign the data.

For PGP, provide secretKeyBytes, secretKeyString.
For JCE-KBE, provide secretKeyBytes, secretKeyString, or keyStoreAlias. If you provide keyStoreAlias, you must provide keyAlias. Otherwise, the service throws an exception.

- secretKeyBytes: byte[ ] Optional. The secret key file in bytes.

Note
Secret key files have a .asc extension for PGP.

- secretKeyString: String Optional. The secret key as a string.
- secretKeyPassphrase: String Password required to extract the private key from the secret key. This is the password provided while generating the secret key.
- keyStoreAlias: String Optional. Applies only to JCE. The keystore alias that contains the private key.
- keyAlias: String Optional. Applies only to JCE. The private key alias in the keystore specified by the keyStoreAlias parameter.
Note
This parameter is required only when you use keyStoreAlias.

signingAlgorithm:String The signing algorithm to use.
For PGP, select one of the following:
- SHA256
- SHA384
- SHA512
The default value is SHA256 for PGP.
For JCE, select one of the following:
- RSA
- SHA256withRSA
- SHA512withRSA
- SHA3-256withRSA
- SHA3-384withRSA
- SHA3-512withRSA

Note
  • If the secret key for signing the data is of the DSA (Digital Signature Algorithm) key type, this service does not support the MD5 signing algorithm. This is applicable only for PGP.

Output Parameters

stream: java.io.OutputStream Conditional. Signed data as an output stream. Returned when the loadAs input parameter is set to stream.

bytes: byte[ ] Conditional. Signed data as bytes. Returned when the loadAs input parameter is set to bytes.

string: String Conditional. Signed data as a string in the ASCII-armored format. Returned when the loadAs input parameter is set to string.

status: String Indicates whether the data is successfully signed or not. If successful, status is success. Otherwise, status contains failure along with an error message.

Note
Authentication keys in the .ecc format are not supported.

signAndEncrypt

Adds a digital signature to data and then encrypts the data.

Input Parameters

securityProvider: String Optional. The type of security provider.
The valid values are:
- PGP (Pretty Good Privacy)
- JCE-KBE (Java Cryptography Extension-Key Based Encryption)
The default value is PGP.

data: Document Data that you want to sign and encrypt. The data must be in one of the following formats. If multiple input parameters are supplied for data, the service throws an exception stating that only one parameter must be passed.
- string: String Optional. The string that you want to sign and encrypt.
- stream: java.io.InputStream Optional. The stream data that you want to sign and encrypt.
- bytes: byte[ ] Optional. The byte array that you want to sign and encrypt.

loadAs: String Optional. The format in which the service returns the output.
Set to:
- bytes to return the output as a byte array. This is the default.
- stream to return the output as a stream object.
- string to return the output as a string.

publicKey: Document The public key required to encrypt the data.

For PGP, provide publicKeyBytes, publicKeyString.
For JCE-KBE, provide publicKeyBytes, publicKeyString, or truststoreAlias. If you provide truststoreAlias, you must also provide certAlias. Otherwise, the service throws an exception.

- publicKeyBytes: Object List Optional. One or more public key files as byte arrays for PGP. JCE supports only a single public key file.

Note
Public key files have a .asc extension for PGP.

- publicKeyString: String List Optional. One or more public keys as strings for PGP. JCE supports only a single public key string.
- truststoreAlias: String Optional. Applies only to JCE. The alias forthe truststore containing the public key and certificate.
- certAlias: String Optional. Applies only to JCE. The alias identifying a particular trusted certificate within a truststore.
Note
This parameteris required only when you use truststoreAlias.

encryptionAlgorithm: String The encryption algorithm to use.
For PGP, select one of the following symmetric key encryption algorithms:
- AES_192
- AES_256
- BLOWFISH
- IDEA
- TRIPLE_DES
- TWOFISH
The default value is AES_256.

- For JCE, select RSA (asymmetric key encryption algorithm).

secretKey: Document The secret key required to sign the data.
For PGP, provide secretKeyBytes, secretKeyString.
For JCE-KBE, provide secretKeyBytes, secretKeyString, or keyStoreAlias. If you provide keyStoreAlias, you must provide keyAlias. Otherwise, the service throws an exception.
- secretKeyBytes: byte[ ] Optional. The secret key file in bytes.

Note
Secret key files have a .asc extension for PGP.
- secretKeyString: String Optional. The secret key as a string.
- secretKeyPassphrase: String Password required to extract the private key from the secret key. This is the password provided while generating the secret key.
- keyStoreAlias: String Optional. Applies only to JCE. The keystore alias that contains the private key.
- keyAlias: String Optional. Applies only to JCE. The private key alias in the keystore specified by the keyStoreAlias parameter.
Note
This parameter is required only when you use keyStoreAlias.

*signingAlgorithm**: String. The signing algorithm to use.
For PGP, select one of the following:
- SHA256
- SHA384
- SHA512
The default value is SHA256 for PGP.
For JCE, select one of the following:
- RSA
- SHA256withRSA
- SHA512withRSA
- SHA3-256withRSA
- SHA3-384withRSA
- SHA3-512withRSA

cipher: String Optional. Applies only to JCE. The cipher for encryption. Select one of the following:
- RSA
- RSA/ECB/PKCS1Padding
- RSA/ECB/OAEPWithSHA-1AndMGF1Padding
- RSA/ECB/OAEPWithSHA-256AndMGF1Padding
- RSA/ECB/OAEPWithSHA-512AndMGF1Padding
- RSA/ECB/OAEPPadding
The default value is RSA.

Output Parameters

stream: java.io.OutputStream Conditional. Signed and encrypted data as an output stream. Returned when the loadAs input parameter is set to stream.

bytes: byte[ ] Conditional. Signed and encrypted data as bytes. Returned when the loadAs input parameter is set to bytes.

string: String Conditional. Signed and encrypted data as a string in the ASCII-armored format. Returned when the loadAs input parameter is set to string.

status: String Indicates whether the data is successfully signed and encrypted or not. If successful,statusis success. Otherwise,status contains failure along with an error message.

Usage Notes

Note
Authentication keys in the .ecc format are not supported.

verify

Verifies signed data.

Input Parameters

securityProvider: String Optional. The type of security provider. The valid values are:
- PGP (Pretty Good Privacy)
- JCE-KBE (Java Cryptography Extension-Key Based Encryption)
The default value is PGP.

data: Document Signed data that you want to verify. The data must be in one of the following formats. If multiple input parameters are supplied for data, the service throws an exception stating that only one parameter must be passed.
- string: String Optional. The signed string that you want to verify.
- stream: java.io.InputStream Optional. The signed stream data that you want to verify.
- bytes: byte[ ] Optional. The signed byte array that you want to verify.

loadAs: String Optional. The format in which the service returns the output. Set to:
- bytes to return the output as a byte array. This is the default.
- stream to return the output as a stream object.
- string to return the output as a string.

publicKey: Document The signer’s public key required to verify the signed data.
For PGP, provide publicKeyBytes, publicKeyString.
For JCE-KBE, provide publicKeyBytes, publicKeyString, or truststoreAlias. If you provide truststoreAlias, you must also provide certAlias. Otherwise, the service throws an exception.


- publicKeyBytes: Object List Optional. One or more public key files as byte arrays for PGP. JCE supports only a single public key file.

Note
Public key files have a.asc extension for PGP.

- publicKeyString: String List Optional. One or more public keys as strings for PGP.
JCE supports only a single public key string.

signingAlgorithm: String. The signing algorithm to use.
For PGP, select one of the following:
- SHA256
- SHA384
- SHA512
The default value is SHA256 for PGP.
For JCE, select one of the following:
- RSA
- SHA256withRSA
- SHA512withRSA
- SHA3-256withRSA
- SHA3-384withRSA
- SHA3-512withRSA

actualData: Document Applies only to JCE. The original data that was signed and needs to be verified against the signature to confirm that it hasn’t been tampered with. The actualData parameter must be in one of the specified formats. If multiple input parameters are provided for actualData, the service throws an exception indicating that only one parameter should be passed.

string: String Optional. The original string that you want to verify.
stream: java.io.InputStream Optional. The original stream data that you want to verify.
bytes: byte[ ] Optional. The original byte array that you want to verify.

Output Parameters

stream:java.io.OutputStream Conditional. Verified data as an output stream.
Returned when the loadAs input parameter is set to stream.

bytes: byte[ ] Conditional. Verified data in bytes. Returned when the loadAs input parameter is set to bytes.

string: String Conditional. Verified data as a string. Returned when the loadAs input parameter is set to string.

verified: Boolean Indicates whether the signature associated with the data is valid or not. A value of:

- true indicates that the signed data is verified.
- false indicates that the signed data is not verified.

status: String Indicates whether the data is successfully verified or not. If successful, status is success. Otherwise, status contains failure along with an error message.

Usage Notes

Note
Authentication keys in the .ecc format are not supported.

createMessageDigest

Generates a message digest for a given message.

Input Parameters

algorithm: String Name of the algorithm that you want to use to compute the message digest. Must be one of the following: MD5, SHA-1, SHA-256, SHA-384, or SHA-512.

input: byte[ ] Optional. Message for which you want the digest generated where the message is in the form of a byte array.

Note
If both input and inputAsStream are provided, inputAsStream takes precedence.

inputAsStream: java.io.InputStream Optional. Message for which you want to generate a message digest where the message is in the form of an input stream.

Note
If both input and inputAsStream are provided, inputAsStream takes precedence.

Output Parameters

output: byte[ ] Conditional. Computed digest in the form of a byte array. output is returned when the input parameter input is provided.

outputAsStream: OutputStream. Conditional. Computed digest in the form of an output stream. outputAsStream is returned when the input parameter inputAsStream is provided.

getCertificateInfo

Retrieves information such as serial number, issuer, and expiration date from a digital certificate.

Input Parameters

certificate: byte[] java.security.cert.X509Certificate The certificate whose information you want to retrieve.

dateFormat: String Optional. The date format to use for the date returned by the notBefore and notAfter fields in the validity output parameter.
The value of dateFormat must be a pattern used by java.text.SimpleDateFormat, for example: MM/dd/yyyy .
By default, getCertificateInfo service uses a preset date format that returns only the last two digits of the certificate expiration year. This can lead can lead to ambiguity as a certificate that expires in 2109 returns an expiration year of 09, which some systems might treat as 2009.

Output Parameters

info: Document Information from the certificate.

- version: java.lang.Number X509 certificate version number.
- serialNumber: String Serial number of the certificate.
- signature: String Signature algorithm used by the issuer to sign this certificate.
- issuer: Document Detailed information about the CA that signed the certificate, such as name, location, and e-mail address.
- validity: Document The time period over which the certificate is valid.

- notBefore: String First date on which this certificate is valid (for example, 3/15/00 3:36PM).
- notAfter: String Last date on which this certificate is notAfter valid (for example, 3/15/00 3:36PM).

- subject: Document. Detailed information about the owner of the certificate, such as name, location, and mail address.
- subjectPublicKeyAlgorithm: String Encryption algorithm with which the certificate’s key is designed to be used (for example, RSA or DSA).

loadPKCS7CertChain

Converts a certificate chain that is in PKCS #7 format to a list of byte arrays.

Input Parameters

certificateChain: byte[ ] The certificate chain in PKCS #7 format.

Output Parameters

certificates: byte[ ] [ ] List of byte arrays in which each byte[ ] in the list contains a certificate from certificateChain.

decryptXML

Decrypts the encrypted XML, and returns the XML as either a string or stream object.

Input Parameters

String Optional. Encrypted XML that needs to be decrypted as plain text.

xmldata: String Optional. Encrypted XML that needs to be decrypted as plain text.

xmlStream: InputStream Optional. Encrypted XML in the form of an input stream.

Note
If both xmldata and xmlStream are provided, xmlStream takes precedence; server uses the xmlStream value and returns only decryptedXMLStream.

keyStoreAlias: String Optional. Alias of the keystore that contains the private key used for decryption.

keyAlias: String Optional. Alias of the private key, contained in the keystore specified by the keyStoreAlias parameter, that is used for decryption.

encoding: String Optional. Specifies the encoding to use if the encoding cannot be extracted from the XML. If encoding is not specified in the XML document or in the encoding parameter, server uses UTF-8.

The encoding value must be a valid IANA encoding.

Output Parameters

decryptedXMLData: String Conditional. DecryptedXML data. decryptedXMLData is returned when the input parameter xmldata is provided.

decryptedXMLStream: Object Conditional. A decrypted XML OutputStream object. decryptedXMLStream is returned when the input parameter xmlStream is provided.

Usage Notes

encryptXML

Encrypt an XML document or node in an XML document.

Input Parameters xmldata: String Optional. The XML to be encrypted.

xmlStream: InputStream Optional. Input stream to the XML that needs to be encrypted.

Note
If both xmldata and xmlStream are provided, xmlStream takes precedence.

nodeSelectors: String List XPaths to the node to be encrypted. If the value for this parameter is left empty, no XML will be encrypted.

nsDecls: Document Optional. Mapping of the namespace prefixes to the namespace URIs. The first column contains the prefixes and the second column contains the corresponding URIs.

recipientCert: Byte[] Optional. The certificate containing the public key that will be used to encrypt the XML. If the input parameters recipientCert and recipientID are both provided, recipientCert is used.

contentOnly: Boolean Optional. Indicates whether the XML tags surrounding the content will be encrypted along with the content.

Set to:
- true to encrypt only the content.
- false to encrypt both the tags and the content. This is the default.

algorithm: String Optional. The symmetric key algorithm to use for encryption.

Set to: - tripledes-cbc for the algorithm at http://www.w3.org/2001/04/xmlenc#tripledes-cbc This is the default.
- aes256-cbc for the algorithm at http://www.w3.org/2001/04/xmlenc#aes256-cbc
- aes192-cbc for the algorithm at http://www.w3.org/2001/04/xmlenc#aes192-cbc
- aes128-cbc for the algorithm at http://www.w3.org/2001/04/xmlenc#aes128-cbc

Note
If you are using aes256-cbc or aes192-cbc with JVM 1.6, make sure the unlimited policy jar files have been installed.

encryptedKeyAlgorithm: String Optional. The symmetric key that is randomly generated, and then encrypted with the receiver’s public key. This encryption uses an asymmetric algorithm if public/private key pairs are being used.

Set to:
- rsa-1_5 for the algorithm at http://www.w3.org/2001/04/xmlenc#rsa-1_5 This is the default.
- rsa-oaep-mgf1p for the algorithm at http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p

encoding: String Optional. Specifies the encoding to use if the encoding cannot be extracted from the XML. If encoding is not specified in the XML document orin the encoding parameter, server uses UTF-8. The encoding value must be a valid IANA encoding.

Output Parameters

encryptedXMLData: String Conditional. Encrypted XML data. encryptedXMLData is returned when the input parameter xmldata is provided.

encryptedXMLStream: OutputStream Conditional. Encrypted XML in the form of an OutputSream. encryptedXMLStream is returned when the input parameter xmlStream is provided.

Usage Notes

Signing and Encrypting the Same XML Document

You can use both encryption and signing in the same XML document.

- If you sign and encrypt different XML elements in a document, you can run either signXML or encryptXML first.
- Typically, if you sign and encrypt the same XML elements in a document, you should sign the elements before encrypting them. That is, invoke signXML before invoking xml:encryptXML.

signXML

Digitally sign an outgoing XML node or document.

Input Parameters

xmldata: String Optional. XML that needs to be signed.

xmlStream: InputStream Optional. Input stream containing the XML that needs to be signed.

Note
If both xmldata and xmlStream are provided, xmlStream takes precedence.

uri: String Optional. URI to the element to be signed. In combination with the nodeSelectors parameter, the uri identifies the nodes to be signed.

noNamespace SchemaLocation: String Optional. A URI that identifies the location of the XML schema definition that contains the ID attribute specified in uri. Provide a noNamespaceSchemaLocation when specifying an ID attribute for uri and the ID attribute resides in an XML schema with no namespaces.

schemaLocations: Document Optional. Document containing name-value pairs forthe XML namespace and the location of the XML schema definition that contains element declarations, attribute declarations, and type definitions for that namespace. Provide a schemaLocation when specifying an ID attribute for uri and the ID attribute resides in an XML schema for a particular namespace.

For example:
- XML namespace = http://www.w3schools.com - XML schema definition location = file:C:/note.xsd

nodeSelectors: String List XPath notation that identifies the nodes to be signed. The locations of the XPaths are not absolute, but relative, and work within the context of the node (an XPath Axes).

Note
Do not use absolute location XPaths here.

nsDecls: Document Optional. Mapping of the namespace prefixes to the namespace URIs. The first column contains the prefixes and the second column contains the corresponding URIs.

isEnveloped: String Optional. Indicates whether the signature is enveloped or enveloping. Set to:
- True to indicate that the generated signature will be enveloped. This is the default. - False to indicate that the generated signature will be enveloping, provided the isDetached parameteris set to False.

Unlike the detached signature, which is kept apart from the original document, enveloping and enveloped signatures are tightly coupled with the original document.

isDetached: String Optional. Indicates whether the signature is detached or not.

The server uses as the container for signature and the XML to be signed. Set to:
- True to indicate that the generated signature will be detached.
- False to indicate that the generated signature will be enveloping or enveloped, based on the isEnveloped parameter setting. This is the default.

Note
  • Setting isDetached to True and isEnveloped to False, indicates that the signature will be detached.
  • Setting isDetached to False and isEnveloped to True,indicates that the signature will be enveloped.
  • Setting isDetached to False and isEnveloped to False,indicates that the signature will be enveloping.
  • Setting isDetached to True and isEnveloped to True, results in error.

signatureNodeSelector: String Optional. XPath to the node where the signature is entered. Applicable only for enveloped signatures. If no value is provided, the signature is placed as a first child of the root node.

signatureAlgorithm: String Optional. Signature algorithm to use when signing the XML node or document. Specify one of the following or use the default value (first algorithm):
- SHA1 (default)
- SHA256
- SHA384
- SHA512

canonicalizationAlgorithm: String Optional. Canonical algorithm used with the XML. Specify one of the following or use the default value (first algorithm):
- http://www.w3.org/TR/2001/rec-xml-c14n-20010315 (default)
- http://www.w3.org/TR/2001/rec-xml-c14n-20010315#WithComments
- http://www.w3.org/2001/10/xml-exc-c14n#
- http://www.w3.org/2001/10/xml-exc-c14n#WithComments

signatureId: String Optional. ID attribute for the signature node.

keyStoreAlias: String Optional. Name (alias) of the keystore that contains the private key/certificate.

keyAlias: String Optional. Name (alias) of the private key, contained in the keystore specified by the keyStoreAlias parameter, that is used for signing.

keyName: String Optional. Name that is used by the signerto communicate a key identifier to the recipient.

includeKeyValue: String Optional. Indicates whether to include the key value (RSAKeyValue or DSAKeyValue), based on the certificate used for signing. The KeyValue element contains a single public key that can be used in validating the signature. Set to:
- True to include the key value (RSAKeyValue or DSAKeyValue) based on the certificate used for signing. - False to exclude the key value from the signature.

includeCertChain: String Optional. Indicates whether the certificate chain should be included in the signature. Set to:
- True to include the certificate chain in the signature. - False to leave the certificate chain out of the signature. This is the default.

certData: String List Optional. Select the X509 certificate data to be entered into the signature’s key information.
- X509_CERTIFICATE (default)
- X509_SUBJECT_NAME
- X509_ISSUER_SERIAL
- X509_SKI
- X509_CRL

Note that the initials “SKI” and “CRL”in denote “Subject Key Identifier” and Certificate Revocation List”.

idXmlObject: String Optional. Specifies the ID for the node that holds the original XML that is signed. Applicable only for enveloping signatures.

encoding: String Optional. Specifies the encoding to use if the encoding cannot be extracted from the XML. If encoding is not specified in the XML document or in the encoding parameter, the server uses UTF-8. The encoding value must be a valid IANA encoding.

addSignatureAsLastElement: Boolean Optional. When isEnveloped is set to True, this parameter indicates the position at which the server should add the signature element child to the root.
Set to:
- True to add the signature element as the last child of the root.
- False to add the signature element as the first child of the root. This is the default.

addDSPrefixToSignature: Boolean. Optional. Set to False to create a Signature element in the signed XML without any prefixes. By default, this input variable is set to True and the “ds:” prefix is added.

Output Parameters

signedXMLData: String Conditional. Signed XML data. signedXMLData is returned when xmlData is provided.

signedXMLStream: OutputStream Conditional. Signed XML in the form of an OutputSream. signedXMLStream is returned when xmlStream is provided.

Usage Notes

Signature Types

As opposed to a detached signature, which is kept apart from the original document, enveloping and enveloped signatures are tightly coupled with the original document.

An enveloping signature must be a parent node of the data being signed: <!– Example of Enveloping Signature –> <Signature> <my_document>. . . </my_document> </Signature>

The following input parameters and values are applicable only to enveloping signatures:

isEnveloped: Specify a value of “false” for enveloping.

If isEnveloped is set to false, then:
- If both uri and idXmlObject are null, the server creates a dynamic unique value for both uri and idXmlObject and signs the XML.
- If idXmlObject is provided and uri is null, the server creates a uri with a value of #idXmlObject_value and signs the XML.
- If both and uri and idXmlObject are provided and match the XML contract (for example,uri=‘#idXmlObject’), The server signs the XML. If the uri and idXmlObject parameters do not match the contract, the server issues an exception.

idXmlObject: Specifies the ID for the node that holds the original, signed XML. An enveloped signature must be a child node of the data being signed:

<!– Example of Enveloped Signature –> <my_document>
<Signature> … </Signature> </my_document>

The following parameters and values are applicable only to enveloped signatures:

isEnveloped: The default value of “true” specifies that the signature is enveloped. signatureNodeSelector: XPath to the node where the signature is entered. If no value is provided, the signature is placed as a first child of the root node.

Signing and Encrypting the Same XML Document

You can use both encryption and signing in the same XML document.

getKeyAndChain

Returns a private key and its associated certificate chain from a designated keystore.

Input Parameters

keyStoreAlias: String Alias for the keystore that contains the private key of interest and its certificate.

keyAlias: String Alias for the private key stored in the specified keystore.

Output Parameters

privateKey: java.security.PrivateKey Object representing the private key.

certChain: byte[ ] [ ] List of byte arrays representing the certificate chain associated with the private key.

Log Business Data

While executing a flow service, IBM webMethods Integration allows you to log business data at the step level as well as at the Flow service level.

Note
  • Log business data functionality has a 16 MB limitation on the size of data that can be logged. This limitation is applicable at the step level as well as at the flow service level.

  • Assign a unique alias to each field when selecting business data for logging.

Log business data at the step level

1.Provide a name and description of the flow service.

2.As we will query contacts from Salesforce CRM and log the business data, select the Salesforce CRM connector, queryContacts operation, and SalesforceCRM_2 as the account.

3.Select the Log business data option available at the step level as shown below. At the step level, the Log business data option is enabled only for connectors.

4.In the Log business data dialog box, choose Always to always log business data. As we will query the contacts from Salesforce CRM, select the output fields and specify the display names for AccountId, LastName, and FirstName as shown below.

5.Run the flow service and go to the Execution History page by clicking the Execution history option.

6.Click on the execution history entry to view the execution details page. As you can see below, the business data is logged.

Log business data at the flow service level

Note
⁠In the Monitor > Flow service execution page, only top-level flow services are visible. To view child-level flow service information, enable Log business data with its value as Always at the flow service level. This information is not directly available on the Monitor page but is one of the options within the top-level flow service operations.

The steps to do this are explained below:

1.Click the icon.
Let us define the input field FirstName as shown below.

2.Click the Log business data option available at the Flow service level.

3.In the Log business data dialog box, choose Always to always log business data.

4.In an earlier step, you had defined the input field FirstName. Select the input field FirstName as shown below and specify the display name as First Name of Customer.

5.Run the flow service. For the FirstName field, enter the value John and again click Run.

6.Click the Execution history option to go to the Execution History page.

7.Click on the execution history entry to view the execution details page. As you can see below, the business data is logged.

Reference Data

Reference data is data that defines the set of permissible values to be used by other data fields. It is a collection of key-value pairs, which can be used to determine the value of a data field based on the value of another data field. For example, the value of a status field in an Application can be “Canceled” and that needs to be interpreted as “CN” in another Application.

IBM webMethods Integration allows you to upload reference data from a text file containing tabular data separated by a character, for example, a comma, semicolon, and so on. The uploaded file should not have an empty column heading or space in the first row, and the first row cannot be empty.

Reference data appears under Services in the flow services workspace. You can access the uploaded reference data in flow services as a list of documents by using the reference data service and providing an appropriate name. You can filter the documents returned into the pipeline by the reference data service.

You can Delete, Download, or Edit a reference data from the Reference Data screen. If a reference data is used in a flow service, you will not be able to delete that reference data. You must remove the reference data from the flow service and then delete the reference data. The Download option allows you to download the previously uploaded reference data, edit it, and then upload the modified file.

Reference Data Signature

Reference data signature is derived from the column names of the uploaded text file. You can filter the Reference data by providing an appropriate matchCriteria. The output of Reference data is a list of documents that match the specified matchCriteria.

Input Parameters

matchCriteria: Document. Criteria on which documents from the Reference data are matched.
Parameters for matchCriteria are:

joins: List of join criteria. Each join criteria consists of:

Output Parameters

Reference Data Name: Document List. List of documents that match the retrieve criteria.

Creating a Reference Data

Let us see how to create a reference data and use it in a flow service with the help of an example.
In this example, we will upload a file that contains a list of courier vendors as reference data in IBM webMethods Integration, and then import the list of vendors as contacts into Salesforce CRM.

Before you begin

Basic Flow

1.Select the project where you want to create the reference data. You can also create a new project.

2.Click Configurations > Flow service > Reference Data > Add Reference Data.

3.Provide a name (CourierVendors) and an optional description for the reference data.

4.For the Reference Data File, click Browse file and select the file. Both csv and a text file having tabular data are supported. The maximum file size you can upload is 1 MB. As shown in the sample, the file should not have an empty column heading or space in the first row and that row cannot be empty. This is because the first row of data is read as column headings.

5.Click Next to define the reference data. Select the Field separator and the Text qualifier. Determine the encoding of the reference data file and from the File Encoding drop down list, select the same encoding.

6.Click Next to preview the data. If you select an incorrect encoding, garbage characters may appear in the preview pane.

7.Click Done to create the reference data. The new reference data appears in the Reference Data page. The reference data also appears under the Services category in the flow services workspace.

8.Go to Flow services and create a new flow service. Provide a name ImportCourierVendorsAsContacts and description of the flow service. Then type reference data in the first step and select Reference Data.

9.Select CourierVendors. Click the icon to add a new step. We need to create a contact for each vendor, so type Repeat to select the Repeat step, and then select the CourierVendors option.

10.Select Salesforce CRM, the action as createcontact and associate the SalesforceCRM_1 account.

11.Click the mapping icon and map the input and output fields as shown below.

12.Save and run the flow service, and view the results.

Note
As Reference Data generally varies across different environments, you need to reconfigure the Reference Data as per the respective environment. So if you are publishing a project that has a flow service with Reference Data, the Reference Data will not be published along with the flow service. You are required to create the Reference data in the destination environment. Further, if a flow service you are exporting has Reference Data, the Reference Data will not be exported along with the flow service. You are required to create the reference data in the destination environment.

Cloning Flow services

The Clone feature allows you to copy the existing functionality of a flow service into a new flow service. This is particularly useful if you want to recreate an existing flow service but change few options. You need not start from scratch and create all over again. When you clone a flow service, the clone is exactly the same as the original. Obviously, you can make changes whenever you want, just like any other flow service.

To clone a flow service:

  1. Locate the flow service that you want to clone.

  2. Click the ellipsis icon () available on the flow service and click Clone from the displayed menu. The Clone Flow service dialog box appears.

  3. Enter the Flow service Name and Project.

  4. Click Clone. The flow service is created under the specified project. You can modify according to your needs as any other flow service.

Note
  • Ensure that you create the account or reference data associated with the respective asset in the target project.
  • You can create a clone of a cloned flow service.
  • Editing a cloned flow service will not affect the original flow service from which it was cloned.
  • A cloned flow service containing the Messaging connector placed within the same project inherits all assets, configurations, and authorizations of the original flow service. However, cloning a flow service to a different project copies items of the original flow service and does not retains assets, configurations, and authorizations. You need to create the account or reference data associated with the respective asset in the destination project.
  • Whenever a flow service is cloned, then any child flow services with the same name are overridden.

Caching in Flow services

About Caching

Caching is an optimization feature that can improve the performance of integrations. Service caching operates according to the input signature of the enabled service. When caching is enabled, the service result is stored using the input signature values as the key. If the service defines an output signature, only the fields included in the output signature are cached. However, if there is no defined output signature, the entire pipeline at that specific point is cached.

During subsequent executions of the service with the same input, the cached entry in the service result cache is retrieved. The cached output fields are then merged with the input pipeline and subsequently returned to the client rather than invoking the flow service again.

Caching can significantly improve response time of flow services. For example, flow services that retrieve information from busy data sources such as high-traffic commercial web servers could benefit from caching.

Note
The Caching feature in Flow services is available upon request for a tenant. Contact IBM support.

When are Cached Results Returned?

When you enable caching for a flow service, IBM webMethods Integration manages the cached results differently, depending on whether the integration has input parameters. It is recommended that a cached flow service has input parameters.

When a cached flow service has input parameters, at run time IBM webMethods Integration scopes the pipeline down to only the declared input parameters of the flow service. IBM webMethods Integration compares the scoped-down inputs to the previously stored copy of the inputs. If a cached entry exists with input parameters that have the same values, IBM webMethods Integration returns the cached results from the previous invocation.

Note
If a cached entry with input parameter values that are identical to the current invocation does not exist in the cache, IBM webMethods Integration runs the service and stores the results in the cache.

When a cached flow service does not have input parameters (for example, date/time) and previous results do not exist in the cache, at run time IBM webMethods Integration runs the service and stores the results. When the flow service runs again, IBM webMethods Integration uses the cached copy. In other words, IBM webMethods Integration does not use the run-time pipeline for the current invocation; you will always receive cached results until the cache expires.

Points to Note

Types of Flow services to Cache

While caching the flow service results can improve performance, not all flow services must be cached. You must never cache the flow services if the cached results might be incorrect for subsequent invocations or if the flow service performs tasks that must be run each time the flow service is invoked. Following are guidelines for you to consider when determining whether to cache the results for a flow service.

Flow services Suited for Caching

Flow services Not Suited for Caching

Enabling Caching

  1. Open the flow service that you want to cache.

  2. Click the ellipsis icon () available on the flow service steps page and click Settings from the displayed menu. The Settings dialog box appears.

  3. Drag the Enable/disable cache switch to right to enable the cache. The default value is Disabled.

  4. Enter the number of minutes that the flow service results must be stored in cache in the Cache expire field. The default value is 15 minutes. The expiration timer begins when the server initially caches the results. The server does not restart the expiration timer each time it retrieves the results from cache. The minimum cache expiration time is one minute.

  5. Click Done. The flow service page appears.

  6. Save and run the flow service. If the flow service runs successfully, the results are stored in cache. Otherwise, the results are not cached.

    Note
    • You can clear cache for any flow service using the Clear cache option available on the respective flow service card.

Document Types

What is a document type?

A document type contains a set of fields used to define the structure and type of data in a document. You can use a document type to specify the input or output parameters for a flow service. Input and output parameters are the names and types of fields that a flow service requires as input and generates as output. These parameters are collectively referred to as a signature.

For example, a flow service takes two string values, an account number (AcctNum ) and a dollar amount (OrderTotal ) as inputs and produces an authorization code (AuthCode ) as the output. If you have multiple flow services with identical input parameters but different output parameters, you can use a document type to define the input parameters rather than manually specifying individual input fields for each flow service.

Benefits of creating a document type

Document types provide the following benefits:

How do I create a document type?

You can create a document type in the following ways from Projects > select a project > Configurations > Flow service > Document Types > Add Document Type:

Build from scratch

Create an empty document type and define the structure of the document type yourself by inserting fields to define its contents and structure. For more information, see Creating Document Types from Scratch.

Build from XML Schema Definition

Create a document type from an XML Schema Definition. The structure and content of the document type matches that of the source file. For more information, see Creating Document Types from an XML Schema Definition.

You can also create document types for already created REST connectors from Projects > select a project > Connectors > REST > Document Types option or from the Request Body and Response Body panels while creating a REST connector.

Document types created for a REST connector do not appear in the Projects > select a project > Configurations > Flow service > Document Types page but appears in the Document Types panel for the selected REST connector.

Note
  • Creation of document type with identical names are not allowed.

  • Copying or pasting data fields from document types is only allowed in flow services, not in deploy anywhere flow services.

  • You can copy a document type from the Document Types page or from the Document Type page for a REST connector. Currently you cannot copy a document type across projects. When you copy a flow service or a Workflow across projects, the document type associated with it is also copied.

  • If a document type is used in any other document type or a flow service, you cannot delete the document type and a warning message appears as follows:

Other than direct dependencies, if there are document types that are created along with the selected document type from the same xsd source, and if any of these documents types are used in any flow services or document types (other than these generated document types), then also you are not allowed to delete the document type.

Build from SAP®

Create a document type from an SAP RFC structure or SAP IDoc, that matches the structure of the document and content of the SAP RFC structure or SAP IDoc respectively. For more information, see Creating a new Document Type from SAP®.

Creating Document Types from Scratch

Creating a document type from scratch allows you to create an empty document type, and specify the structure of the document type by inserting fields to define its contents and structure.

To add or edit a document type from scratch

1.From the IBM webMethods Integration navigation bar, click Projects. Select a project and click Configurations > Flow service > Document Types. From the Document Types page, you can add, edit, delete, or copy a document type. To edit an existing document type, on the Document Types page, click the Edit icon for the document type.

2.To create a new document type from scratch, from the Document Types page, click Add Document Type > Build from scratch.

3.Provide a name and description of your document type. Required fields are marked with an asterisk on the page.

4.Click Load XML to generate a document type from the XML structure or click Load JSON to generate a document type from the JSON structure.

5.Click the icon to add a new field and update the field properties.

Provide the Name and Type of the field to define the structure and content of the document type. The type can be a String, Document, Document Reference, Object, Boolean, Double, Float, Integer, Long, or Short. If you select the Type as Document Reference, select a Document Reference. Types are used to declare the expected content and structure of the signatures, document contents, and pipeline contents.

Allow Null: Values determines whether a field can accept null values. Set one of the following values:

- **Yes**: When you want the field to accept null values, allowing optional data to be present without a value.

- **No**: When the field is mandatory and cannot accept null values, ensuring the field always has a value.

If you select the Type as String, in the Display Type field, select Text Field if you want the input entered in a text field. Select Password if you want the input entered as a password, with asterisks reflected instead of characters. Select Large Editor if you want the input entered in a large text area instead of a text field. This is useful if you expect a large amount of text as input for the field, or you need to have new line characters in the input. In the Pick List field, define the values that will appear as choices when IBM webMethods Integration prompts for input at run time.

In addition to specifying the name and type of the field, and whether the type is an Array, you can set properties that specify an XML Namespace and indicate whether the field is required at runtime by selecting the Required field option. Select the Content Type you can apply to String, String list, or String table variables. See Content Types and Variable Constraints for information.

You can add a field from the fields panel by clicking the duplicate field icon. You can also copy a field from the fields panel and depending on the context, you can either paste the field or the field path. For example, if you copy a field and paste the field in the Set Value window in a flow service, the field path will be pasted. If you copy an array item, the path that is pasted includes the item index. You cannot modify or paste the child fields of a Document Reference. When defining a document type, it is recommended to avoid adding identically named fields to the document. In particular, do not add identically named fields that are of the same data type.

You can assign an XML namespace and prefix to a field by specifying a URI for the XML namespace property and by using the prefix:fieldName format for the field name. For example, suppose a field is named eg:account and the XML namespace property is set to http://www.example.com. The prefix is eg, the localname is account, and the namespace name is http://www.example.com.

Keep the following points in mind when assigning XML namespaces and prefixes to a field:

Note
When you edit a document type, any change is automatically propagated to all flow services that use or reference the document type.

Creating Document Types from an XML Schema Definition

Let us see how to create a document type from an XML Schema Definition with the help of an example. We will create a document type from an XML Schema Definition and then use the document type to create Accounts in Salesforce CRM.

1.Log in to your tenant and from the IBM webMethods Integration navigation bar, click Projects. Select a project and then select Configurations > Flow service > Document Types. From the Document Types page, you can add, edit, delete, or copy a document type. To edit an existing document type, on the Document Types page, click the Edit icon for the document type.

2.To create a new document type from an XML Schema Definition, from the Document Types page, click Add Document Type > Build from XML Schema Definition.

3.Provide a name and description of your document type, for example, customerOrder. Required fields are marked with an asterisk on the page.

4.On the Source selection panel, under XML schema source, do one of the following to specify the source file for the document type:

Note
The maximum file upload size is 5 MB which includes the primary source file and additional files, if any.

5.Click Next and on the Processing options panel, under Content model compliances, select a content model compliance to indicate how strictly IBM webMethods Integration represents content models from the XML Schema Definition in the resulting document type. Let us select None.

6.You can specify whether IBM webMethods Integration enforces strict, lax, or no content model compliance when generating the document type. Content models provide a formal description of the structure and allowed content for a complex type. The type of compliance that you specify can affect whether IBM webMethods Integration generates a document type from a particular XML Schema Definition successfully. Currently, IBM webMethods Integration does not support repeating model groups, nested model groups, or the any attribute. If you select strict compliance, IBM webMethods Integration does not generate a document type from any XML Schema Definition that contains those items.

Select… To…
Strict Generate the document type only if IBM webMethods Integration can represent the content models defined in the XML Schema Definition correctly. Document type generation fails if IBM webMethods Integration cannot accurately represent the content models in the source XML Schema Definition. Currently, IBM webMethods Integration does not support repeating model groups, nested model groups, or any attribute. If you select strict compliance, IBM webMethods Integration does not generate a document type from any XML Schema Definition that contains those items.
Lax When possible, generate a document type that correctly represents the content models for the complex types defined in the XML Schema Definition. If IBM webMethods Integration cannot correctly represent the content model in the XML Schema Definition in the resulting document type, IBM webMethods Integration generates the document type using a compliance mode of None. When you select lax compliance, IBM webMethods Integration generates the document type even if the content models in the XML Schema Definition cannot be represented correctly.
None Generate a document type that does not necessarily represent or maintain the content models in the source XML Schema Definition.

7.If you select strict or lax compliance, do one of the following to specify whether document types generated contain multiple *body fields to preserve the location of text in instance documents.

8.If you want IBM webMethods Integration to use the Xerces parser to validate the XML Schema Definition, select the Validate schema using Xerces check box.

Note
IBM webMethods Integration automatically uses an internal schema parser to validate the XML Schema Definition. However, the Xerces parser provides more strict validation than the internal schema parser. As a result, some schemas that the internal schema parser considers to be valid might be considered invalid by the Xerces parser.

9.Click Next and on the Select root nodes panel, select the elements that you want to use as the root elements for the document type. The resulting document type contains all of the selected root elements as top-level fields in the generated document type.

10.Click Save.

IBM webMethods Integration creates the document type.

Note
You can modify the document type by clicking the Edit icon. However, the Edit action is not recommended as the edited document type asset cannot be reverted to the original state. For example, if you change any field name such as Area to Province you cannot reset it to Area again.

Also, you can see that other document types are created automatically from the same xsd source file. This is because if an element in the XML Schema Definition is a complex type, IBM webMethods Integration creates the document type that defines the structure of the above complex type automatically, along with the main document type. For example, in the below EmployeeDetails.xsd file, the field address is a complex type containing Doorno, street, city, and pincode as its fields.

Then two document types are created when we create the document type with this xsd source. One document type is the main document type, Employeedetails and the other document type is docTypeRef_AddressType, which represents the structure of the complex type.

Note
  • If you have selected strict compliance and IBM webMethods Integration cannot represent the content model in the complex type accurately, IBM webMethods Integration does not generate any document type.

  • If you have selected lax compliance and indicated that IBM webMethods Integration should preserve text locations for content types that allow mixed content (you selected the Preserve text position check box), IBM webMethods Integration adds *body fields in the document type only if the complex type allows mixed content and IBM webMethods Integration can correctly represent the content model declared in the complex type definition. If IBM webMethods Integration cannot represent the content model in a document type, IBM webMethods Integration adds a single *body field to the document type.

  • If the XML Schema Definition contains an element reference to an element declaration whose type is a named complex type definition (as opposed to an anonymous complex type definition), IBM webMethods Integration creates a document type for the named complex type definition only if it is referred multiple times in the schema.

  • IBM webMethods Integration uses the prefixes declared in the XML Schema or the ones you specified as part of the field names. Field names have the format prefix:elementName or prefix:@attributeName.

  • If the XML Schema does not use prefixes, IBM webMethods Integration creates prefixes for each unique namespace and uses those prefixes in the field names. IBM webMethods Integration uses “ns” as the prefix.

  • If the XML Schema Definition contains a user-specified namespace prefix and a default namespace declaration, both pointing to the same namespace URI, IBM webMethods Integration uses the user-specified namespace prefix and not the default namespace.

  • If the namespace prefix in the XML Schema and the default namespace point to the same namespace URI, IBM webMethods Integration gives preference to the user-specified namespace prefix over the default namespace.

11.Now let us use the document type customerOrder to create Accounts in Salesforce CRM.
Go to the Flow services page, click the + icon to create a new flow service, and then provide a name CreateAccountsDocType and description of the flow service.

Click the I/O icon as shown above, and define the input and output fields. Select the document reference and save it.

12.Select Salesforce CRM and link the SalesforceCRM_1 account.

13.Click the mapping icon and map the input and output fields.

14.Close the mapping panel by clicking the icon, click the run icon and enter the input values.

15.Click Run and inspect the results.

Content Types

The following table identifies the content types you can apply to String or String list variables. Each of these content types corresponds to a built-in simple type defined in the specification XML Schema Part 2: Datatypes.

Content Types Description
anyURI A Uniform Resource Identifier Reference. The value of anyURI may be absolute or relative. Constraining Facets
enumeration, length, maxLength, minLength, pattern
Note: The anyURI type indicates that the variable value plays the role of a URI and is defined like a URI. URI references are not validated because it is impractical for applications to check the validity of a URI reference.
base64Binary Base64-encoded binary data. Constraining Facets
enumeration, length, maxLength, minLength, pattern
boolean True or false. Constraining Facets
pattern
Example
true, 1, false, 0
byte A whole number whose value is greater than or equal to –128 but less than or equal to 127. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
-128, -26, 0, 15, 125
date A calendar date from the Gregorian calendar. Values need to match the following pattern: CCYY-MM-DD
Where CC represents the century, YY the year, MM the month, DD the day. The pattern can include a Z at the end to indicate Coordinated Universal Time or to indicate the difference between the time zone and coordinated universal time.
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
1997-08-09 (August 9, 1997)
dateTime A specific instant of time (a date and time of day). Values need to match the following pattern: CCYY-MM-DDThh:mm:ss.sss
Where CC represents the century, YY the year, MM the month, DD the day, T the date/time separator, hh the hour, mm the minutes, and ss the seconds. The pattern can include a Z at the end to indicate Coordinated Universal Time or to indicate the difference between the time zone and Coordinated Universal Time.
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
2000-06-29T17:30:00-05:00 represents 5:30 pm Eastern Standard time on June 29, 2000. (Eastern Standard Time is 5 hours behind Coordinated Universal Time.)
decimal A number with an optional decimal point. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
8.01, 290, -47.24
double Double-precision 64-bit floating point type. Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example 6.02E23, 3.14, -26, 1.25e-2
duration A length of time. Values need to match the following pattern: PnYnMnDTnHnMnS
Where nY represents the number of years, nM represents the number of months, nD is the number of days, T separates the date and time, nH the number of hours, nM the number of minutes and nS the number of seconds. Precede the duration with a minus (-) sign to indicate a negative duration.
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
P2Y10M20DT5H50M represents a duration of 2 years, 10 months, 20 days, 5 hours, and 50 minutes
ENTITIES Sequence of whitespace-separated ENTITY values declared in the DTD. Represents the ENTITIES attribute type from the XML 1.0 Recommendation. Constraining Facets
enumeration, length, maxLength, minLength
ENTITY Name associated with an unparsed entity of the DTD. Represents the ENTITY attribute type from the XML 1.0 Recommendation. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
float A number with a fractional part. Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
8.01, 25, 6.02E23, -5.5
gDay A specific day that recurs every month. Values must match the following pattern: —DD
Where DD represents the day. The pattern can include a Z at the end to indicate Coordinated Universal Time or to indicate the difference between the time zone and Coordinated Universal Time.
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
---24 indicates the 24th day of each month
gMonth A Gregorian month that occurs every year. Values must match the following pattern: –MM
Where MM represents the month. The pattern can include a Z at the end to indicate Coordinated Universal Time or to indicate the difference between the time zone and Coordinated Universal Time.
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
--11 represents November
gMonthDay A specific day and month that recurs every year in the Gregorian calendar. Values must match the following pattern: –MM-DD
Where MM represents the month and DD represents the day. The pattern can include a Z at the end to indicate Coordinated Universal Time or to indicate the difference between the time zone and Coordinated Universal Time.
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
--09-24 represents September 24th
gYear A specific year in the Gregorian calendar. Values must match the following pattern: CCYY
Where CC represents the century, and YY the year. The pattern can include a Z at the end to indicate Coordinated Universal Time or to indicate the difference between the time zone and Coordinated Universal Time.
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
2001 indicates the year 2001.
gYearMonth A specific month and year in the Gregorian calendar. Values must match the following pattern: CCYY-MM
Where CC represents the century, YY the year, and MM the month. The pattern can include a Z at the end to indicate Coordinated Universal Time or to indicate the difference between the time zone and Coordinated Universal Time
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
2001-04 indicates April 2001.
hexBinary Hex-encoded binary data. Constraining Facets
enumeration, length, maxLength, minLength, pattern
ID A name that uniquely identifies an individual element in an instance document. The value for ID needs to be a valid XML name. The ID datatype represents the ID attribute type from the XML 1.0 Recommendation. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
IDREF A reference to an element with a unique ID. The value of IDREF is the same as the ID value. The IDREF datatype represents the IDREF attribute type from the XML 1.0 Recommendation. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
IDREFS Sequence of white space separated IDREFs used in an XML document. The IDREFS datatype represents the IDREFS attribute type from the XML 1.0 Recommendation. Constraining Facets
enumeration, length, maxLength, minLength
int A whole number with a value greater than or equal to -2147483647 but less than or equal to 2147483647. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
-21474836, -55500, 0, 33123, 4271974
integer A positive or negative whole number. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
-2500, -5, 0, 15, 365
language Language identifiers used to indicate the language in which the content is written. Natural language identifiers are defined in IETF RFC 1766. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
long A whole number with a value greater than or equal to -9223372036854775808 but less than or equal to 9223372036854775807. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
-55600, -23, 0, 256, 3211569432
Name XML names that match the Name production of XML 1.0 (Second Edition). Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
NCName Non-colonized XML names. Set of all strings that match the NCName production of Namespaces in XML. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
negativeInteger An integer with a value less than or equal to –1. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
-255556, -354, -3, -1
NMTOKEN Any mixture of name characters. Represents the NMTOKEN attribute type from the XML 1.0 Recommendation. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
NMTOKENS Sequences of NMTOKENS. Represents the NMTOKENS attribute type from the XML 1.0 Recommendation. Constraining Facets
enumeration, length, maxLength, minLength
nonNegativeInteger An integer with a value greater than or equal to 0. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
<br> 0, 15, 32123
nonPositiveInteger An integer with a value less than or equal to 0. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits, whiteSpace
Example
-256453, -357, -1, 0
normalizedString Represents white space normalized strings. Set of strings (sequence of UCS characters) that do not contain the carriage return (#xD), line feed (#xA), or tab (#x9) characters. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
Example
MAB-0907
positiveInteger An integer with a value greater than or equal to 1. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
1, 1500, 23000
short A whole number with a value greater than or equal to -32768 but less than or equal to 32767. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
-32000, -543, 0, 456, 3265
string Character strings in XML. A sequence of UCS characters (ISO 10646 and Unicode). By default, all white space is preserved for variables with a string content constraint. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
Example
MAB-0907
time An instant of time that occurs every day. Values must match the following pattern: hh:mm:ss.sss
Where hh indicates the hour, mm the minutes, and ss the seconds. The pattern can include a Z at the end to indicate Coordinated Universal Time or to indicate the difference between the time zone and Coordinated Universal Time.
Constraining Facets
enumeration, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern
Example
18:10:00-05:00 (6:10 pm, Eastern Standard Time) Eastern Standard Time is 5 hours behind Coordinated Universal Time.
token Represents tokenized strings. Set of strings that do not contain the carriage return (#xD), line feed (#xA), or tab (#x9) characters, leading or trailing spaces (#x20), or sequences of two or more spaces. Constraining Facets
enumeration, length, maxLength, minLength, pattern, whiteSpace
unsignedByte A whole number greater than or equal to 0, but less than or equal to 255. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
0, 112, 200
unsignedInt A whole number greater than or equal to 0, but less than or equal to 4294967295. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
0, 22335, 123223333
unsignedLong A whole number greater than or equal to 0, but less than or equal to 18446744073709551615. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
0, 2001, 3363124
unsignedShort A whole number greater then or equal to 0, but less than or equal to 65535. Constraining Facets
enumeration, fractionDigits, maxExclusive, maxInclusive, minExclusive, minInclusive, pattern, totalDigits
Example
0, 1000, 65000

Customizing a String Content Type

Instead of applying an existing content type or simple type to a String or String list, you can customize an existing type and apply the new, modified type to a variable. You can customize a content type or simple type by changing the constraining facets applied to the type.

When you customize a type, you actually create a new content type. The constraining facets you can specify depend on the content type. Note that content types and constraining facets correspond to datatypes and constraining facets defined in XML Schema. For more information about constraining facets for a datatype, see the specification XML Schema Part 2: Datatypes (http://www.w3.org/TR/xmlschema-2/).

To customize a content type

1.Select the variable to which you want to apply a customized content type and click the edit icon.

2.Click the Content type drop-down arrow and then in the Content type list, select the content type you want to customize. The constraining facet fields below the Content type list are made available for data entry.

3.In the fields below the Content type field, specify the constraining facet values you want to apply to the content type and click Save.

Note
The constraining facets displayed below the Content type list depend on the primitive type from which the simple type is derived. Primitive types are the basic data types from which all other data types are derived. For example, if the primitive type is string, the constraining facets Enumeration, Length, Minimum Length, Maximum Length, Whitespace, and pattern are displayed. For more information about primitive types, see XML Schema Part 2: Datatypes at http://www.w3.org/TR/xmlschema-2/.

Variable Constraints

You apply content constraints to variables in the document types that you want to use as blueprints in data validation. Content constraints describe the data a variable can contain. At validation time, if the variable value does not conform to the content constraints applied to the variable, the validation engine considers the value to be invalid.

When applying content constraints to variables, do the following:

Select a content type: A content type specifies the type of data for the variable value, such as string, integer, boolean, or date. A content type corresponds to a simple type definition in a schema.

Set constraining facets: Constraining facets restrict the content type, which in turn, restrict the value of the variable to which the content type is applied. Each content type has a set of constraining facets. For example, you can set a length restriction for a string content type, or a maximum value restriction for an integer content type.

For example, for a String variable named itemQuantity, specify a content type that requires the variable value to be an integer. You could then set constraining facets that limit the content of itemQuantity to a value between 1 and 100.

The content types and constraining facets correspond to the built-in data types and constraining facets in XML Schema. The World Wide Web Consortium (W3C) defines the built-in data types and constraining facets in the specification XML Schema Part 2: Datatypes (http://www.w3c.org/TR/xmlschema-2).

Applying Constraints to a Variable

You can apply content constraints to variables in the document types that you want to use as blueprints in data validation.

To apply constraints to a variable

1.On the Document Types page, for a document type, click the Edit icon. Select a field and click the edit field icon to view the field properties panel.

You can apply constraints to the fields of a document type, and also the fields declared on the Input/Output page after you click the Define I/O option in a flow service. If the selected variable is a String or String list, and you want to specify content constraints for the variable, do the following:

If you want to use a content type that corresponds to a built-in simple type in XML schema, in the Content type list, select the type for the variable contents. To apply the selected type to the variable, click Save.

2.Repeat this procedure for each variable to which you want to apply the constraints in the document type and click Save.

Lock and Unlock Flow Services

IBM webMethods Integration allows you to manage a flow service during the development life cycle by auto locking. When you edit a flow service, it is automatically locked for you. This restricts multiple users from editing the flow service at the same time. After you edit a flow service and save the changes, you can exit the edit mode to unlock the flow service and make it available for other users.

If you are editing a flow service and if another user opens the flow service, then that user sees the following message.

A flow service cannot be edited in view mode.

After you edit a flow service and save the changes, the other user sees the following message:

If you are editing a flow service and another user tries to delete the flow service, the other user sees the following message:

If you have kept the user session idle for quite sometime or because of any other issues a flow service lock remains and is not resolved, then only a user with Admin role can unlock the flow service and make it available for editing.

To unlock a flow service, click the ellipsis icon available on a flow service and select Unlock.

If the Admin unlocks the flow service, all editing permissions are automatically revoked for the user who has locked the flow service, and any unsaved changes will be lost. The following message appears after the Admin unlocks the flow service:

Further, all users who are currently editing or viewing the flow service, see the following message:

Version Management of Flow services

IBM webMethods Integration allows you to view the version history of a flow service. Click the ellipsis icon and select the Version history option available on the flow services tool bar panel to view the version history.

When you save a flow service, a new version is added to the Version History with the default commit message. You can also provide a custom commit message by clicking the drop-down arrow beside the Save option and selecting Save with message.
You can click on any version on the Version history panel and view the corresponding flow service version.
To restore an earlier version, select the earlier version of the flow service, and click the Restore icon .
If you have reverted to an earlier version and there is a scheduled execution for the flow service, the reverted version runs as per the defined schedule.

Note
  • If a flow service references any other flow service, then the pipeline mapping of the referenced flow service is also restored to that particular version. But if the pipeline mapping of the referenced flow service has been modified in a later version, the modification might break the mappings and the flow service execution will not be successful.
  • If a flow service references any document types, reference data, custom operations, REST connectors, and SOAP connectors, and if those references have been modified, then those references will not be restored.
  • If you delete a flow service and then create another flow service with the same name, the version history of the deleted flow service will be available.

Debug Flow services

You can debug a flow service and can inspect the data flow during the debugging session. The flow service gets automatically saved when you start the debug session.

You can do the following in debug mode:

To start the Debug session, from the Flow services page, select a flow service, insert the breakpoints, and then click the Debug icon . The debug session halts at the first step even if you have not inserted a breakpoint.

If you have defined input fields for the flow service, the Input Values dialog box appears where you can specify the input values, else the Debug panel appears if no input fields are defined.

Note
  • If you have not defined any input fields or if there are no pipeline output variables, then while debugging, a message appears as the pipeline is empty. Further, if you disable a step, that step will not be considered while debugging. The Flow service Execution page (Monitor > Flow service Execution) as well as the Execution History page do not display any execution logs for a debug session.
  • If a flow service has a child flow service, IBM webMethods Integration will not step into the child flow service during a debug session.

The following table describes the options available while debugging the flow service:

Icon Applicable for… Action/Description
Insert Breakpoints Insert a breakpoint in a flow service by clicking on the step number.
To remove a breakpoint, click on the step number where the breakpoint is inserted.
Breakpoints are recognized only when you run a flow service in debug session.
A breakpoint is a point where you want processing to pause when you debug the flow service. Breakpoints can help you isolate a section of code or examine data values at a particular point in the execution path. For example, you might want to set a pair of breakpoints before and after a particular step, so that you can examine the pipeline before and after that step executes.When you run a flow service that contains a breakpoint, the flow service is executed up to, but not including the designated breakpoint.
Icon Applicable for… Action/Description
Disable Breakpoints Ignores all breakpoints inserted in the flow service steps.
Icon Applicable for… Action/Description
Enable Breakpoints Enables all breakpoints inserted in the flow service steps.
Icon Applicable for… Action/Description
Resume Resumes the debug session but pauses at the next breakpoint.
Icon Applicable for… Action/Description
Stop Terminates the debug session. A debug session might also stop by itself for the following reasons:
- The flow service that you are debugging executes to completion (error or success).
- You select Step over for the last step in the flow service.
- You Exit the flow service.
Icon Applicable for… Action/Description
Restart Restarts the debug session from the first step.
Icon Applicable for… Action/Description
Step over Executes the flow service on a step-by-step basis. For conditional controls:
- Conditions are evaluated
- If values are true, then the steps inside it are executed on the next step over.
Icon Applicable for… Action/Description
Clear all breakpoints Removes all breakpoints inserted in the flow service.
Icon Applicable for… Action/Description
Close Closes the Debug panel and goes back to the flow service.

Modifying the current pipeline data while debugging

While debugging, you can modify the contents of the pipeline by clicking on the field values as shown below. The changed values are not applied on the current step but on successive steps when you do a Step over or Resume.

While modifying the pipeline, keep the following points in mind:

Note
While running or debugging flow services and testing operations, if the input has any duplicate keys, or if the service returns an output with duplicate keys, you can view those keys.

Restart and Resume Flow services

IBM webMethods Integration allows you to restart or resume failed Flow service executions. If an execution fails, you can resume that execution from the point where it had failed. Resuming an execution does not execute the previously successful operations but executes only the failed operations and operations that are not yet executed. When a flow service execution is restarted, the execution occurs from the beginning.

Note
  • The Restart and Resume options are available upon request for a tenant. Contact IBM support.
  • The Restart and Resume options are not available for flow services created through Swagger (REST APIs) and WSDL (SOAP APIs).
  • If a flow service is invoked through a Messaging subscriber then the Restart and Resume options are not applicable.

The following table provides information on when you can restart or resume a flow service execution:

Execution Result Status Restartable Resumable
Successful Executions Yes No
Failed Executions Yes Yes
Completed with Errors Yes No
Running Executions No No
Note
  • You can restart one or multiple flow services as per your requirements.

  • If a flow service has only the restart capability enabled, resuming it from the flow service Executions listing page will also trigger a restart of the execution instead of resuming from the point it failed in the previous run.

  • The flow service executions list displays two buttons in the Actions column for the relevant execution: Restart and Resume.

How to restart a single Flow service

  1. From the IBM webMethods Integration navigation bar, click Projects. Select a project and then select Flow services.

  2. Click the ellipsis icon available on the flow service and select Overview.

  3. On the Overview page, select the Enable Flow service to be restarted option. If the flow service is updated, you cannot restart its executions that have occurred before the update.

    Further, flow services using Operations and other flow services, which have fields of type Object in their signature, may not execute properly when restarted or resumed.

  4. Select the flow service and run it.

  5. Provide the input values, if needed, and then click Run.

  6. Go to the Monitor > Execution Results > Flow service Execution page. Click on the execution log and on the execution details page, click the Restart option. Alternatively, you can also restart the execution from the Monitor page. Click on the Restart button displayed in the Actions column.

    Note
    The Flow Service Executions listing screen on the Monitor page displays two buttons named Restart and Resume in the Actions column. If a flow service has only the restart capability enabled, resuming it from the Flow Service Executions listing page will also trigger a restart of the execution instead of resuming from the point it failed in the previous run.

  7. Provide the input values, and then click Run to restart the execution from the beginning.

How to resume a single Flow Service

  1. From the IBM webMethods Integration navigation bar, click Projects. Select a project and then select Flow services.

  2. Click the ellipsis icon available on the flow service and select Overview.

  3. On the Overview page, select the Enable Flow service to be resumed option. Enabling this option increases the execution time of a flow service. If the flow service is updated, you cannot restart or resume its executions that have occurred before the update.

    Further, flow services using Operations and other flow services, which have fields of type Object in their signature, may not execute properly when resumed.

  4. Select the flow service and run it.

  5. Provide the input values, if needed, and then click Run.

  6. Go to the Monitor > Execution Results > Flow service Execution page. Click on the execution log and on the execution details page, click the Resume option. Alternatively, you can also resume the execution from the Monitor page. Click on the Resume button displayed in the Actions column.

    Note
    The flow service Executions listing screen on the Monitor page displays two buttons named Restart and Resume in the Actions column. If a flow service has only the restart capability enabled, resuming it from the flow service Executions listing page will also trigger a restart of the execution instead of resuming from the point it failed in the previous run.
  7. Provide the input values, and then click Run to restart the execution from the beginning. Click the Resume option, edit the input data, and resume the execution from the point where it had failed in the previous run.

How to restart multiple flow services

You can select multiple successful or failed flow service executions to restart in just one click.

  1. From the IBM webMethods Integration navigation bar, click Projects. Select a project and then select Flow services.

  2. Click the ellipsis icon available on the flow service and select Overview.

  3. On the Overview page, select the Enable Flow service to be restarted option. Enabling this option increases the execution time of a flow service. If the flow service is updated, you cannot restart or resume its executions that have occurred before the update.
    Further, flow services using Operations and other flow services, which have fields of type Object in their signature, may not execute properly when restarted or resumed.

  4. In the Executions table, select the checkbox beside the name of successful or failed flow service and click the Restart button.


Note
  • While restarting multiple flow service executions, if one of the selected flow services fail, you will need to make necessary changes to the corresponding flow service from the canvas only. Editing the input data is not supported when you restart multiple flow services.
  • You can select a maximum of 150 flow service executions to restart at a time.

Invoke Flow services over HTTP

IBM webMethods Integration allows you to trigger the execution of a flow service from an external system. This option provides you with another way to trigger flow service executions from a software application, for example, a REST client, apart from manual and scheduled executions from the user interface.

On the external program, provide the HTTP URL, Method, required JSON body, and necessary header parameters, including the required security credentials (user name and password) to invoke the flow service. After the flow service is executed, the response contains the pipeline data.

How it Works

  1. Log in to your tenant and from the IBM webMethods Integration navigation bar, click Projects. Select a project and then click Flow services.

  2. Click the ellipsis icon available on a flow service and select Overview.

    The Overview page appears.

  3. On the Overview page, select the Enable Flow service to be invoked over HTTP option. Once the flow service is enabled to be invoked over HTTP, the HTTP request URL appears.

    Note
    When you enable the Invoke Flow service over HTTP option for a flow service, and clone, export, or import it, the option stays enabled in the cloned, exported, or imported flow service.
  4. Click the Advanced details section to view the HTTP Method, sample JSON input, and the parameters that are required to invoke the flow service from an external system.

Synchronous URL

You can execute flow services synchronously using the run URL:

https://sub-domain.domain/integration/rest/external/integration/run/stagename/integrationname

run - Flow service executes and the response contains the pipeline data.

sub-domain is a domain that is part of the primary domain.

run - Flow service executes and the response contains the pipeline data.

stagename is the name of the active stage.

integrationname is the name of the Flow service.

Note: You must provide your user name and password to execute the Flow service from the external program, else you may encounter the 401 - Unauthorized User Error.

Asynchronous URL

You can execute flow services asynchronously using the submit URL:

https://sub-domain.domain/integration/rest/external/integration/submit/stagename/integrationname

submit - Flow service has been submitted for execution and the response contains a status indicating whether the flow service has been submitted for execution. When the request is submitted for execution using the submit option, the response contains a reference to the execution result identifier so that a new HTTP call can be made later to get the execution results.

Application Status Codes for submit

To get the execution results, construct the URL of the new HTTP call from the URI field available in the Response section.

To construct the URL of the new HTTP call, add the response URI obtained from resultReference in the Response section to: https://sub-domain.domain.com

Response URI format: https://sub-domain.domain/integration/rest/external/integration/execution/result?resultReference=765733-6a21-4b02-864f-e958f698373

HTTP Status Codes

5.Download the Postman app (Windows 64-bit) from https://www.postman.com/downloads, install the app, and then sign-in to Postman.

6.On the Postman page, click Create a request.

7.On the Postman app Request page, select POST. Then copy the Synchronous URL from the IBM webMethods Integration flow service Overview page and paste it in the Enter Request URL field as shown below.

8.Go to the IBM webMethods Integration flow service Overview > Advanced details page and get the Content-Type and Accept header parameters.

9.Go to the Postman app Request page, click Headers, and enter the Content-Type and Accept values as shown below.

10.On the Postman app Request page, select POST, click Authorization, select the Type as Basic Auth, enter your IBM webMethods Integration login user name and password, and click Send as shown below.

The result appears in the Body section at the lower part of the Postman Request page. The execution result also appears on the IBM webMethods Integration flow service Execution History page and on the Monitor > Execution Results > Flow service Execution page under Execution Logs.

Private Service Access

Services can be exposed over the internet using HTTPS. Additionally, the capability to flag service invocation as private has been introduced, ensuring exclusive access for components within your tenant’s network, while external clients over the internet are restricted. This feature provides the advantage of enabling policy-enforced access to the service through API Gateway.

To enable private service invocation, you need to activate two options: Enable Flow service invocation over HTTP and Enable private invocation. The latter is only accessible when the former is selected. This configuration ensures that flow service invocation remains private, restricting access to components within your tenant’s network.

How Private Service Access Works

To enable private service invocation, following are the essential steps:

Before you begin

Enable private service invocation in flow service

  1. Log in to your tenant and from the IBM webMethods Integration navigation bar, click Projects.

  2. Select a project and then click Flow services.

  3. Click the ellipsis icon available on a flow service and select Overview.

    The Overview page appears.

  4. On the Overview page, select the Enable Flow service invocation over HTTP option. Once the flow service is enabled to be invoked over HTTP, the private service URL appears.

  5. Select Enable private invocation option for a private mode.

After generating the URLs, the next step is to copy them in API Gateway to create an API.

Create and configure the API

  1. Click the APIs menu, click Create API, and select Create API from scratch option.

  2. Under API details, provide an API name, and then click Technical information option.

  3. In the Server URL field, enter the flow service domain name.

  4. Click Resources and methods option and click Add resources.

  5. Provide a Resource name, and under Resource path field, enter the resource location where the flow service can be accessed. So, the Resource path in this scenario will be:

    /integration/private/rest/external/integration/run/development/<project ID>/<flowservice-name>

Enable HTTPS protocol

Go to the Policies menu, click Edit, and select HTTPS checkbox under Protocol.

Define routing configurations

  1. Go to Routing. Under Endpoint URI, provide alias and resource path as inputs.

    • To enter alias as input, enter ${aliasname}.

    • To enter resource path as input, enter ${sys:resource_path}

    Set required HTTP Connection Timeout (maximum 5 minutes) and Read Timeout (maximum 5 minutes).

  2. Click Save.

Activate the API

  1. Click Activate and then confirm the activation action.

  2. Copy Gateway Endpoint URL

  3. Go to API details menu, scroll down to Gateway endpoint(s) section, and copy the endpoint.

    Use this URL to execute the associated private flow service by sending HTTP requests to it.

    Note
    If you have set any authentication method at the time of configuring the private service invocation, then ensure that you provide the necessary authentication details when sending the HTTP request.

Export Flow services

IBM webMethods Integration allows you to export flow services from the Flow services page. You can export flow services only if you have the required capability for exporting flow services. You can export a flow service from one tenant and import that flow service to another tenant.

How It Works

1.From the IBM webMethods Integration navigation bar, click Projects. Select a project and then click Flow services. The Flow services page appears.

2.Click the ellipsis icon available on the flow service and select Export. If a flow service you are exporting uses Document Types, SOAP, or REST Connectors, those components are also exported along with the flow service.

Note
If a flow service you are exporting has Reference Data, the Reference Data will not be exported along with the flow service.

The Confirm Export dialog box appears.

3.Click Export to export the flow service. The flow service is downloaded as a zip file to your default download folder. The zip file has the same name as that of the flow service. Do not modify the contents of the exported zip file. If you modify the contents of the zip file, the flow service cannot be imported back to IBM webMethods Integration.

Exporting a Flow service having an On-Premises Connector

After exporting a flow service that has an on-premises connector, if you want to import the flow service, then before importing the flow service, ensure that you upload the same on-premises connector to IBM webMethods Integration. Else you will not be able to import the flow service.

Skip All Dependencies

The Skip all dependencies option allows you to export or import only the parent flow service, excluding any associated dependent services, packages, or configurations. This option is useful in the following scenarios:

Using Skip Dependencies

  1. Go to Projects > Flow services.

  2. Select a flow service.

  3. Ensure the flow service references has at least one parent and child flow steps, as shown in the illustration that follows:

  4. Click Export.

  5. In the Export flow service page, select Skip all dependencies to deselect the dependency services. Skipped dependencies appear under the Flow service name pane.

  6. Click Export.

    The zip file is saved to your local drive’s default download folder, allowing you to use it to import assets into the same or different tenants.

    Note
    Ensure that all required dependencies are available in the target environment for proper functionality when using Skip all dependencies.

Import Flow services

IBM webMethods Integration allows you to import flow services from a zip file that was earlier exported from IBM webMethods Integration. You can export flow services from one tenant and import those flow services to another tenant. You can import flow services provided you have the required capability.

Note
If you want to import a flow service that has an on-premises connector, before importing the flow service, ensure that you upload the same on-premises connector to IBM webMethods Integration, else you will not be able to import the flow service.

How It Works

1.From the IBM webMethods Integration navigation bar, click Projects. Select a project and then click Flow services. The Flow services page appears.

2.Click Import and select the zip file that contains the exported flow service.

While importing a flow service, if a dependent flow service conflicts with an existing flow service in the same project, you can:

Points to Consider when Importing Flow Services

Best Practices for Flow Services

Troubleshooting Tips

Handling Export errors with invalid constructs

The errors that are preventing the successful export of the flow service.

Error

This operation cannot be performed as Integrations <flow-name> are in inconsistent state.

Use case

Consider a scenario where you have a complex flow service that includes child flows and reference data.

Some of these components might have invalid constructs. These are marked with a red circle to highlight the issues.

Exporting the flow service without resolving the highlighted steps leads to an export failed error when attempting to export the flow service.

Resolution

To resolve the error, follow these steps:

If you still find issues, consider renaming and adding the reference data on your own.

Publish-Project errors with invalid constructs

This section addresses the challenges faced when attempting to publish complex flow services in a project, including parent flows, child flows, and reference data.

Error

Operation cannot be performed as Integrations <flow-name> are in an inconsistent state.

Use Case

Consider a scenario where you have a complex flow, which includes parent and child flows, along with reference data. For example,

Some of these components have invalid constructs. These are marked with a red circle to highlight the issues.

While attempting to publish this flow, you encounter the aforementioned error.

Resolution

To resolve the error, follow these steps:

Once all dependencies are appropriately resolved, attempt to publish the flow once more.

Handling large payloads and performance optimization

The flow service encountered performance issues when processing large datasets, especially when iterating datasets with over 32,000 elements. The issue occurred due to the following two problems:

Problem 1: Variable persistence in child flows

Use case

When invoking a child flow within a parent flow, variables from the parent flow are carried over to the child flow, causing unexpected behavior and potential performance issues.

Example
Parent flow invokes a child flow without dropping the variable document, which is used in both the flows.

In the child flow, document variable persists, leading to unintended iterations and errors in conditional logic. When input data is improper, the repeat loop fails to run, resulting in unexpected behavior.

Error

There is no error message displayed, yet the child flows fail to run properly due to the persistence of the document variable.

Resolution

Problem 2: Inefficient handling of large payloads

Use case

Attempt to convert a huge dataset (over 32,000 rows) to string format using loops. The problem resulted from the use of a loop method to iterate through each element in the document list, with mapping and operations being conducted independently. Even after implementing optimizations such as addItemToVector and vectorToArray, the loop’s execution time remained around two minutes.

Error

There is no error message displayed, yet the services took longer time than expected.

Resolution

Additional headers were observed when running a REST application

When a REST application flow service is run with changed header attributes, sw6 headers may be observed in the pipeline output result.

Note that sw6 is a valid request header used by End-to-End Monitoring for monitoring IBM product runtimes. This has no impact on feature functionalities.

Assets Supported in Flow Services

All assets that can be used with workflows and flow services can be cloned, exported, imported, published, and deployed. These functions are helpful when migrating, promoting, or copying the existing flows.

The following table lists the functions that are supported in the current product version for flow service:

Feature Clone Export and Import Publish and Deploy
Flow service with Predefined connectors Yes Yes Yes
Flow service with Custom CloudStreams connectors Yes Yes Yes
Flow service with REST connectors Yes Yes Yes
Flow service with SOAP connectors Yes Yes Yes
Flow service with On-Premise connectors Yes Yes Yes
Flow service with Flatfile connectors Yes Yes Yes
Flow service with connectors (For example, SFTP/FTP/PGP/Cloud Container/SMTP/HTTP) Yes Yes Yes
Flow service with backend Node.js connectors (For example, MYSQL, Pusher) Yes Yes Yes
Flow service with CLI based Node.js connectors (For example, PubNub, Workspan, Weather Underground) Yes Yes Yes
Flow service with Adapters (For example, Database and SAP ERP) Yes Yes Yes
Flow service with Messaging Yes Yes Yes
Flow service with Reference data
Note: Reference data will not be exported or published, but the flow service can be exported or published.
Yes Yes Yes
Flow service with Document Types Yes Yes Yes