Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Note: This is a test setup on how to set up Invoice API in Schedule Flow

Note: The required batch size would be 60 only to prevent hitting a governor limit.

  1. Set up Flow

...

  • Create a Schedule Trigger Flow

...

  • Set Schedule

...

  • Select Object (ex. Opportunity)

Drag Get Records to the screen and select Gateway Account as Object and map the ID to the Opportunity Gateway Account

...

·        Drag Action to the Screen. To initiate a scheduled invoice generation, an Autolaunched Flow invoking the Invoice API invocable class should be created where the flow will be called in a Batch Job.

How to create an Autolaunched Flow invoking the Invoice API

Follow the steps on how to create an Autolaunched Flow invoking the Invoice API invocable class:

  1. Go to Setup.

  2. In the Quick Find box, search and select Flows.

  3. Click New Flow.

  4. In the New Flow modal, select Autolaunched Flow (No Trigger).

    Image Added
  5. Select a layout of your choice.

    Image Added
  6. Add a new input variable that will serve as the placeholder for each record to process. This input variable is necessary for the Batch Job creation.

    1. Click New Resource.

      Image Added
    2. Complete the following steps in the New Resource modal, and click Done:

      1. In the Resource Type, select Variable.

      2. Provide your desired API Name.

      3. In the Data Type, select Text.

      4. Make sure that the Available for input (under the Availability Outside the Flow) is TRUE.

        Image Added
  7. Add a Get Records element to retrieve the exact record where an invoice will be generated. For this example, we will be using Opportunity.

    1. Drag/Add the Get Records element onto the canvas.

      Image Added
    2. Complete the following steps in the New Get Records modal, and click Done:

      1. Make sure to provide the exact object of the record.

      2. Filter the records to be processed based on the stored record in the input variable

        Image Added
  8. Add a Get Records element to retrieve the Gateway Account of the retrieved record from the previous action as it will be necessary to generate an invoice.

    1. Drag/Add the Get Records element onto the canvas.

      Image Added
    2. Complete the following steps in the New Get Records modal, and click Done:

      1. Select Gateway Account as the Object.

      2. Filter the records to retrieve ONLY the Gateway Account of the to-be-processed record.

        1. Value = {!Get_Opportunity_Records.Gateway_Account__r.Id}

          Image Added
  9. Add an Action element to invoke the Invoice API invocable class.

    Image Added
    1. Complete the following steps in the New Action modal, and click Done:

      1. Filter by Type and select Apex Action.

        Image Added
      2. Find and select the Invoice API

...

·        Configure the apex action to pass the following Opportunity’s details to the invocable variables:

·   Gateway Account = Opportunity’s Gateway Account (custom field)

·   Amount = Opportunity’s Amount

·   Currency = Opportunity’s Currency

·   Token = Opportunity’s Payment Source (custom field) → Token

·   Relate Record To = Opportunity record ID

...

      1. invocable class.

        Image Added
      2. Provide the necessary details:

        1. Amount (required) = The amount of the record

        2. Currency (required) = The preferred currency to be used

        3. Gateway Account Record (required) = The Gateway Account of the record

        4. Related Record To (optional) = The record ID of the record you want to be linked in the Gateway Invoice. In this case, you can link the to-be-processed record to Gateway Invoice which will be created after the invoice generation.

        5. Related Record To - Field (optional) = The custom lookup field under the Gateway Invoice object

...

·        And Click Done

·   And after that, your flow should look like these

...

        1. that will be populated with the record ID of the linked record.

        2. Token (required) = The token that will be used in the payment processing during the invoice generation. You can use the Token from the Payment Source if your organization is using PosiPay’s Payment Source.

          1. Token = {!Get_Opportunity_Records.Payment_Source__r.PosiPay__Token__c}

            Image Added
  1. Save your Autolaunched Flow and make sure to activate it to be accessible in the Batch Job creation.

Create a Batch Job

Follow the steps on how to create a batch job

  1. Go to Setup.

  2. In the Quick Find box, search and select Batch Management.

  3. Click New.

  4. Enter some required data and click the autolaunch flow that’s been created a while ago and click Next. In next screen, select the recordId as Flow Input Variable and Opportunity as Object
    Note: The required batch size would be 60 only to prevent hitting the governor limit

...

  1. Click Save.

Create a Schedule Flow

Follow the steps on how to create a Scheduled-Triggered Flow

  1. Go to Setup.

  2. In the Quick Find box, search and select Flows.

  3. Click New Flow.

  4. In the New Flow modal, select Scheduled-Triggered Flow.

...

  1. Set the date, time, and frequency.

...

  1. Drag an action and find the batch name that you created a while ago in batch management and select it.

    image-20240910-234320.pngImage Added

    image-20240910-234337.pngImage Added

    7. Click Save and activate.

Next place to go : Step 6 - Schedule a Gateway Settlement