Dynamically Update Invoke Connections at Runtime

You can dynamically update the invoke connection to use at runtime. This feature lets you use a single integration to send requests to multiple end systems or instances of the same application and eliminates the need to create a separate integration for each endpoint or multiple invoke connections configured in a switch action in a single integration.

Dynamic Connection Capabilities

Dynamic connections provide the following capabilities.

  • Connections can be local to a project, shared between projects, or standalone (that is, available globally and not under the context of a project).
  • Each connection can be defined with different properties and security policies (including connectivity agent configurations). For example, an FTP over SSL invoke connection configured with the FTP Public Key Authentication security policy at design-time can be overridden at runtime by an sFTP connection configured with the FTP Server Access Policy security policy.
  • The runtime connection to use is defined by a property in the payload of the incoming message or through the result of a lookup table function.

    Note:

    Lookup table-based expressions are supported only in the design-time lookup wizard and not in the mapper at runtime.
  • For any invoke connection, you can specify an XPath expression or optionally a lookup table function result on the source payload. Once evaluated against the actual data, the value of the connection ID to use at runtime is provided for that particular invoke connection.
  • The invoke connection used dynamically can be tracked and monitored in the activity stream at runtime.

Configure and Use a Dynamic Connection

This example walks you through how to create and use a dynamic connection across two projects. You can also create and use dynamic connections in a single project or in standalone environments (that is, outside of projects).

For this example, two projects are created.


The Dyn Conn Project 2 and Dyn Conn Project 1 project names are shown, along with the type and last updated details.

Project Dyn Conn Project 2 consists of the following:
  • Integration dyn conn demo ftp e2e.
  • Connection FTP 138 Keybased Shared: This key-based connection (FTP Public Key Authentication) is shared across both projects. The use of this connection dynamically at runtime in Dyn Conn Project 1 is demonstrated in this section.
  • Connection FTP 147 Project 2: This is a user name/password-based connection (FTP Server Access Policy).
  • Connection FTP 138 Project 2: This is a user name/password-based connection (FTP Server Access Policy).
  • Connection Rest Trigger: This connection triggers the integration.


The Dyn Conn Project 2 project is shown. At the top are the Design, Deploy, and Observe buttons. To the right in the middle are two icons. At the far right are five icons. Below Design are Integration, Healthcare, and B2B icons. In the middle are the Integrations section and Connections section. The created integration and connections in this project are described above this image.

Project Dyn Conn Project 1 consists of the following:
  • Integration dyn conn demo ftp.
  • Connection FTP 138 Keybased: This connection references the shared key-based connection (FTP Public Key Authentication) in the Dyn Conn Project 2 project.
  • Connection FTP 147 Project 1: This is a user name/password-based connection (FTP Server Access Policy).
  • Connection FTP 138 Project 1: This is a user name/password-based connection (FTP Server Access Policy).
  • Connection Rest Trigger: This connection triggers the integration.


The Dyn Conn Project 1 project is shown. At the top are the Design, Deploy, and Observe buttons. To the right in the middle are two icons. At the far right are five icons. Below Design are Integration, Healthcare, and B2B icons. In the middle are the Integrations section and Connections section. The created integration and connections in this project are described above this image.

  1. In Dyn Conn Project 2, open the dyn conn demo ftp e2e integration for editing.

    Note that the FTP 138 Project 2 FTP Adapter invoke connection is being used in the design.


    The integration shown includes a trigger, map, invoke, and map. The cursor is hovering over the invoke action to show the type (FTP), endpoint name, and connection name (FTP 138 Project 2).

  2. Open this invoke connection for editing in the integration canvas.
  3. On the Basic Info page, click Continue.
  4. On the Dynamic Connections page, select Enable Dynamic Connection to specify a dynamic connection ID to use at runtime.

    The Dynamic Connection ID field is displayed.

  5. Click Switch to Developer View Switch view icon.
  6. Specify a dynamic connection ID in either of two ways.
    • Input sources: Click to pass the connection ID as an XPath expression with the dynamic-connection-id query parameter. The XPath expression evaluates to the connection ID of the dynamic invoke connection used at runtime.
    • Functions: Click to use a lookup table function to pass different connection IDs representing the different regions.

    For this example, the dynamic-connection-id XPath expression is dragged to the field.


    The integration is shown on the left side. The invoke connection is selected for editing. The Edit Dynamic Connections page is shown. The Input sources and Functions tabs are shown. The Input sources tree is expanded to show the dynamic-connection-id. To the right, the Enable Dynamic Connection check box is selected. Below this is the Dynamic Connection ID field, which is populated with the dynamic-connection-id XPath expression. Two icons appear to the right of this field.

  7. Save the updates.

    It's time to run the integration.

  8. Go to the Dyn Conn Project 1 project.
  9. Hover over the dyn conn demo ftp integration to run.
  10. From the Actions Actions icon menu, select Run.
  11. In the Body tab, upload the payload file to use (for this example, named sample.json).
  12. In the URI parameters tab, specify the following:
    • file-name: File name of the payload.
    • directory: Target directory in which to write the file.
    • dynamic-connection-id: FTP Adapter invoke connection to use dynamically at runtime. Begin typing letters to filter the display of invoke connections available for selection. For this example, FTP 138 Keybased is selected. This is the shared invoke connection on which you defined the dynamic XPath expression in Step 7. If you leave this field blank, the connection added at design time, and not a dynamic connection, is used.


      The Configure and run page is shown. The Run button appears at the top. The Request section is shown, which consists of the URI parameters (which is selected), Headers, Body, cURL, and Integration properties tabs. Below this are the file-name parameter and its value, the directory parameter and its value, and the dynamic-connection-id parameter and its value.

  13. Click Run.
  14. Expand the connection and wire message in the activity stream.

    A connection message indicates the dynamic connection was used instead of the design-time connection. The wire message identifies the connection ID used (FTP 138 Keybased) and connection type (ftp) used.


    The Configure and run page is shown. The Run button appears at the top. The Request section is shown, which consists of the URI parameters (which is selected), Headers, Body, cURL, and Integration properties tabs. Below this are the file-name parameter and its value, the directory parameter and its value, and the dynamic-connection-id parameter and its value.