Newer Version Available

This content describes an older version of this product. View Latest

Flow

Represents the metadata associated with a flow. With Flow, you can create an application that navigates users through a series of screens to query and update records in the database. You can also execute logic and provide branching capability based on user input to build dynamic applications.

Where possible, we changed noninclusive terms to align with our company value of Equality. We maintained certain terms to avoid any effect on customer implementations.

Important

For information about the corresponding UI-based flow building tool, see “Flow Builder” in Salesforce Help.

When using Metadata API to work with flows, consider that:
  • You can’t use Metadata API to access a flow installed from a managed package, unless the flow is a template.
  • Spaces in flow file names can cause errors at deployment. Heading and trailing spaces are allowed, but they’re trimmed during deployment.
  • When using Metadata API, you can deploy changes to active flows in specific situations.
    • The org isn’t a production org, for example, a scratch org or sandbox. The active flow is the latest version.
    • The org is a production org that enabled the Deploy processes and flows as active preference. The active flow is the latest version.
    After you deploy changes to an active flow, the flow’s detail page displays a new flow version that’s active. The new version includes your changes. For example, version 3 of myflow is active and the latest version. After you change and deploy version 3, the myflow’s detail page displays version 4 as active.
  • You can delete a flow version as long as it isn’t active and has no paused interviews. If the flow version has paused interviews, wait for those interviews to resume and finish, or delete them.

Don’t edit the metadata of retrieved Process Builder processes (Flow components whose processType is Workflow or InvocableProcess.) If you deploy process metadata that you edited, you might not be able to open the process in the target org.

Warning

Declarative Metadata File Suffix and Directory Location

Flows are stored in the Flow directory of the corresponding package directory. The file name matches the flow’s unique full name, and the extension is .flow.

Version

The flow Metadata API is available in API version 24.0 and later.

Flow

This metadata type represents a valid definition of a flow. This type extends the Metadata metadata type and inherits its fullName field.

Field Name Field Type Description
actionCalls FlowActionCall[] An array of nodes that define calls to actions. This field is available in API version 31.0 and later.
apexPluginCalls FlowApexPluginCall[] An array of nodes that define calls to Apex plug-ins.
assignments FlowAssignment[] An array of assignment nodes.
choices FlowChoice[] An array of static choice options.
constants FlowConstant[] An array of constants.
decisions FlowDecision[] An array of decision nodes.
description string Description of the flow.
dynamicChoiceSets FlowDynamicChoiceSet[] An array that constructs a set of choice options based on a database lookup.
environments FlowEnvironment (enumeration of type string) The environment in which the flow can run. Valid values are:
  • Default—The flow can run offline or from a Visualforce component, Lightning page, flow action, or custom Aura component.
  • Slack—The flow can run in Slack and the default environment. You specify the Slack flow environment when you save the flow.

This field is available in API version 55.0 and later.

formulas FlowFormula[] An array of formulas.
fullName string Required. Inherited from the Metadata component. Name of the file in Metadata API.

A unique name for the flow that contains only underscores and alphanumeric characters. The name must be unique across the org, begin with a letter, not include spaces, not end with an underscore, and not contain two consecutive underscores.

To deploy or retrieve a version, you can specify the version number. For example, sampleFlow-3 specifies version 3 of the flow whose unique name is sampleFlow. If you don’t specify a version number, the flow is the latest version.

In API version 43.0 and earlier, this field included the version number. In API version 44 and later, this field no longer includes the version number.

interviewLabel string Label for the interview. This label helps users and administrators differentiate interviews from the same flow.

In the user interface, this label appears in the Paused Flow Interviews component on the user’s Home tab and in the list of paused flow interviews in Setup.

isAdditionalPermissionRequiredToRun boolean Indicates whether to override the default behavior and restrict access to enabled profiles or permission sets (true) or not (false). The default value is (false). Available in API version 47.0 and later.
isTemplate boolean Indicates whether the process or flow is a template. When installed from managed packages, processes and flows can’t be viewed or cloned by subscribers because of intellectual property (IP) protection. But when those processes and flows are templates, subscribers can open them in a builder, clone them, and customize the clones. Available in API version 45.0 and later.

Default: false

label string Required. Label for the flow.
loops FlowLoop[] An array of nodes for iterating through collections. This field is available in API version 30.0 and later.
migratedFromWorkflowRuleName string The name of the workflow rule that the flow was migrated from. Available in API version 54.0 and later.
orchestratedStages FlowOrchestratedStage[] An array of stage nodes in an orchestration. Available in API version 53.0 and later.
processMetadataValues FlowMetadataValue[] Metadata values for the flow.

This field is available in API version 31.0 and later.

processType FlowProcessType (enumeration of type string) The type of the flow, as determined by the active version (or latest version, if there’s no active version). Valid values are:
  • Appointments—A flow for Lightning Scheduler. This value is available in API version 44.0 and later.
  • AutoLaunchedFlow—A flow that doesn’t require user interaction.
  • CheckoutFlow—A flow used in Lightning B2B Commerce to create a checkout in a store. This value is available in API version 48.0 and later.
  • ContactRequestFlow—A flow that lets customers request that customer support get back to them. This flow is used to create contact request records. This value is available in API version 45.0 and later.
  • CustomerLifecycle—A Salesforce Surveys flow that lets you associate survey questions with different stages in customer lifecycles. This value is available in API version 49.0 and later and only when the Customer Lifecycle Designer license is enabled.
  • CustomEvent—A process that is invoked when it receives a platform event message. In the UI, it’s an event process. This value is available in API version 41.0 and later.
  • EvaluationFlow—A flow for evaluating custom entry and exit conditions in an orchestration. Uses the isOrchestrationConditionMet output variable and discards values from any other output variables. Available in API version 54.0 and later.
  • FieldServiceMobile—A flow for the Field Service mobile app. This value is available in API version 39.0 and later.
  • FieldServiceWeb—A flow for embedded Appointment Booking. Its UI label is Field Service Embedded Flow. This value is available in API version 41.0 and later.
  • Flow—A flow that requires user interaction because it contains one or more screens or local actions, choices, or dynamic choices. In the UI and Salesforce Help, it’s a screen flow. Screen flows can be launched from the UI, such as with a flow action, Lightning page, or web tab.
  • FSCLending—A flow for Financial Services Cloud Mortgage. This value is available in API version 46.0 and later.
  • InvocableProcess—A process that can be invoked by another process or the Invocable Actions resource in REST API. This value is available in API version 38.0 and later.
  • LoginFlow—A flow for login. Available in API version 51.0 and later.
  • LoyaltyManagementFlow—A flow for the Loyalty Management app and can be invoked by loyalty program processes. This value is available in API version 54.0 and later.
  • Orchestrator—An orchestration that organizes flows into groups of steps contained in a series of stages. Available in API version 53.0 and later.
  • RoutingFlow—A flow for Salesforce Omni-Channel routing and other business logic. This value is available in API version 52.0 and later.
  • Survey—A flow for Salesforce Surveys. From the UI, this type of flow is created in Survey Builder. This value is available in API version 42.0 and later.
  • SurveyEnrich—A Salesforce Surveys flow that uses the Survey Data Mapper. From the UI, this type of flow is created in the Survey Builder and requires an associated survey flow type. This value is available in API version 49.0 or later and only when the Customer Lifecycle Designer license is enabled.
  • Workflow—A process that is invoked when a record is created or edited. In the UI and Salesforce Help, it’s a record change process.

Across flow versions, you can change the type only from Flow to AutoLaunchedFlow or vice versa. Before you change the flow type, make sure that the flow contains only elements, resources, and functionality that the new flow type supports.

These values are reserved for future or Salesforce internal use.
  • ActionCadenceFlow
  • ActionPlan
  • AppProcess
  • CartAsyncFlow
  • DigitalForm
  • Journey
  • JourneyBuilderIntegration
  • LoginFlow
  • ManagedContentFlow
  • OrchestrationFlow
  • RecommendationStrategy
  • SalesEntryExperienceFlow
  • TransactionSecurityFlow
  • UserProvisioningFlow

This field is available in API version 31.0 and later.

recordCreates FlowRecordCreate[] An array of nodes for creating records in the database.
recordDeletes FlowRecordDelete[] An array of nodes for deleting records in the database.
recordLookups FlowRecordLookup[] An array of nodes for looking up records in the database.
recordRollbacks FlowRecordRollback[] An array of nodes for rolling back transactions in the screen flow. Available in API version 52.0 and later.
recordUpdates FlowRecordUpdate[] An array of nodes for updating records in the database.
runInMode FlowRunInMode (enumeration of type string) The context that the flow runs in. Valid values are:
  • DefaultMode—How the flow is launched determines whether the flow runs in user context or in system context. In the UI, this value appears as User or System Context—Depends on How Flow is Launched.
  • SystemModeWithSharing—The flow respects org-wide default settings, role hierarchies, sharing rules, manual sharing, teams, and territories. But the flow doesn’t respect object permissions, field-level access, or other permissions of the running user. In the UI, this value appears as System Context with Sharing—Enforces Record-Level Access.

This field is available in API version 48.0 and later.

screens FlowScreen[] An array of screen nodes.
stages FlowStage[] An array of stage resources that you can use throughout the flow. This field is available in API version 42.0 and later.
start FlowStart Represents the flow’s Start element, which specifies how and when the flow starts. This field is available in API version 47.0 and later.
startElementReference string Specifies which node or element is the starting point in the flow.

This field isn’t used in flows that are created or saved in Flow Builder in Winter ’20 and later. Those flows use the start field instead to specify how the flow starts.

status FlowVersionStatus (enumeration of type string) The activation status of the flow. Valid values are:
  • Active
  • Draft—In the UI, this status appears as Inactive.
  • Obsolete—In the UI, this status appears as Inactive.
  • InvalidDraft—In the UI, this status appears as Draft.
steps FlowStep[] An array of step nodes.
subflows FlowSubflow[] An array of subflows. This field is available in API version 25.0 and later.
textTemplates FlowTextTemplate[] An array of text templates.
triggerOrder int The run order of a record-triggered flow, from 1 to 2,000. See "Guidelines for Defining the Run Order of Record-Triggered Flows for an Object" in Salesforce Help. Available in API version 54.0 and later.
variables FlowVariable[] An array of variable definitions.
waits FlowWait[] An array of wait nodes. This field is available in API version 32.0 and later.

FlowActionCall

Defines a call to an action from the flow. It extends FlowNode.

Available in API version 31.0 and later.

Field Name Field Type Description
actionName string Required. Name for the action. Must be unique across actions with the same actionType.
actionType InvocableActionType (enumeration of type string) Required. The action type. Valid values are:
  • activateSessionPermSet—Activates a session-based permission set for the running user.
  • addMessageToChat—Adds a message to an existing Salesforce Anywhere chat. Available in API version 49.0 and later.
  • addMessageToQuipChat—Adds a Quip message to an existing chat room. Available in API version 46.0 and later.
  • addMessageToQuipDocument—Adds a Quip message to an existing Quip document, spreadsheet, or slide. Available in API version 46.0 and later.
  • addQuipDocumentToFolder—Adds an existing Quip document, spreadsheet, or slide to an existing folder. Available in API version 46.0 and later.
  • addUsersToChat—Adds users to an existing Salesforce Anywhere chat. Available in API version 49.0 and later.
  • addUsersToQuipDocument—Adds users, identified by their email addresses, to an existing Quip document, spreadsheet, or slide. Available in API version 46.0 and later.
  • addUsersToQuipChat—Adds users, identified by their email addresses, to an existing Quip chat room. Available in API version 46.0 and later.
  • attachQuipDocumentToRecord—Attaches a Quip document, spreadsheet, or slide to a Salesforce record. Available in API version 46.0 and later.
  • apexInvokes an Apex method that has the @invocableMethod annotation.
  • archiveKnowledgeArticles—Archives a list of published Knowledge articles. Available in API version 45.0 and later.
  • assignKnowledgeArticles—Mass assigns Knowledge articles from article list views. Available in API version 44.0 and later.
  • chat—Creates a Salesforce Anywhere chat. Available in API version 49.0 and later.
  • chatterPost—Posts to Chatter.
  • choosePricebook—Selects a price book.
  • contactRequestAction—Creates a contact request record. Available in API version 45.0 and later.
  • component—Invokes the Lightning component that implements the lightning:availableForFlowActions interface and that is referenced by actionName. Available in API version 43.0 and later.
  • contentWorkspaceEnableFolders—Enables folders in a library.
  • copyQuipDocument—Creates a copy of an existing Quip document, spreadsheet, or slide and gives it a new title. Available in API version 46.0 and later.
  • createDraftFromOnlineKnowledgeArticle—Creates a draft from a published Knowledge article. Available in API version 45.0 and later.
  • createInvoiceFromFulfillmentOrder—Creates an invoice from a purchase order. Available to B2B Commerce on Lightning Experience. Available in API version 49.0 and later.
  • createQuipChat—Creates a Quip chat room. Available in API version 46.0 and later.
  • createQuipDocument—Creates a Quip document, spreadsheet, or slide. Available in API version 46.0 and later.
  • createQuipFolder—Creates a Quip folder. Available in API version 46.0 and later.
  • customNotificationAction—Sends a custom notification. Available in API version 46.0 and later.
  • deactivateSessionPermSet—Deactivates a session-based permission set for the running user.
  • decisionStudioAction—Available in API version 49.0 and later.
  • deleteKnowledgeArticle—Deletes a draft version (translation or master-language) or an entire archived Knowledge article. Available in API version 46.0 and later.
  • editQuipDocument—Modifies the contents of an existing Quip document, spreadsheet, or slide. Available in API version 46.0 and later.
  • emailAlert—Sends an email by referencing a workflow email alert
  • emailSimple—Sends an email by using flow resources
  • externalService—Invokes an External Service operation that makes an HTTP request to an external system made available by an External Service schema registered through Setup. Available in API version 46.0 and later.
  • flow—Invokes an autolaunched flow. This action type isn’t available for flows with a processType of Flow or AutolaunchedFlow. To invoke an autolaunched flow from one of those types, use FlowSubflow. Available in API version 32.0 and later.
  • limitRepetitions—Limit the number of times the same recommendation or offer appears on the same record or for the same user during a time period in a recommendation strategy flow. Available in API version 55.0 and later.
  • marketingEmail—Available in API version 49.0 and later.
  • massUpdateAccountForecast—Bulk updates forecasts asynchronously. Available in API version 48.0 and later.
  • massUpdateSalesAgreement—Bulk updates sales agreements asynchronously. Available in API version 48.0 and later.
  • quickAction—Invokes a QuickAction.
  • publishKnowledgeArticles—Mass publishes Knowledge articles from article list views. Available in API version 44.0 and later.
  • publishPardotContent—Available in API version 49.0 and later.
  • restoreKnowledgeArticleVersion—Restores an archived version of a Knowledge article. Available in API version 45.0 and later.
  • sendAlert—Sends Salesforce Anywhere alerts to users. Available in API version 49.0 and later.
  • sendNotification—Sends an available notification type. Available in API version 54.0 and later.
  • sendSurveyInvitation—Send email survey invitations to leads, contacts, and users in your org based on an action, such as when a customer support case closes. Available in API version 49.0 and later.
  • performSurveySentimentAnalysis—Perform survey sentiment analysis to create or update the AI Sentiment Result records. Available in API version 55.0 and later.
  • skillsBasedRouting—Creates a PendingServiceRouting record used for Omni-Channel skills-based routing. Available in version 44.0 and later.
  • slackArchiveChannel—Archives a Slack channel in a Slack workspace. Available in API version 54.0 and later.
  • slackCheckUsersAreConnectedToSlack—Indicates whether a collection of Salesforce users is connected to a given Slack app. Available in API version 54.0 and later.
  • slackCreateChannel—Creates a Slack channel in a Slack workspace. Available in API version 54.0 and later.
  • slackGetConversationInfo—Retrieves the name of a Slack channel or group direct message and finds out whether it’s archived. Available in API version 54.0 and later.
  • slackInviteUsersToChannel—Adds users who are connected to a given Slack app to a Slack channel or group direct message. Available in API version 54.0 and later.
  • slackPinMessage—Pin or unpin a message in a Slack channel or group direct message. Available in API version 54.0 and later.
  • slackPostMessage—Send a message to a Slack channel or group direct message. Available in API version 54.0 and later.
  • slackUpdateMessage—Edits a message that was previously sent to a Slack channel or group direct message. Available in API version 54.0 and later.
  • storeReplyRecommendationsFeedback—Available in API version 49.0 and later.
  • submitKnowledgeArticleForTranslation—Submits a published or draft Knowledge article for translation. Available in API version 46.0 and later.
  • submit—Submits a record for approval.
These values are used in Omnichannel Inventory. If no version is specified, the value is available in API version 51.0 and later.
  • ociCreateReservation—Creates one or more inventory reservations at a location or location group.
  • ociFulfillReservation—Fulfills one or more inventory reservations at a location.
  • ociGetAvailability—Gets inventory availability data for one or more products at one or more inventory locations or location groups.
  • ociReleaseReservation—Releases one or more inventory reservations.
  • ociTransferReservation—Transfers one or more inventory reservations between locations or location groups.

These values are used in the B2B Commerce Checkout Flow. If no version is specified, the value is available in API version 47.0 and later.

  • updateCheckoutSessionStateAction—Updates the checkout session next state for checkout flows. Available in API version 49.0 and later.
  • priceCart—Requests prices for all items in a cart during B2B Commerce checkout. Available in API version 47.0 and later.
  • checkoutSessionAction—Initiates or retrieves an existing Checkout Session for Checkout Flows. Available to B2B Commerce on Lightning Experience. Available in API version 49.0 and later.
  • cancelCartAsyncOperation—Cancels a WebCart’s async operation. Available to B2B Commerce on Lightning Experience. Available in API version 49.0 and later.
  • calcCartPromotionsAction—Requests a full cart promotion calculation of all applicable line items in the Web Cart. Available to B2B Commerce on Lightning Experience. Available in API version 52.0 and later.
  • checkCartInventoryAction—Requests an inventory for all items in a Web Cart during B2B Commerce checkout. Available in API version 47.0 and later.
  • calcCartShipmentAction—Calculates the shipping cost for all items in a Web Cart during B2B Commerce checkout. Available in API version 47.0 and later.
  • cartToOrderAction—Creates a Salesforce Standard Order in draft mode. Available in API version 47.0 and later.
  • activateOrderAction—Activates a draft order, which creates an order summary. Available in API version 47.0 and later.

These values are used in the Commerce Checkout Flow. If no version is specified, the value is available in API version 55.0 and later.

  • addCartItem—Adds an item to a cart during Commerce checkout.
  • createCart—Creates a cart during Commerce checkout.
  • deleteCart—Deletes a cart during Commerce checkout.
These values are used in Order Management. If no version is specified, the value is available in API version 48.0 and later.
  • addOrderItemSummarySubmit—Adds order item summaries to an order summary. Available in API version 54.0 and later.
  • adjustOrderItemSummariesPreview—Previews the expected results of applying a price adjustment to order item summaries from an order summary without actually applying it. Available in API version 49.0 and later.
  • adjustOrderItemSummariesSubmit—Applies a price adjustment to order item summaries from an order summary. Available in API version 49.0 and later.
  • authorizePayment—Authorizes a card payment. Available in API version 55.0 and later.
  • cancelFulfillmentOrderItem—Removes items from a fulfillment order.
  • cancelOrderItemSummariesPreview—Previews the expected results of canceling order item summaries from an order summary without actually canceling them.
  • cancelOrderItemSummariesSubmit—Cancels order item summaries from an order summary.
  • confirmHeldFulfillmentOrderCapacity—Confirms held fulfillment order capacity. Available in API version 55.0 and later.
  • createCreditMemoOrderSummary—Creates a credit memo for an order summary.
  • createFulfillmentOrder—Creates one or more fulfillment orders and fulfillment order products for an order delivery group summary, which defines a recipient and delivery method.
  • createFulfillmentOrders—Creates fulfillment orders and fulfillment order products for multiple order delivery group summaries, each of which defines a recipient and delivery method. Available in API version 51.0 and later.
  • createInvoiceFromFulfillmentOrder—Creates an invoice for a fulfillment order.
  • createOrderPaymentSummary—Creates an order payment summary for an authorization or payments belonging to an order summary.
  • createOrderSummary—Creates an order summary for an order.
  • createReturnOrder—Creates a return order and return order items for an order.
  • ensureFundsOrderSummaryAsync—triggers an asynchronous background process to ensure funds through a payment provider for an invoice belonging to an order summary.
  • ensureRefundsOrderSummaryAsync—Triggers an asynchronous background process to ensure refunds through a payment provider for an invoice belonging to an order summary.
  • getFulfillmentOrderCapacityValues—Gets fulfillment order capacity information. Available in API version 55.0 and later.
  • holdFulfillmentOrderCapacity—Holds fulfillment order capacity. Available in API version 55.0 and later.
  • orderRoutingFindRoutesWithFewestSplits—Evaluates ordered product quantities against available inventory to determine the smallest combination of locations that can fulfill the order. Available in API version 51.0 and later.
  • orderRoutingFindRoutesWithFewestSplitsUsingOCI—Evaluates ordered product quantities against available inventory at specified location groups and locations to determine the smallest combination of locations that can fulfill the order. Available in API version 54.0 and later.
  • orderRoutingRankByAverageDistance—Calculates the average distance from sets of inventory locations to an order recipient, and returns the sets sorted by that average distance. Available in API version 51.0 and later.
  • releaseHeldFulfillmentOrderCapacity—Releases held fulfillment order capacity. Available in API version 55.0 and later.
  • returnOrderItemSummariesPreview—Previews the expected results of returning order item summaries from an order summary without actually returning them.
  • returnOrderItemSummariesSubmit—Returns order item summaries from an order summary.
  • returnReturnOrderItems—Processes return order line items.
  • storeReplyRecommendationsFeedback—Initiates a store’s standard reply to customer recommendations and feedback. Available in API version 49.0 and later.
  • storeReplyRecommendationsFeedback—Updates the current state of a buyer’s checkout session. Available in API version 49.0 and later.
These values are used in Financial Services Cloud:
  • createFinancialRecords—Creates person accounts, contacts, financial accounts, properties, assets, and liabilities from a residential loan application. Available in API version 49.0 and later.

For values used in Manufacturing Cloud, see Flow for Manufacturing Cloud.

These values are used in Rebate Management:
  • addRebateMemberList—Adds a list of members to a rebate program. Available in API version 51.0 and later.
  • calculateProjectedRebateAmount—Calculates the projected rebate amount for rebate types associated with a specified transaction ID. Available in API version 54.0 and later.
  • calculateRebateAmountAndUpsertPayout—Calculates the rebate amount and upserts the rebate payout for the specified aggregate record. Available in API version 51.0 and later.
  • getBenefitAndCalculateRebateAmount— Gets benefit details and optionally calculates the rebate amount for the specified aggregate record. Available in API version 51.0 and later.
  • getEligibleProgramRebateTypes—Retrieve the eligible program rebate types for a mapped object. Available in API version 52.0 and later.
  • generateRebatePayoutPeriods—Generates payout periods for a rebate program based on the frequency specified in the program. Available in API version 51.0 and later.
  • processRebatesBatchCalculationJob—Processes a rebate batch calculation job from the Data Processing Engine. Available in API version 51.0 and later.
  • processProgramRebateTypeProducts—Insert or delete records in the Program Rebate Type Product object. Available in API version 53.0 and later.
  • rebatesProcessCSV—Processes an uploaded CSV file using Bulk API 2.0 and converts the file’s data into records in the target object. Available in API version 51.0 and later.
  • upsertCustomRebatePayout—Upserts the custom calculated rebate payout for the specified aggregate record. Available in API version 51.0 and later.
These values are used in Loyalty Management:
  • adjustPoints—Adjusts loyalty points for a specified program member or journal transaction. Available in API version 51.0 and later.
  • assignTierBenefits—Assign Member Benefits to a member tier for benefits that are associated with a Benefit Action. Available in API version 51.0 and later.
  • cancelAccrual—Cancels a specific set of accrual transactions.
  • creditPoints—Credits loyalty points to a specified program member’s balance. Available in API version 51.0 and later.
  • cancelRedemption—Reverts a specific set of redemption transactions. Available in API version 51.0 and later.
  • changeTier—Changes the tier for a specified program member. Available in API version 51.0 and later.
  • changeTierWhenNoErrors—Changes tier for a specified loyalty program member only when all the input parameters meet the criteria. Available in API version 51.0 and later.
  • debitPoints—Debits loyalty points to a specified program member’s balance. Available in API version 51.0 and later.
  • executeMemberBenefit—Processes the benefit action associated with the benefit, which is assigned to a loyalty program member. Available in API version 51.0 and later.
  • getMemberActiveSegments—Retrieve active Salesforce CDP market segments that a loyalty program member is a part of.
  • getTier—Gets the current tier for a specified program member. Available in API version 51.0 and later.
  • getPointsBalance—Gets the loyalty points balance for a specified program member. Available in API version 51.0 and later.
  • getLoyaltyPromotion—Get active loyalty promotions based on a transaction journal. Available in API version 53.0 and later.
  • getLoyaltyPromotionBasedOnSalesforceCDP—Get promotions for a member based on the market segment the member belongs to. Available in API version 53.0 and later.
  • issueVoucher—Issues a voucher for a member or contract. Available in API version 51.0 and later.
  • transferMemberPointsToGroups—Transfers points from an individual member or a corporate member to the member's associated group. Available in API version 53.0 and later.
  • updateProgressForCumulativePromotionUsage—Updates the progress a member has made towards attaining a cumulative type promotion. Available in API version 53.0 and later.
These values are for Decision Table:
  • decisionTableAction—Runs an active decision table definition. Available in API version 51.0 and later.
  • refreshDecisionTable—Refreshes the decision table cache. Available in API version 51.0 and later.
These values are for the Batch Management jobs:
  • batchJobAction—Runs the batch management jobs definitions. Available in API version 51.0 and later.
  • submitFailedRecordsBatchJob—Resubmits an existing batch job with failed records for processing. Available in API version 52.0 and later.
This value is for Data Processing Engine:
  • dataProcessingEngineAction—Runs the data processing engine definitions. Available in API version 51.0 and later.
This value is used for Einstein Visit Recommendation:
  • saveRecommendationDecision—Save visit and task recommendation decisions.Available in API version 51.0 and later.
These values are reserved for future use.
  • thanks
  • metricRefresh
  • exportSurveyResponses
  • sendSurveyInvitation
These values are used in Field Service. If no version is specified, the value is available in API version 52.0 and later.
  • addWorkPlans—Creates work plan and work step objects from the work plan library.
  • addWorkSteps—Creates work step objects from the work plan library.
  • deleteWorkPlans—Deletes all the work plans and work steps associated with a work order or work order line item.
  • generateWorkPlans—Generates work plans based off rules defined in the work plan library.
connector FlowConnector Specifies which node to execute after this action call.
dataTypeMappings FlowDataTypeMapping[] An array of data type mappings for input and output values that have the generic sObject data type. This field is available in API version 48.0 and later.
faultConnector FlowConnector Specifies which node to execute if the action call results in an error.
inputParameters FlowActionCallInputParameter[] An array of input parameters from the flow to the action.
outputParameters FlowActionCallOutputParameter[] An array of output parameters from the action to the flow.
storeOutputAutomatically boolean Indicates whether the action’s output parameters are automatically available in the flow without creating any variables. When the value is true, you can reference an output parameter by specifying the API name of the Action element in the flow. The default value is false. When the value is false, create variables manually to store output values from the action.

This field is available in API version 48.0 and later.

FlowActionCallInputParameter

Defines an input parameter from the flow to the action. It extends FlowBaseElement and inherits all its fields. Available in API version 31.0 and later.

Field Name Field Type Description
name string Required. Unique name for the input parameter.
value FlowElementReferenceOrValue Defines the value of the input parameter.

FlowActionCallOutputParameter

Defines an output parameter from the action to the flow. It extends FlowBaseElement and inherits all its fields. Available in API version 31.0 and later.

Field Name Field Type Description
assignToReference string Required. Specifies the variable to which you want to assign the output parameter value.
name string Required. Unique name for the output parameter.

FlowApexPluginCall

Defines a call to an Apex plug-in from the flow. It extends FlowNode and inherits all its fields.

Field Name Field Type Description
apexClass string Required. The name of the Apex class.
connector FlowConnector Specifies which node to execute after this Apex plug-in call.
faultConnector FlowConnector Specifies which node to execute if the Apex plug-in call results in an error.
inputParameters FlowApexPluginCallInputParameter[] An array of input parameters from the flow to the Apex plug-in.
outputParameters FlowApexPluginCallOutputParameter[] An array of output parameters from the Apex plug-in to the flow.

FlowApexPluginCallInputParameter

Defines an input parameter from the flow to the Apex plug-in. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
name string Required. Unique name for the input parameter.
value FlowElementReferenceOrValue Defines the value of the input parameter.

FlowApexPluginCallOutputParameter

Defines an output parameter from the Apex plug-in to the flow. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
assignToReference string Required. Specifies the variable to which you want to assign the output parameter value.
name string Required. Unique name for the output parameter.

FlowAssignment

Defines an assignment node that can dynamically change the value of a variable in the flow. It extends FlowNode and inherits all of its fields.

Field Name Field Type Description
assignmentItems FlowAssignmentItem[] An array of assignment operations that is executed in the given order, starting from the index 0.
connector FlowConnector Specifies which node to execute after this assignment node.

FlowAssignmentItem

Defines an operation to apply to a variable. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
assignToReference string Required. Reference to the variable to which you want to apply the specified operator.
operator FlowAssignmentOperator (enumeration of type string) Required. Operation to apply to the variable reference in the assignToReference field. For valid values, see FlowAssignmentOperator.
value FlowElementReferenceOrValue Defines the value that you want the operator to apply to the variable reference in the assignToReference field.

FlowAssignmentOperator

An enumeration of type string that specifies the operation to apply to the variable in the assignToReference field. See “Flow Operators in Assignment Elements” in Salesforce Help.

Valid values are:

Enumeration Value Description
Add When the assignToReference field is a variable of type number or currency, this operator adds the value to the variable.

When the assignToReference field is a variable of type date, this operator adds the value in days to the variable.

When the assignToReference field is a variable of type string, this operator appends the value to the end of the string.

When the assignToReference field is a variable of type picklist, this operator appends the value to the end of the last item in the picklist.

When the assignToReference field is a variable of type multipicklist, this operator appends the value to the end of the last item in the multi-select picklist. To instead add an item to the end of the multi-select picklist, use the AddItem operator.

When the assignToReference field is the $Flow.ActiveStages global variable, this operator appends the value as a new item at the end of $Flow.ActiveStages.

When the assignToReference field is a collection variable, this operator appends the value to the end of the collection. Support for a collection variable as the value is available in API version 43.0 and later but only via Metadata API. From Flow Builder, you can’t save an Assignment element that contains a collection variable in the Value column for the Add operator.

The Add operator isn’t supported when the assignToReference field is a variable of type boolean, dateTime, or sObject.

AddAtStart Supported only when the assignToReference field is a collection variable or the $Flow.ActiveStages global variable. Adds the value as a new item at the beginning of the collection. When the value is a collection variable, the operator adds all items at the beginning of the collection. This operator is available in API version 43.0 and later.
AddItem Supported only when the assignToReference field is a variable of type multipicklist. Adds the value to the picklist, including the semi-colon that’s required to mark a value as a separate item. This operator is available in API version 34.0 and later.
Assign Assigns the value to the variable in the assignToReference field.
AssignCount Supported only when the value is a collection variable or the $Flow.ActiveStages global variable. Counts the number of stages or items in the collection and assigns that number to the variable in the assignToReference field. Corresponds to equals count in the user interface. This operator is available in API version 43.0 and later.
RemoveAfterFirst Supported only when the assignToReference field is a collection variable or the $Flow.ActiveStages global variable. Finds the first instance of the value within the variable in the assignToReference field. Removes everything after that first instance from the variable. This operator is available in API version 43.0 and later.
RemoveAll Supported only when the assignToReference field is a collection variable or the $Flow.ActiveStages global variable. Removes all instances of the value from the variable in the assignToReference field. When the value is a collection variable, the operator removes all instances of each item from the variable in the assignToReference field. This operator is available in API version 43.0 and later.
RemoveBeforeFirst Supported only when the assignToReference field is a collection variable or the $Flow.ActiveStages global variable. Finds the first instance of the value within the variable in the assignToReference field. Removes everything before that first instance from the variable. This operator is available in API version 43.0 and later.
RemoveFirst Supported only when the assignToReference field is a collection variable or the $Flow.ActiveStages global variable. Removes the first instance of the value from the variable in the assignToReference field. This operator is available in API version 43.0 and later.
RemovePosition Supported only when the assignToReference field is a collection variable or the $Flow.ActiveStages global variable. Removes the item at the specified position. For example, if the collection contains three items (Red, Green, Blue) and the value is 2, the second item (Green) is removed from the collection variable. This operator is available in API version 43.0 and later.

Make sure that the value at run time is a positive integer within the range of the number of items in the collection variable.

RemoveUncommon Supported only when assignToReference and value are both collection variables. Keeps items that are in both collections and removes the rest from the collection variable in the assignToReference field. This operator is available in API version 43.0 and later.
Subtract Supported only when the assignToReference field is a variable of type currency, date, or number.

When the assignToReference field is a variable of type number or currency, this operator subtracts the value from the variable.

When the assignToReference field is a variable of type date, this operator subtracts the value in days from the variable.

FlowChoice

A choice resource is a standalone choice option that you can reference or reuse throughout the flow. It extends FlowElement and inherits all of its fields.

Field Name Field Type Description
choiceText string Required. Choice label to display in the screen.
dataType FlowDataType (enumeration of type string) Required. Valid types are:
  • Currency
  • Date
  • Number
  • String
  • Boolean
userInput FlowChoiceUserInput Enables the choice to allow user input when the choice is selected. Not supported for choices in multi-select fields.
value FlowElementReferenceOrValue Actual value that’s used during flow execution, for example, in assignments, calls to Apex plug-ins, and record elements. If null, this choice always has the value of null.

FlowChoiceUserInput

Allows the choice to include a user input field that appears when the choice is selected by the user. User input isn’t supported for choices in multi-select fields. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
isRequired boolean Indicates whether users are required to enter something into the field when they select the choice.
promptText string Text that is displayed to prompt the user for input at runtime. Supports merge fields.
validationRule FlowInputValidationRule Rule used at runtime to validate the user input.

FlowCondition

Defines a condition for a rule. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
leftValueReference string Required. Unique name of the element that serves as the left side of the condition expression.
operator FlowComparisonOperator (enumeration of type string) Required. Valid values are:
  • EqualTo
  • NotEqualTo
  • GreaterThan
  • LessThan
  • GreaterThanOrEqualTo
  • LessThanOrEqualTo
  • StartsWith
  • EndsWith
  • Contains
  • IsNull
  • WasSet—This value is available in API version 30.0 and later.
  • WasSelected—Requires a choice on the left side.
  • WasVisited—Requires a node on the left side.
rightValue FlowElementReferenceOrValue Unique name of an element or the actual value, such as text or a number, for the right side of the condition expression.

FlowConnector

Connectors determine the order in which the nodes of the flow are executed. A connector defines and links to the subsequent node. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
targetReference string Required. Which node to execute after completing the current node.

FlowDataTypeMapping

This data type mapping defines the specific sObject data type for input and out values that have the generic sObject data type. It extends FlowBaseElement and inherits all its fields. Available in API version 48.0 and later.
Field Name Field Type Description
typeName string Required. API name of the input or output variable. The T__ prefix is required for input variables. The U__ prefix is required for output variables. For example, T__inputCollection represents the API name of the input variable inputCollection.
typeValue string Required. API name of the specific sObject data type that this value maps to. For example, Account.

FlowConstant

A constant resource defines a fixed value that can be used throughout your flow. It extends FlowElement and inherits all its fields.

Field Name Field Type Description
dataType FlowDataType (enumeration of type string) Required. Valid types are:
  • Currency
  • Date
  • Number
  • String
  • Boolean
value FlowElementReferenceOrValue Default value of the constant. This field can’t have merge fields, nor can it reference another resource besides $GlobalConstant.EmptyString.

FlowDecision

Decision node that evaluates a set of rules and routes the flow execution based on the first rule that evaluates to true. It extends FlowNode and inherits all its fields.

Field Name Field Type Description
defaultConnector FlowConnector Specifies which node to execute if none of the rules evaluate to true.
defaultConnectorLabel string Label for the default connector.
rules FlowRule[] An array of rules for the decision. The rules are evaluated in the order they’re listed, and the connector of the first true rule is used. If no rules are true, then the default connector is used. In Flow Builder, rules are referred to as decision outcomes.

FlowDynamicChoiceSet

Looks up data or metadata from an object and dynamically generates a set of choices at run time. It extends FlowElement and inherits all its fields. Depending on the fields that are set, this element represents a record choice or a picklist choice.
  • A record choice dynamically generates choices based on records that meet specified filter criteria. If a dynamic choice doesn’t have the picklistField and picklistObject parameters set, it’s a record choice and it can’t have a data type of Picklist or Multipicklist.
  • A picklist choice dynamically generates choices based on the available values for a picklist or multi-select picklist field. If a dynamic choice has the picklistField and picklistObject parameters set, it’s a picklist choice and it must have a data type of Picklist or Multipicklist.
Field Name Field Type Description
collectionReference string The collection used to generate choices. Available in API version 54.0 and later.
dataType FlowDataType (enumeration of type string) Required. Valid types are:
  • Boolean
  • Currency
  • Date
  • Multipicklist—Picklist choices only
  • Number
  • Picklist—Picklist choices only
  • Record
  • String

Picklist and Multipicklist are available in API version 35.0 and later. Record is available in API version 54.0 and later.

displayField string Required for record choices. Specifies the object field. The values of the object field are displayed to the user as choice labels for selecting a record.

For example, for an account, if you want the dynamically generated choices to be displayed as the account names from the records that are retrieved from the database, specify Name in displayField.

Not supported for picklist choices. Picklist choices always display the labels for the retrieved picklist values.

filters FlowRecordFilter[] An array of filters to apply to the records that are retrieved from the database. For example, filter accounts to include only the accounts that were created in the past three months.

Not supported for picklist choices.

limit int Maximum number of choices to include in the generated set of choices. Maximum and default: 200.

If sortField and sortOrder are also specified, the records are sorted before the limit takes effect.

This field is available in API version 25.0 and later.

This field is nillable in API version 45.0 and later.

object string Required for record choices. The object whose fields you want to retrieve from the database and use to generate the set of choices. For example, use “Account” to dynamically generate choices from the information in account records in the database.

Not supported for picklist choices.

outputAssignments FlowOutputFieldAssignment[] An array that assigns fields from the user-selected record to variables that can be used elsewhere in the flow. For example, when the user selects an account name from the dynamically generated list of choice options, outputAssignments can assign the Id and AnnualRevenue from the user-selected account to variables that you specify.

Not supported for picklist choices.

picklistField string Required for picklist choices. The field whose available values you want to retrieve from the database and use to generate the picklist choice. For example, use “Industry” to dynamically generate one choice for each available value on the Industry picklist field.

Not supported for record choices.

This field is available in API version 35.0 and later.

picklistObject string Required for picklist choices. The object whose field metadata you want to retrieve from the database and use to generate the picklist choice. For example, use “Account” to dynamically generate choices from a picklist field on the Account object.

Not supported for record choices.

This field is available in API version 35.0 and later.

sortField string Field that is used for sorting the records that meet the filter criteria. If this field isn’t specified, the returned records aren’t sorted.

You can only sort records by fields that have the Sort API field property, as specified in SOAP API.

Not supported for picklist choices.

This field is available in API version 25.0 and later.

sortOrder SortOrder (enumeration of type string) Order in which to sort the records. If this field isn’t specified, then the results aren’t sorted.
Valid values are:
  • Asc—Ascending
  • Desc—Descending

Not supported for picklist choices.

This field is available in API version 25.0 and later.

valueField string Stored value for the choice, which can differ from what is displayed to the user as the choice options (displayField). For example, the displayField might be the account “Name” while the valueField is the account “Id.”

Not supported for picklist choices. Picklist choices always store the API value for the retrieved picklist values.

FlowElement

Base class for all flow elements. This is an abstract class. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
description string Description of the flow element.
name string Required. Unique name of the flow element.

FlowBaseElement

Base class for all flow elements that require contextual information in metadata values. This is an abstract class. FlowBaseElement is available in API version 32.0 and later.

Field Name Field Type Description
processMetadataValues FlowMetadataValue[] Contextual information for the element.

FlowMetadataValue

Defines contextual information that can be passed between elements in a flow. Flow metadata values can be used in an application that produces or consumes flows. FlowMetadataValue is available in API version 31.0 and later.

Field Name Field Type Description
name string Required. Name for the metadata value. This name doesn’t need to be unique across all elements.
value FlowElementReferenceOrValue Reference or value for the metadata value.

FlowElementReferenceOrValue

Defines a reference to an existing element or a particular value that you specify. Make sure that you specify only one of the fields.

Field Name Field Type Description
booleanValue boolean Use this field to specify a boolean value. If you want to specify a different data type or element reference, don’t use this field.
dateTimeValue dateTime Use this field to specify a dateTime value. If you want to specify a different data type or element reference, don’t use this field. This field is available in API version 30.0 and later.
dateValue date Use this field to specify a date value. If you want to specify a different data type or element reference, don’t use this field.
elementReference string Use this field to specify the name of an existing element. If you want to specify a value instead of an element reference, don’t use this field.
numberValue double Use this field to specify a double value. If you want to specify a different data type or element reference, don’t use this field.
stringValue string Use this field to specify a string value. If you want to specify a different data type or element reference, don’t use this field.

FlowFormula

Calculates a value using functions and elements in the flow. It extends FlowElement and inherits all its fields.

Field Name Field Type Description
dataType FlowDataType (enumeration of type string) The data type for the formula. Valid values are:
  • Boolean
  • Currency
  • Date
  • DateTime
  • Number
  • String

dataType defaults to Number if it isn’t defined in a formula.

This field is available in API version 31.0 and later.

expression string Required. Salesforce formula expression. The return value must match the data type. See “Flow Formula Considerations” in Salesforce Help.

For API version 30.0 and earlier, the return value must be numeric.

scale int Scale of the return value, specifically, the number of digits to the right of the decimal point. Available only when the data type is Number or Currency. Corresponds to the Decimal Places field in Flow Builder.

FlowInputFieldAssignment

Assigns the value for a record field based on a resource or static value. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
field string Required. Name of the field to be assigned a value while a record is being created or updated.
value FlowElementReferenceOrValue Value to be assigned to the field.

FlowInputValidationRule

Validation rules verify that the data entered by the user meets the specified requirements. If the validation rule evaluates to false, then the specified error message is displayed.

Field Name Field Type Description
errorMessage string Required. Error message to display when formulaExpression evaluates to false.
formulaExpression string Required. Boolean formula used to validate the user input. See “Flow Formula Considerations” in Salesforce Help.

FlowLoop

A construct for iterating through a collection. It extends FlowNode and inherits all of its fields. FlowLoop is available in API version 30.0 and later.

Field Name Field Type Description
assignNextValueToReference string Required. The variable to which the current value in the collection is assigned before navigating to the target of nextValueConnector.
collectionReference string Required. The collection being looped through.
iterationOrder iterationOrder (enumeration of type string) Valid values are:
  • Asc—Iterate through the collection in the order the values are listed (first to last).
  • Desc—Iterate through the collection in the reverse order the values are listed (last to first).
nextValueConnector FlowConnector Points to the element that the flow navigates to for each of the entries in the collection. This is where the flow goes for the next value in the collection.
noMoreValuesConnector FlowConnector Points to the element to navigate to when all entries in the collection have been looped through.

FlowNode

A node is a type of element that is visible in the flow diagram. It extends FlowElement and inherits all its fields.

Field Name Field Type Description
label string Required. Name of the node. This non-unique label is different from the unique name of the node, which is inherited from FlowElement.
locationX int Required. Horizontal location of the node, in pixels from the left.
locationY int Required. Vertical location of the node, in pixels from the top.

FlowOrchestratedStage

A stage node that contains steps in an orchestration. It extends FlowNode and inherits all of its fields. Available in API version 53.0 and later.

Field Name Field Type Description
connector FlowConnector Specifies which node to execute after this stage.
exitActionInputParameters FlowStageStepExitActionInputParameter[] An array of input parameters from the stage to the evaluation flow used as an exit condition for the stage.
exitActionName string Name of the evaluation flow used as an exit condition for the stage. Valid values are:
  • isOrchestrationConditionMet
exitActionOutputParameters FlowStageStepExitActionOutputParameter[] An array of output parameters from the evaluation flow to the stage used as an exit condition for the stage.
exitActionType InvocableActionType (enumeration of type string) The type of the evaluation flow for the custom exit condition. Valid values are:
  • EvaluationFlow
exitConditionLogic string Reserved for internal use.
exitConditions FlowCondition[] An array of conditions to be met for exiting the stage.
faultConnector FlowConnector Reserved for future use.
stageSteps FlowStageStep[] An array of stage step resources.

FlowOutputFieldAssignment

Assigns a record field’s value from a record to a variable that can be used elsewhere in the flow. The record could be selected by a record lookup or via a user selection for a choice. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
assignToReference string Required. Reference to the variable where you want to store the value of the record field.
field string Required. Name of the field whose value is to be assigned after a record lookup.

FlowRecordCreate

Create a new record in the database using values from the flow. It extends FlowNode and inherits all its properties.

The flow record create, lookup, update, and delete operations are different from the CRUD-based metadata calls create(), retrieve(), update(), and delete(). The flow record methods apply to record operations from within a flow, which aren’t the same as doing any metadata calls to CRUD setup entities.

Note

Field Name Field Type Description
assignRecordIdToReference string Reference to the variable where you want to store the ID after the record is created.
connector FlowConnector Specifies which node to execute after creating the record.
faultConnector FlowConnector Specifies which node to execute if the attempt to create a record results in an error.
inputAssignments FlowInputFieldAssignment[] An array that assigns values to the specified fields of the record being created.
inputReference string Specifies the record variable whose field values are used to populate the new record’s fields.
object string Required. Object for the record to be created by this element
storeOutputAutomatically boolean Indicates whether the record ID is automatically available in the flow without creating any variables. When the value is true, you can reference the record ID by specifying the API name of the Create Records element in the flow. The default value is false. When the value is false, create a variable to store the record ID.

This field is available in API version 48.0 and later.

FlowRecordDelete

Deletes one or more records in the database. It extends FlowNode and inherits all its fields.

The flow record create, lookup, update, and delete operations are different from the CRUD-based metadata calls create(), retrieve(), update(), and delete(). The flow record methods apply to record operations from within a flow, which aren’t the same as doing any metadata calls to CRUD setup entities.

Note

Field Name Field Type Description
connector FlowConnector Specifies which node to execute after deleting the record.
faultConnector FlowConnector Specifies which node to execute if the attempt to delete a record results in an error.
filters FlowRecordFilter[] An array that specifies the criteria used to select which records to delete from the database. For example, delete accounts whose last activity was older than a specified date.
inputReference string Specifies the record variable whose record ID is used to identify which record to delete in the database.
object string Required. The name of the object whose records are deleted.

FlowRecordFilter

Sets the criteria for searching records in the database. It extends FlowBaseElement and inherits all its fields.

Field Name Field Type Description
field string Required. The field to be used for filtering records.
operator FlowRecordFilterOperator (enumeration of type string) Required. Valid values are:
  • EqualTo
  • NotEqualTo
  • GreaterThan
  • LessThan
  • GreaterThanOrEqualTo
  • LessThanOrEqualTo
  • StartsWith
  • EndsWith
  • Contains
  • IsNull
value FlowElementReferenceOrValue Reference or value used with the field and operator to filter records.

FlowRecordLookup

Finds records in the database and stores their field values in the flow. Corresponds to a Get Records element in Flow Builder. It extends FlowNode and inherits all its fields.

The flow record create, lookup, update, and delete operations are different from the CRUD-based metadata calls create(), retrieve(), update(), and delete(). The flow record methods apply to record operations from within a flow, which aren’t the same as doing any metadata calls to CRUD setup entities.

Note

Field Name Field Type Description
assignNullValuesIfNoRecordFound boolean Specifies that all values are set to null when no record is found. Supported only when storeOutputAutomatically is false.

This field is available in API version 30.0 and later.

connector FlowConnector Specifies which node to execute after getting records from the database.
faultConnector FlowConnector Specifies which node to execute if the attempt to get records results in an error.
filters FlowRecordFilter[] An array that specifies the criteria used to select the record from the database.

If the filters return more than one record, they’re sorted according to the specified sortField and sortOrder. If outputReference specifies a non-collection record variable or if getFirstRecordOnly is true, only the first record in the sorted list is selected.

If sortField or sortOrder isn’t specified, records aren’t returned in any particular order. If outputReference specifies a non-collection record variable or if getFirstRecordOnly is true, only the first record in the unsorted list is selected.

getFirstRecordOnly boolean Indicates whether to store field values for only one record, even when multiple records meet the filter criteria. Supported only when storeOutputAutomatically is true. When storeOutputAutomatically is false, what determines whether one or multiple records are stored is whether outputReference specifies a record variable or a record collection variable.

This field is available in API version 47.0 and later.

limit int The maximum number of records to return, to limit the amount of data received. This field is available in API version 30.0 and later.
object string Required. Name of the object from which to select the record.
outputAssignments FlowOutputFieldAssignment[] An array that assigns fields from the selected record to variables that can be used elsewhere in the flow. Supported only when storeOutputAutomatically is false.
outputReference string Specifies the record variable or record collection variable that stores the queried fields’ values. Supported only when storeOutputAutomatically is false.
queriedFields string[] An array that specifies which fields from the selected record is saved to the specified record variable.
sortField string Field that is used for sorting the records that meet the filter criteria. If this field isn’t specified, the returned records aren’t sorted.

You can only sort records by fields that have the Sort API field property, as specified in SOAP API.

This field is available in API version 25.0 and later.

sortOrder SortOrder (enumeration of type string) Order in which to sort the records. If this field isn’t specified, then the results aren’t sorted.
Valid values are:
  • Asc—Ascending
  • Desc—Descending

This field is available in API version 25.0 and later.

storeOutputAutomatically boolean Indicates whether the returned records’ field values are automatically available in the flow without creating any variables. When the value is true, the flow can reference a field by specifying the name of the Get Records element and the record field, such as Get_Contacts.AccountId. Supported only when processType is Flow or AutoLaunchedFlow.

This field is available in API version 47.0 and later.

FlowRecordRollback

Rolls back the current transaction and cancels its pending record changes. Corresponds to the Roll Back Records element in Flow Builder. Available only in screen flows.

FlowRecordRollback extends FlowNode and inherits all of its fields. Available in API version 52.0 and later.

Field Name Field Type Description
connector FlowConnector Specifies which node to execute after rolling back the current transaction.

FlowRecordUpdate

Finds records in the database and updates them with values from the flow. It extends FlowNode and inherits all of its fields.

The flow record create, lookup, update, and delete operations are different from the CRUD-based metadata calls create(), retrieve(), update(), and delete(). The flow record methods apply to record operations from within a flow, which aren’t the same as doing any metadata calls to CRUD setup entities.

Note

Field Name Field Type Description
connector FlowConnector Specifies which node to execute after completing the record update.
faultConnector FlowConnector Specifies which node to execute if the attempt to update a record results in an error.
filters FlowRecordFilter[] An array that specifies the criteria used to select the records to update in the database.
inputAssignments FlowInputFieldAssignment[] An array that assigns values to the specified fields of the record being updated.
inputReference string Specifies the record variable whose field values are used to update the record’s fields.
object string Required. Name of the object whose records are updated.

FlowRule

Defines the conditions and logic that would enable a rule to evaluate to true. It extends FlowElement and inherits all of its fields.

Field Name Field Type Description
conditionLogic string Specifies logic for the conditions. Value can be:
  • and—Evaluates to true only if all its conditions evaluate to true
  • or—Evaluates to true if any of its conditions evaluate to true
  • Advanced logic like 1 AND (2 OR 3)—Evaluates to true if the first condition is true and either the second or third condition is true

    When you use advanced logic, the string must consist of 1,000 or fewer characters.

conditions FlowCondition[] An array of conditions for the rule.
connector FlowConnector Specifies which node to execute if this is the first rule that evaluates to true in a decision.
label string Required. Label for the connector.
doesRequireRecordChangedToMeetCriteria boolean If set to true, conditions evaluate to true only if the record didn't meet the required conditions before the triggering update, but now meets the conditions after the update. Available in API version 50.0 and later.

FlowScreen

Screens capture information from users and display information to users. It extends FlowNode and inherits all its fields.

Field Name Field Type Description
allowBack boolean Indicates whether to show (true) or hide (false) the Previous button on the screen at runtime. When true, the Previous button appears only if the user visited a previous screen in the flow path and if showFooter for the screen is set to true. Set this field to false when revisiting the previous screen triggers an action that you don’t want repeated, such as a credit card transaction.

This field is available in API version 26.0 and later.

Default: true

You can set either allowBack or allowFinish to false, but not both.

allowFinish boolean Indicates whether to show (true) or hide (false) the Finish button on the screen at runtime. When true, the Finish button appears only if the screen element is the end of a flow path and if showFooter for the screen is set to true. Set this to false if you need the user to go back to a previous screen to continue or complete the flow. For example, you wouldn’t include a Finish button on a screen that tells the user to go back and make corrections on a previous screen.

This field is available in API version 26.0 and later.

Default: true

You can set either allowBack or allowFinish to false, but not both.

allowPause boolean Indicates whether to show (true) or hide (false) the Pause button on the screen at runtime. The default value is true.
A flow screen displays the Pause button if all these conditions are true.
  • In the organization’s process automation settings, Let users pause flows is enabled.
  • allowPause for the screen is set to true.
  • If the flow is embedded in a Visualforce page, the <flow:interview> component has its showAllowPause attribute set to true.
  • The showFooter field for the screen is set to true.

This field is available in API version 33.0 and later.

backButtonLabel string
connector FlowConnector Specifies which node to execute after the screen node.
fields FlowScreenField[] An array of fields to display on the screen.
helpText string Text that appears if the end user clicks a link for help text.

Supports merge fields in API version 26.0 and later.

nextOrFinishButtonLabel string
pauseButtonLabel string
pausedText string Confirmation message that appears when an end user clicks Pause.

This field is available in API version 33.0 and later.

rules FlowScreenRule[] Reserved for future use.
showFooter boolean Indicates whether to show (true) or hide (false) the screen’s footer at Lightning runtime. Classic runtime isn’t supported. The default value is true.

The footer includes navigation actions for the screen. If showFooter is hidden, use Lightning components on the screen to show navigation actions.

This field is available in API version 42.0 and later.

showHeader boolean Indicates whether to show (true) or hide (false) the screen’s header at Lightning runtime. Classic runtime isn’t supported. The default value is true.

The header includes access to help text for the screen. If showHeader is hidden, use Lightning components on the screen to show help text.

This field is available in API version 42.0 and later.

FlowScreenField

Represents a screen component. FlowScreenField extends FlowElement and inherits all its fields.

Field Name Field Type Description
choiceReferences string[] An array of references to FlowChoices or FlowDynamicChoiceSets. The resulting choice options appear in the order specified in this array, where the element at index 0 provides the top-most choice option. Supported for these types of screen components:
  • RadioButtons
  • DropdownBox
  • MultiSelectCheckboxes
  • MultiSelectPicklist

Multi-select checkboxes and multi-select picklist fields are available in API version 26.0 and later.

dataType FlowDataType (enumeration of type string) Data type of the screen component. Only supported for the InputField, RadioButtons, and DropdownBox types of screen components. Valid data types are:
  • Boolean
  • Currency
  • Date
  • DateTime
  • Number
  • String

Boolean input fields, which appear as checkbox fields at runtime, are available in API version 26.0 and later.

Only the string data type is supported for multi-select checkboxes and multi-select picklist fields. Multi-select fields are available in API version 26.0 and later.

Date/time input fields are available in API version 43.0 and later.

dataTypeMappings FlowDataTypeMapping[] Reserved for future use.
defaultSelectedChoiceReference string The name of the FlowChoice element to use as the default value for the screen component. Supported for these types of screen components:
  • RadioButtons
  • DropdownBox
  • MultiSelectCheckboxes
  • MultiSelectPicklist

For DropdownBox field types only, if defaultSelectedChoiceReference is empty or null, the reference at index 0 of choiceReferences is used as the default value.

You can specify only one FlowChoice element as the default value for multi-select checkboxes and multi-select picklist fields. Multi-select fields are available in API version 26.0 and later.

defaultValue FlowElementReferenceOrValue The value that is used by default when the screen component requires users to provide input. Only supported for InputField, LargeTextArea, and PasswordField.
extensionName string The name of the Lightning component to display. This field is available in API version 42.0 and later.
fieldText string Field label that is displayed on the screen. Supports merge fields.
fieldType FlowScreenFieldType (enumeration of type string) Required. Valid values are:
  • DisplayText
  • InputField
  • LargeTextArea
  • PasswordField
  • RadioButtons
  • DropdownBox
  • MultiSelectCheckboxes–Available in API version 26.0 and later
  • MultiSelectPicklist–Available in API version 26.0 and later
  • ComponentInstance–Available in API version 42.0 and later
  • ComponentChoice and ComponentInput–Available in API version 48.0 and later for the Survey processType value only

At runtime, each multi-select field stores its field value as a concatenation of the user-selected choice values, separated by semicolons. Any semicolons in the selected choice values are removed when added to the multi-select field value.

helpText string Text that appears if the end user clicks the help icon (info) for the screen component.

Supports merge fields in API version 26.0 and later.

inputParameters FlowScreenFieldInputParameter[] An array of input parameters. Supported only when fieldType is ComponentInstance.

This field is available in API version 42.0 and later.

isRequired boolean Indicates whether the user must select a choice or provide input. Not supported for DisplayText or boolean inputField.
isVisible boolean Reserved for future use.
outputParameters FlowScreenFieldOutputParameter[] An array of output parameters. Supported only when fieldType is ComponentInstance and when storeOutputAutomatically is false.

This field is available in API version 42.0 and later.

regionContainerType FlowRegionContainerType (enumeration of type string) Stores information about a section component header. Possible values include:
  • SectionWithHeader
  • SectionWithoutHeader

Available only when the component type is Section. Available in API version 55.0 and later.

scale int Controls the number of digits to the right of the decimal point up to 17 places. If you leave this field blank or set it to zero, only whole numbers appear when your flow runs. Available only when the data type is Number or Currency. Corresponds to the Decimal Places field in Flow Builder.
storeOutputAutomatically boolean Indicates whether the screen component’s output parameters are automatically available in the flow without creating any variables. When the value is true, you can reference an output parameter by specifying the name of the screen component and the output parameter, such as Mailing_Address.City.

Supported only when fieldType is ComponentInstance.

This field is available in API version 47.0 and later.

validationRule FlowInputValidationRule A rule used to validate the user input when the screen component is of type InputField, LargeTextArea, or PasswordField.
visibilityRule FlowVisibilityRule A rule based on conditions that is used to render or hide the screen component.

This field is available in API version 47.0 and later.

FlowScreenFieldInputParameter

Defines an input parameter from the flow to the extension. It extends FlowBaseElement and inherits all its fields. FlowScreenFieldInputParameter is available in API version 42.0.

Field Name Field Type Description
name string Required. Unique name for the input parameter.
value string Defines the value of the input parameter.

FlowScreenFieldOutputParameter

Defines an output parameter from the extension to the flow. It extends FlowBaseElement and inherits all its fields. FlowScreenFieldOutputParameter is available in API version 42.0.

Field Name Field Type Description
assignToReference string Required. Specifies the variable to which you want to assign the output parameter value.
name string Required. Unique name for the output parameter.

FlowStage

A section of your flow that can be represented in the UI, such as with breadcrumbs. It extends FlowElement and inherits all its fields.

When an interview starts, any stages where isActive is true are added to the $Flow.ActiveStages global variable, which holds a collection of stages. Each stage’s stageOrder determines the order they’re added in. The stage with the lowest stageOrder is assigned to the $Flow.CurrentStage global variable.

Field Name Field Type Description
isActive boolean Indicates whether the stage is active by default.
label string A user-friendly label for this stage.
stageOrder int Indicates how the stage should be ordered against other stages. The stageOrder value must be unique within the flow.

FlowStageStep

A step resource defines a step within a stage node. Available in API version 53.0 and later.

Field Name Field Type Description
actionName string Required. Name of the flow associated with the step.
actionType InvocableActionType (enumeration of type string) Required. The type of the step. Valid values are:
  • stepBackground
  • stepInteractive
assignees FlowStageStepAssignee[] An array of users, groups, or queues assigned to complete the interactive step.
entryActionInputParameters FlowStageStepEntryActionInputParameter[] An array of input parameters from the step to the evaluation flow used as an entry condition for the step.
entryActionName string Name of the evaluation flow used as an entry condition for the step.
entryActionOutputParameters FlowStageStepEntryActionOutputParameter[] An array of output parameters from the evaluation flow to the step used to determine if the step can be started.
entryActionType InvocableActionType (enumeration of type string) The type of the evaluation flow used as a custom entry condition for the step. Valid values are:
  • EvaluationFlow
entryConditionLogic string Reserved for internal use.
entryConditions FlowCondition[] An array of conditions to be met for starting the step.
exitActionInputParameters FlowStageStepExitActionInputParameter[] An array of input parameters from the step to the evaluation flow used as an exit condition for the step.
exitActionName string Name of the evaluation flow used as an exit condition for the step.
exitActionOutputParameters FlowStageStepExitActionOutputParameter[] An array of output parameters from the evaluation flow to the step used to determine if the step meets its exit criteria.
exitActionType InvocableActionType (enumeration of type string) The type of the evaluation flow used as a custom exit condition for the step. Valid values are:
  • EvaluationFlow
inputParameters FlowStageStepInputParameter[] An array of input parameters from the step to its associated flow.
label string Required. The label for the step.
outputParameters FlowStageStepOutputParameter[] An array of output parameters from a flow to its associated step.
requiresAsyncProcessing boolean Indicates whether the background step is processed asynchronously.

FlowStageStepAssignee

An assignee associated with an Interactive step. Applicable only for interactive steps. Available in API version 53.0 and later.

Field Name Field Type Description
assignee FlowElementReferenceOrValue Required. Names of the user, group, or queue assigned to the interactive step.
assigneeType FlowStageStepAssigneeType (enumeration of type string) Required. The type of the assignee associated with the interactive step. Valid values are:
  • Group
  • Queue
  • User

FlowStageStepEntryActionInputParameter

Defines an input parameter from the step to its associated evaluation flow. It extends FlowBaseElement and inherits all its fields. Available in API version 53.0 and later.

Field Name Field Type Description
name string Required. Unique name for the input parameter of the evaluation flow used by a step as an entry condition.
value FlowElementReferenceOrValue Defines the value of the input parameter of the evaluation flow used by a step as an entry condition.

FlowStageStepEntryActionOutputParameter

Defines an output parameter from an evaluation flow used to determine if the step meets entry criteria. It extends FlowBaseElement and inherits all its fields. Available in API version 53.0 and later.

Field Name Field Type Description
assignToReference string Reserved for future use.
name string Required. Unique name for the output parameter of the evaluation flow used by a step as an entry condition. Valid values are:
  • isOrchestrationConditionMet

FlowStageStepExitActionInputParameter

Defines an input parameter from the stage or step to its associated evaluation flow. It extends FlowBaseElement and inherits all its fields. Available in API version 53.0 and later.

Field Name Field Type Description
name string Required. Unique name for the input parameter of the evaluation flow used by a stage or step as an exit condition.
value FlowElementReferenceOrValue Defines the value of the input parameter of the evaluation flow used by a stage or step as an exit condition.

FlowStageStepExitActionOutputParameter

Defines an output parameter from an evaluation flow used to determine if the stage or step meets exit criteria. It extends FlowBaseElement and inherits all its fields. Available in API version 53.0 and later.

Field Name Field Type Description
assignToReference string Reserved for future use.
name string Required. Unique name for the output parameter of the evaluation flow used by a stage or step as an exit condition. Valid values are:
  • isOrchestrationConditionMet

FlowStageStepInputParameter

Defines an input parameter from the step to the flow. It extends FlowBaseElement and inherits all its fields. Available in API version 53.0 and later.

Field Name Field Type Description
name string Required. Unique name for the input parameter for a flow associated with the step.
value FlowElementReferenceOrValue Defines the value of the input parameter of the flow associated with a step.

FlowStageStepOutputParameter

Defines an output parameter from the step to the flow. It extends FlowBaseElement and inherits all its fields. Available in API version 53.0 and later.

Field Name Field Type Description
assignToReference string Reserved for future use.
name string Required. Unique name for the output parameter for a flow associated with the step.

FlowStart

Represents the flow’s Start element, which specifies how the flow starts. In an autolaunched flow, the Start element can also define when and how frequently to run the flow and whether to run the flow for a set of records that meet filter criteria.

FlowStart extends FlowNode and inherits all its fields except name and label. Available in API version 47.0 and later.

Field Name Field Type Description
connector FlowConnector Specifies which element to execute first.
doesRequireRecordChangedToMeetCriteria boolean If set to true, conditions evaluate to true only if the record didn't meet the required conditions before the triggering update, but now meets the conditions after the update. Available in API version 50.0 and later.
filterFormula string A formula used to filter which records execute the flow during a save. Available only in record-triggered flows. Available in API version 55.0 and later.
filterLogic string The filter logic applied to the filter condition requirements. To require all conditions, use AND. To require any conditions, use OR. For custom condition logic, enter the entire logic string, for example 1 AND 2 OR (3 AND 4). Available in API version 50.0 and later.
filters FlowRecordFilter[] An array of filters to apply when retrieving records from the database. For example, filter accounts to include only the records that haven’t been updated in the last 4 weeks.
object string The object whose records you want to retrieve from the database. A flow interview starts for each record that meets the filter conditions.
recordTriggerType RecordTriggerType (enumeration of type string) Specifies what type of record changes can start the flow. Possible values are:
  • Create—When a record is created.
  • Update—When a record is updated,
  • CreateAndUpdate—When a record is created and updated.
  • Delete—When a record is deleted. Available in API version 50.0 and later.

Available only when triggerType is RecordBeforeSave. This field is available in API version 48.0 and later.

schedule FlowSchedule Required when triggerType is Scheduled. Specifies when and how frequently the flow runs.
scheduledPaths FlowScheduledPath[] Specifies the flow's scheduled paths. Available in API version 51.0 and later.
triggerType FlowTriggerType (enumeration of type string) Specifies what causes the flow to run. If you exclude this field, the flow has no trigger and starts only when a user or app launches the flow. Possible values are:
  • PlatformEvent—The flow starts when a platform event message is received. This value is available in API version 49.0 and later.
  • RecordAfterSave—The flow starts after a record is saved. This value is available in API version 49.0 and later.
  • RecordBeforeSave—Creating and/or updating a record triggers an autolaunched flow to make more updates to that record before it’s saved to the database. This value is available in API version 48.0 and later.
  • RecordBeforeDelete—Deleting a record triggers an autolaunched flow before the record is deleted from the database. This value is available in API version 50.0 and later.
  • Scheduled—The flow starts at the scheduled time. This value is available in API version 47.0 and later.

Available only when processType is AutoLaunchedFlow. This field is available in API version 47.0 and later.

FlowSchedule

Specifies when and how frequently to run the flow. Available in API version 47.0 and later.

Field Name Field Type Description
frequency FlowStartFrequency (enumeration of type string) Specifies how frequently to run the flow. Valid values are:
  • Once
  • Daily
  • Weekly
startDate date The date when the flow runs, or when the flow’s run schedule starts recurring.
startTime time The time of day when the flow runs, based on the org’s default time zone.

FlowScheduledPath

Defines a scheduled path. It extends FlowElement and inherits all its fields. Available in API version 51.0 and later.

Field Name Field Type Description
connector FlowConnector Specifies which node to execute after this scheduled path.
label string Label for the scheduled path.
maxBatchSize int The maximum number of scheduled path interviews to execute in a single batch, from 1 to 200. Default is 200.
offsetNumber int Number of days, hours, or minutes to offset the time that the scheduled path executes. Negative values offset the time to execute before the provided time. Positive values offset the time to execute after the provided time.
offsetUnit FlowScheduledPathOffsetUnit (enumeration of type string) Specify the time unit used to offset when the scheduled path executes. Possible values are:
  • Days
  • Hours
  • Minutes
pathType FlowScheduledPathType (enumeration of type string) The type of scheduled path. null is used for time-triggered and record-triggered paths. The default value is null.
  • AsyncAfterCommit—The scheduled path runs asynchronously after a save.
recordField string The field used to determine when the scheduled path executes. The field’s object is defined in FlowStart.
timeSource FlowScheduledPathTimeSource (enumeration of type string) Specify if a field or event is used to determine when the scheduled path executes. Possible values are:
  • RecordField
  • RecordTriggerEvent

FlowStep

Steps function as placeholders when you're building a flow. It extends FlowNode and inherits all its fields.

Field Name Field Type Description
connectors FlowConnector[] Specifies which node to execute after the step node.

FlowSubflow

A subflow element references another flow, which it calls at run time. The flow that contains the subflow element is referred to as the master flow. FlowSubflow extends FlowNode and inherits all of its fields. It’s available in API version 25.0 and later.

Field Name Field Type Description
connector FlowConnector Specifies which node to execute after the subflow.
flowName string References the flow to call at runtime. The value must be an API name of a flow and it can’t contain an appended hyphen and version number.
inputAssignments FlowSubflowInputAssignment[] An array of input variable assignments that are set at the start of the referenced flow.
outputAssignments FlowSubflowOutputAssignment[] An array of output variable assignments that are set at the end of the referenced flow.
storeOutputAutomatically boolean Indicates whether the subflow’s output parameters are automatically available in the flow without creating any variables. When the value is true, you can reference an output parameter by specifying the API name of the subflow in the flow. When the value is false, create variables manually to store output values from the subflow. The default value is false.

This field is available in API version 49.0 and later.

FlowSubflowInputAssignment

Assigns an element or value from the master flow to a variable in the referenced flow. Input assignments occur when the subflow calls the referenced flow. It extends FlowBaseElement and inherits all its fields. It’s available in API version 25.0 and later.

Field Name Field Type Description
name string Required. Unique name for the variable in the referenced flow.
value FlowElementReferenceOrValue Defines the value to assign to the variable.

FlowSubflowOutputAssignment

Assigns the value of a variable from the referenced flow to a variable in the master flow. Output assignments occur when the referenced flow is finished running. It extends FlowBaseElement and inherits all its fields. It’s available in API version 25.0 and later.

Field Name Field Type Description
assignToReference string Required. Unique name for the variable in the master flow.
name string Required. Unique name for the variable in the referenced flow.

FlowTextTemplate

Defines a text template that can be used throughout the flow. It extends FlowElement and inherits all its fields.

Field Name Field Type Description
isViewedAsPlainText boolean If set to true, the flow resource remembers the View as Plain Text setting used for the text template after the flow resource is saved. If set to false, the flow resource uses the View as Rich Text setting.

Default value is false.

text string Actual text of the template. Supports merge fields.

FlowVariable

Variables allow you to create updatable values to use in the flow. FlowVariable extends FlowElement and inherits all its fields.

Field Name Field Type Description
apexClass string The Apex class of this variable if its data type is Apex. Available in API version 46.0 and later.
dataType FlowDataType (enumeration of type string) Required. Valid types are:
  • Apex—This value is available in API version 46.0 and later.
  • Boolean
  • Currency
  • Date
  • DateTime—This value is available in API version 30.0 and later.
  • Number
  • Multipicklist—This value is available in API version 34.0 and later.
  • Picklist—This value is available in API version 34.0 and later.
  • String
  • sObject—This value corresponds to a record variable.
isCollection boolean Indicates whether the variable is a collection of values. This field is available in API version 30.0 and later. In API version 32.0 and later, a collection variable can be of any data type.

Default value is False.

isInput boolean Indicates whether the variable can be set at the start of the flow using URL parameters, Visualforce controllers, or subflow inputs. This field is available in API version 25.0 and later.
Default value:
  • False for a variable created in API version 25.0 and later or in the Flow Builder in Summer ’12 and later.
  • True for a variable created in API version 24.0 or in Flow Builder in Spring ’12 and earlier.

Disabling input or output access for an existing variable can break the functionality of applications and pages that call the flow and access the variable. For example, you can access variables from URL parameters, processes, and other flows.

Warning

isOutput boolean Indicates whether the variable’s value can be accessed from Visualforce controllers and other flows. This field is available in API version 25.0 and later.
Default value:
  • False for a variable created in API version 25.0 and later or in the Flow Builder in Summer ’12 and later.
  • True for a variable created in API version 24.0 or in Flow Builder in Spring ’12 and earlier.

Disabling input or output access for an existing variable can break the functionality of applications and pages that call the flow and access the variable. For example, you can access variables from URL parameters, processes, and other flows.

Warning

objectType string Object type of this variable if its data type is sObject.
scale int Controls the number of digits to the right of the decimal point up to 17 places. If you leave this field blank or set it to zero, only whole numbers appear when your flow runs. Available only when the data type is Number or Currency. Corresponds to the Decimal Places field in Flow Builder.
value FlowElementReferenceOrValue Default value of this variable.

Default values aren’t supported if the variable’s data type is Picklist or Multipicklist.

FlowVisibilityRule

Visibility rules render a flow screen component when visibility rule conditions are met. Hides a flow screen component when visibility rule conditions aren’t met. Available in API version 47.0 and later.

Field Name Field Type Description
conditionLogic string Specifies logic for the conditions. Value can be:
  • and—Evaluates to true only if all its conditions evaluate to true
  • or—Evaluates to true if any of its conditions evaluate to true
  • Advanced logic like 1 AND (2 OR 3)—Evaluates to true if the first condition is true and either the second or third condition is true

    When you use advanced logic, the string must consist of 1,000 or fewer characters.

conditions FlowCondition[] An array of conditions that must be true for the flow to wait for this event.

FlowWait

Waits for one or more defined events to occur. FlowWait extends FlowNode and inherits all its fields. FlowWait is available in API version 32.0 and later.

Field Name Field Type Description
defaultConnector FlowConnector Specifies which node to execute if the conditions are false for every event in the Wait element.
defaultConnectorLabel string Label for the default connector.
faultConnector FlowConnector Specifies which node to execute if the attempt to wait results in an error. If any of the wait events fail, the flow takes the fault connector.
waitEvents FlowWaitEvent[] An array of events that the Wait element is waiting for.

If the conditions for every event evaluate to false, the defaultConnector is used.

FlowWaitEvent

An event that a FlowWait element is waiting for. FlowWaitEvent extends FlowElement and inherits all its fields. FlowWaitEvent is available in API version 32.0 and later.

Field Name Field Type Description
conditionLogic string Specifies logic for the conditions. Value can be:
  • and—Evaluates to true only if all its conditions evaluate to true
  • or—Evaluates to true if any of its conditions evaluate to true
  • Advanced logic like 1 AND (2 OR 3)—Evaluates to true if the first condition is true and either the second or third condition is true

    When you use advanced logic, the string must consist of 1,000 or fewer characters.

conditions FlowCondition[] An array of conditions that must be true for the flow to wait for this event.
connector FlowConnector Specifies which node to execute if this is the first event that occurs.
eventType string Required. The event’s type. The type determines which input parameters are available to define this event. Valid values are:
  • AlarmEvent—This event is an alarm based off an absolute date/time value.
  • DateRefAlarmEvent—This event is an alarm based off a date/time field on a record.
inputParameters FlowWaitEventInputParameter[] An array of the event’s input parameters. The parameter values are set by using values from the flow.
label string Required. Label for the wait event.
outputParameters FlowWaitEventOutputParameter[] An array of the event’s output parameters. The parameter values are assigned from the event to variables in the flow.

FlowWaitEventInputParameter

An input parameter for FlowWaitEvent. The parameter’s value is set by using values from the flow. It extends FlowBaseElement and inherits all its fields. FlowWaitEventInputParameter is available in API version 32.0 and later.

Field Name Field Type Description
name string Required. Unique name for the input parameter.
value FlowElementReferenceOrValue Defines the value of the input parameter.

FlowWaitEventOutputParameter

An output parameter for FlowWaitEvent. The parameter’s value is assigned to a variable in the flow so that it can be referenced in another part of the flow. It extends FlowBaseElement and inherits all its fields. FlowWaitEventOutputParameter is available in API version 32.0 and later.

Field Name Field Type Description
assignToReference string Required. Specifies the variable to which you want to assign the output parameter value.
name string Required. Unique name for the output parameter.

Upgrade Flow Files to API Version 44.0 or Later

In API version 43.0 and earlier, the Flow object’s fullName field included the flow’s version number. Starting in API version 44, the field no longer includes the version number. Before you deploy using API version 44.0 via Metadata API or Salesforce CLI, make sure that:
  • The flows directory doesn’t include any unused flow versions.
  • For each active flow, the status field is Active. Any flow without a status value is deployed or retrieved with a status value of Draft.
  • The flowDefinitions directory is empty.
For Metadata API only.
  • The package.xml file is set to API version 44.0.
  • For the latest version of each flow, the file name doesn't include a version number. For example, change myflow-3.flow to myflow.flow.
For Salesforce CLI only.
  • The sfdx-project.json file is set to "sourceApiVersion": "44.0".
  • For the latest version of each flow, the file name doesn’t include a version number. For example, change myflow-1.flow-meta.xml to myflow.flow-meta.xml.

As part of this upgrade, flow definitions are no longer necessary when you deploy or retrieve via Metadata API. If you deploy with flow definitions, the active version numbers in the flow definitions override the status fields in the flows. For example, the active version number in the flow definition is version 3, and the latest version of the flow is version 4 with the status field as Active. After you deploy your flow, the active version is version 3.

After you finished this upgrade, you can integrate with a version control system without worrying about flow file names changing. To reduce deployment issues when you push the source code into a scratch org, make sure that you don’t reuse an existing scratch org.

Declarative Metadata Sample Definition

Here’s a sample XML definition of a flow.

1<?xml version="1.0" encoding="UTF-8"?>
2<Flow xmlns="http://soap.sforce.com/2006/04/metadata">
3    <actionCalls>
4        <name>Post_to_Contact_s_Feed</name>
5        <label>Post to Contact&apos;s Feed</label>
6        <locationX>269</locationX>
7        <locationY>396</locationY>
8        <actionName>chatterPost</actionName>
9        <actionType>chatterPost</actionType>
10        <connector>
11            <targetReference>Confirm</targetReference>
12        </connector>
13        <inputParameters>
14            <name>text</name>
15            <value>
16                <elementReference>chatterMessage</elementReference>
17            </value>
18        </inputParameters>
19        <inputParameters>
20            <name>subjectNameOrId</name>
21            <value>
22                <elementReference>contact.Id</elementReference>
23            </value>
24        </inputParameters>
25        <storeOutputAutomatically>true</storeOutputAutomatically>
26    </actionCalls>
27    <actionCalls>
28        <name>Get_Info</name>
29        <label>Get Info</label>
30        <locationX>372</locationX>
31        <locationY>354</locationY>
32        <actionName>GetFirstFromCollection</actionName>
33        <actionType>apex</actionType>
34        <dataTypeMappings>
35            <typeName>T__inputCollection</typeName>
36            <typeValue>Account</typeValue>
37        </dataTypeMappings>
38        <dataTypeMappings>
39            <typeName>U__outputMember</typeName>
40            <typeValue>Account</typeValue>
41        </dataTypeMappings>
42        <inputParameters>
43            <name>inputCollection</name>
44            <value>
45                <elementReference>accts</elementReference>
46            </value>
47        </inputParameters>
48        <storeOutputAutomatically>true</storeOutputAutomatically>
49    <assignments>
50        <name>Set_Contact_ID</name>
51        <label>Set Contact ID</label>
52        <locationX>568</locationX>
53        <locationY>396</locationY>
54        <assignmentItems>
55            <assignToReference>contact.Id</assignToReference>
56            <operator>Assign</operator>
57            <value>
58                <elementReference>existingId</elementReference>
59            </value>
60        </assignmentItems>
61        <connector>
62            <targetReference>Update_Contact</targetReference>
63        </connector>
64    </assignments>
65    <decisions>
66        <name>Update_If_Existing</name>
67        <label>Update If Existing?</label>
68        <locationX>260</locationX>
69        <locationY>52</locationY>
70        <defaultConnector>
71            <targetReference>Create_Contact</targetReference>
72        </defaultConnector>
73        <defaultConnectorLabel>No</defaultConnectorLabel>
74        <rules>
75            <name>Update_Yes</name>
76            <conditionLogic>and</conditionLogic>
77            <conditions>
78                <leftValueReference>updateExisting</leftValueReference>
79                <operator>EqualTo</operator>
80                <rightValue>
81                    <booleanValue>true</booleanValue>
82                </rightValue>
83            </conditions>
84            <connector>
85                <targetReference>Find_a_Match</targetReference>
86            </connector>
87            <label>Yes</label>
88        </rules>
89    </decisions>
90    <decisions>
91        <name>Update_or_Create</name>
92        <label>Update or Create?</label>
93        <locationX>447</locationX>
94        <locationY>239</locationY>
95        <defaultConnector>
96            <targetReference>Create_Contact</targetReference>
97        </defaultConnector>
98        <defaultConnectorLabel>Create New</defaultConnectorLabel>
99        <rules>
100            <name>Update_Existing</name>
101            <conditionLogic>and</conditionLogic>
102            <conditions>
103                <leftValueReference>existingId</leftValueReference>
104                <operator>IsNull</operator>
105                <rightValue>
106                    <booleanValue>false</booleanValue>
107                </rightValue>
108            </conditions>
109            <connector>
110                <targetReference>Set_Contact_ID</targetReference>
111            </connector>
112            <label>Update Existing</label>
113        </rules>
114    </decisions>
115    <dynamicChoiceSets>
116        <name>accounts</name>
117        <dataType>String</dataType>
118        <displayField>Name</displayField>
119        <object>Account</object>
120        <outputAssignments>
121            <assignToReference>contact.AccountId</assignToReference>
122            <field>Id</field>
123        </outputAssignments>
124        <valueField>Id</valueField>
125    </dynamicChoiceSets>
126    <formulas>
127        <name>created_or_updated</name>
128        <dataType>String</dataType>
129        <expression>IF({!Create_Contact}, &quot;created&quot;, &quot;updated&quot;)</expression>
130    </formulas>
131    <interviewLabel>New Contact {!$Flow.CurrentDateTime}</interviewLabel>
132    <isAdditionalPermissionRequiredToRun>true</isAdditionalPermissionRequiredToRun>
133    <isTemplate>true</isTemplate>
134    <label>New Contact</label>
135    <processMetadataValues>
136        <name>BuilderType</name>
137        <value>
138            <stringValue>LightningFlowBuilder</stringValue>
139        </value>
140    </processMetadataValues>
141    <processMetadataValues>
142        <name>OriginBuilderType</name>
143        <value>
144            <stringValue>LightningFlowBuilder</stringValue>
145        </value>
146    </processMetadataValues>
147    <processType>Flow</processType>
148    <recordCreates>
149        <name>Create_Contact</name>
150        <label>Create Contact</label>
151        <locationX>269</locationX>
152        <locationY>241</locationY>
153        <connector>
154            <targetReference>Post_to_Contact_s_Feed</targetReference>
155        </connector>
156        <inputReference>contact</inputReference>
157        <storeOutputAutomatically>true</storeOutputAutomatically>
158    </recordCreates>
159    <recordLookups>
160        <name>Find_a_Match</name>
161        <label>Find a Match</label>
162        <locationX>456</locationX>
163        <locationY>53</locationY>
164        <assignNullValuesIfNoRecordsFound>true</assignNullValuesIfNoRecordsFound>
165        <connector>
166            <targetReference>Update_or_Create</targetReference>
167        </connector>
168        <filters>
169            <field>FirstName</field>
170            <operator>EqualTo</operator>
171            <value>
172                <elementReference>contact.FirstName</elementReference>
173            </value>
174        </filters>
175        <filters>
176            <field>LastName</field>
177            <operator>EqualTo</operator>
178            <value>
179                <elementReference>contact.LastName</elementReference>
180            </value>
181        </filters>
182        <object>Contact</object>
183        <outputAssignments>
184            <assignToReference>existingId</assignToReference>
185            <field>Id</field>
186        </outputAssignments>
187        <storeOutputAutomatically>false</storeOutputAutomatically>
188    </recordLookups>
189    <recordUpdates>
190        <name>Update_Contact</name>
191        <label>Update Contact</label>
192        <locationX>456</locationX>
193        <locationY>396</locationY>
194        <connector>
195            <targetReference>Post_to_Contact_s_Feed</targetReference>
196        </connector>
197        <inputReference>contact</inputReference>
198    </recordUpdates>
199    <screens>
200        <name>Confirm</name>
201        <label>Confirm</label>
202        <locationX>270</locationX>
203        <locationY>519</locationY>
204        <allowBack>false</allowBack>
205        <allowFinish>true</allowFinish>
206        <allowPause>true</allowPause>
207        <fields>
208            <name>confirmation_message</name>
209            <fieldText>Thanks! &lt;a href=&quot;/{!contact.Id}&quot;&gt;The contact&lt;/a&gt; was {!created_or_updated}.</fieldText>
210            <fieldType>DisplayText</fieldType>
211        </fields>
212        <showFooter>true</showFooter>
213        <showHeader>true</showHeader>
214    </screens>
215    <screens>
216        <name>Contact_Info</name>
217        <label>Contact Info</label>
218        <locationX>160</locationX>
219        <locationY>50</locationY>
220        <allowBack>true</allowBack>
221        <allowFinish>true</allowFinish>
222        <allowPause>true</allowPause>
223        <connector>
224            <targetReference>Update_If_Existing</targetReference>
225        </connector>
226        <fields>
227            <name>contactName</name>
228            <extensionName>flowruntime:name</extensionName>
229            <fieldType>ComponentInstance</fieldType>
230            <isRequired>true</isRequired>
231            <outputParameters>
232                <assignToReference>contact.FirstName</assignToReference>
233                <name>firstName</name>
234            </outputParameters>
235            <outputParameters>
236                <assignToReference>contact.LastName</assignToReference>
237                <name>lastName</name>
238            </outputParameters>
239        </fields>
240        <fields>
241            <name>Account</name>
242            <choiceReferences>accounts</choiceReferences>
243            <dataType>String</dataType>
244            <fieldText>Account</fieldText>
245            <fieldType>DropdownBox</fieldType>
246            <isRequired>true</isRequired>
247        </fields>
248        <fields>
249            <name>update_toggle</name>
250            <extensionName>flowruntime:toggle</extensionName>
251            <fieldType>ComponentInstance</fieldType>
252            <inputParameters>
253                <name>label</name>
254                <value>
255                    <stringValue>If this contact already exists, update the existing record.</stringValue>
256                </value>
257            </inputParameters>
258            <inputParameters>
259                <name>messageToggleActive</name>
260                <value>
261                    <stringValue>Update existing</stringValue>
262                </value>
263            </inputParameters>
264            <inputParameters>
265                <name>messageToggleInactive</name>
266                <value>
267                    <stringValue>Create other contact</stringValue>
268                </value>
269            </inputParameters>
270            <isRequired>true</isRequired>
271            <outputParameters>
272                <assignToReference>updateExisting</assignToReference>
273                <name>value</name>
274            </outputParameters>
275        </fields>
276        <showFooter>true</showFooter>
277        <showHeader>true</showHeader>
278    </screens>
279    <start>
280        <locationX>50</locationX>
281        <locationY>50</locationY>
282        <connector>
283            <targetReference>Contact_Info</targetReference>
284        </connector>
285    </start>
286    <status>Draft</status>
287    <textTemplates>
288        <name>chatterMessage</name>
289        <text>The contact was {!created_or_updated}.</text>
290    </textTemplates>
291    <variables>
292        <name>contact</name>
293        <dataType>SObject</dataType>
294        <isCollection>false</isCollection>
295        <isInput>false</isInput>
296        <isOutput>false</isOutput>
297        <objectType>Contact</objectType>
298    </variables>
299    <variables>
300        <name>existingId</name>
301        <dataType>String</dataType>
302        <isCollection>false</isCollection>
303        <isInput>false</isInput>
304        <isOutput>false</isOutput>
305    </variables>
306    <variables>
307        <name>updateExisting</name>
308        <dataType>Boolean</dataType>
309        <isCollection>false</isCollection>
310        <isInput>false</isInput>
311        <isOutput>false</isOutput>
312    </variables>
313</Flow>

Wildcard Support in the Manifest File

This metadata type supports the wildcard character * (asterisk) in the package.xml manifest file. For information about using the manifest file, see Deploying and Retrieving Metadata with the Zip File.