Add the #DF24 Developer Keynote to your agenda. Join us in-person on 9/18 at 2:30 p.m. PT or on Salesforce+ at 5 p.m. PT for the must-see session built just for developers.

Prospect Object

Learn more about prospects in Salesforce Help.

OperationURL FormatRequired ParametersDescription
query/api/prospect/version/3/do/query?...user_key, api_keyReturns the prospects matching the specified criteria parameters. See Using Prospects for complete descriptions of prospect XML Response Formats. Also see Prospect in Object Field References.

Search criteria may be used together in any combination and/or order unless otherwise specified. Unless output=mobileis specified, 200 prospects will be returned with each query request. This limit is not enforced for responses formatted for mobile devices.

ParameterDatatypeOptionsDescription
assignedbooleantrue, falseSelects prospects based on whether they are assigned.
assigned_to_userinteger/string<any_positive_integer>, <any_string>Selects prospects based on whether they are assigned to a specified user. Users can be specified by their email address or their Account Engagement IDs. Note: Using assigned_to_user overrides the assigned criteria.
created_afterstringtoday, yesterday, last_7_days, this_month, last_month, <custom_time>Selects prospects that were created after the specified time. If a <custom_time> is used, ensure that the specified date is formatted using GNU Date Input Syntax.
created_beforestringtoday, yesterday, last_7_days, this_month, last_month, <custom_time>Selects prospects that were created before the specified time. If a <custom_time> is used, ensure that the specified date is formatted using GNU Date Input Syntax.
deletedbooleantrue, falseSelects prospects based on whether they have been deleted. Default value: false.
grade_equal_tostringA+, A, A-, B+, B, B-, C+, C, C-, D+, D, D-, FSelects prospects that have a grade equal to the specified grade. Note: Any value provided for grade_equal_to MUST be URL-encoded.
grade_greater_thanstringA+, A, A-, B+, B, B-, C+, C, C-, D+, D, D-, FSelects prospects that have a grade greater than the specified grade. Note: Any value provided for grade_greater_than MUST be URL-encoded.
grade_less_thanstringA+, A, A-, B+, B, B-, C+, C, C-, D+, D, D-, FSelects prospects that have a grade less than the specified grade. Note: Any value provided for grade_less_than MUST be URL-encoded.
id_greater_thaninteger<any_positive_integer>Selects prospects with IDs greater than the specified integer.
id_less_thaninteger<any_positive_integer>Selects prospects with IDs less than the specified integer.
is_starredbooleantrue, falseSelects prospects based on whether they are starred.
last_activity_beforestringtoday, yesterday, last_7_days, this_month, last_month, <custom_time>Selects prospects that have been active before the specified time. If a <custom_time> is used, ensure that the specified date is formatted using GNU Date Input Syntax. Prospects are considered active if a prospect's last_activity_at is before the specified time. See Prospect in Object Field References.
last_activity_afterstringtoday, yesterday, last_7_days, this_month, last_month, <custom_time>Selects prospects that have been active after the specified time. If a <custom_time> is used, ensure that the specified date is formatted using GNU Date Input Syntax. Prospects are considered active if a prospect's last_activity_at is after the specified time. See Prospect in Object Field References.
last_activity_neverbooleanTRUESelects prospects that have never been active. Prospects are considered active if a prospect's last_activity_at is null. See Prospect in Object Field References.
limit_related_recordsbooleantrue, falselimit number of visitor_activity records returned on prospect/read to 2000. When set to false or not specified the system will return all the available visitor records for the requested prospect, but the operation may timeout if there are too many related records.
list_idinteger<any positive integer>Selects prospects based on their membership of the list with the given list_id.
newbooleantrue, falseSelects prospects based on whether they are classified as new. Prospects are considered new if they have not been assigned to a user or a queue, have not been marked as reviewed, and have a last_activity_at timestamp specified. See Prospect in Object Field References. Note: Using the new criteria overrides the assigned, assigned_to_user, last_activity_at, and last_activity_before criteria if specified.
score_equal_tointeger<any_integer>Selects prospects that have a score equal to a specified integer.
score_greater_thaninteger<any_integer>Selects prospects that have a score greater than a specified integer.
score_less_thaninteger<any_integer>Selects prospects that have a score less than a specified integer
updated_afterstringtoday, yesterday, last_7_days, this_month, last_month, <custom_time>Selects prospects that were last updated after the specified time. If a <custom_time> is used, ensure that the specified date is formatted using GNU Date Input Syntax.
updated_beforestringtoday, yesterday, last_7_days, this_month, last_month, <custom_time>Selects prospects that were last updated before the specified time. If a <custom_time> is used, ensure that the specified date is formatted using GNU Date Input Syntax.

Since query result sets are limited to 200 results each, the results returned may not include all prospects that were matched by the query. To retrieve the remaining results, the following criteria can be used to navigate through the result set.

ParameterDatatypeOptionsDescription
fieldsarray<comma_separated_field_ids>Specifies the fields to be returned. Note: If this parameter isn't present, all default fields and custom fields for which the prospect has a value will be returned; <id> will always be returned.
limitinteger<any_positive_integer>Specifies the number of results to be returned. Default value: 200. Note: This number cannot be larger than 200.
offsetinteger<any_positive_integer>Specifies the first matching prospect(according to the specified sorting order) to be returned in the query response. The first offset matching prospects will be omitted from the response. Default value: 0. Example: Specifying offset=400 will return the results starting with the 401st prospect matched by the provided criteria.
outputstringsimple, mobileSpecifies the format to be used when returning the results of the query. See XML Response Formats in Using Prospects for more details.
sort_bystringcreated_at, id, probability, valueSpecifies the field that should be used to sort the results of the query. See Supported Sorting Options for more details.
sort_orderstringascending, descendingSpecifies the ordering to be used when sorting the results of the query. The default value varies based on the value of the sort_by parameter. See Supported Sorting Options for more details.

The ordering of the results returned by a query request can be changed by specifying sort_by and sort_order parameters. Any of the following values are valid when specifying the sort_by parameter. For a complete list of fields involved in Prospect queries, see Prospect in Object Field References.

ValueDefault Sort OrderDescription
created_atdescendingSpecifies that the query results should be sorted by the prospects' created_at timestamps.
idascendingSpecifies that the query results should be sorted by the prospects' id fields.
last_activity_atdescendingSpecifies that the query results should be sorted by the prospects' last_activity_at timestamps.
updated_atdescendingSpecifies that the query results should be sorted by the prospects' updated_at timestamps.
TagDescription
<result>Contains the resulting prospects for the specified query.
<total_results>Contains the number of prospects selected by this query. If this value is higher than 200, then several query requests may be necessary to retrieve all matched prospects.
<prospect>The data for an individual Prospect. See Using Prospects for complete descriptions of prospect XML Response Formats. Also see Prospect in Object Field References. Note: Data concerning a prospect's profile criteria matchings, visitors, visitor activities, and list subscriptions will NOT be included in a query response. To retrieve this data, submit a read request for the prospect of interest.

For a complete list of fields involved in Prospect operations, see the Prospect section of Object Field References.

OperationURL FormatRequired ParametersDescription
assign/api/prospect /version/3 /do/assign/ email/<email>?...user_key, api_key, email, (user_email OR user_id OR group_id)Assigns or reassigns the prospect specified by <email> to a specified Account Engagement user or group. One (and only one) of the following parameters must be provided to identify the target user or group: <user_email>, <user_id>, or <group_id>. Returns an updated version of the prospect. Note: Prospect assignments and reassignments do not overwrite existing assignments in CRMs.
assign/api/prospect /version/3 /do/assign/ id/<id>?...user_key, api_key, id, (user_email OR user_id OR group_id)Assigns or reassigns the prospect specified by <id> to a specified Account Engagement user or group. One (and only one) of the following parameters must be provided to identify the target user or group: <user_email>, <user_id>, or <group_id>. Returns an updated version of the prospect. Note: Prospect assignments and reassignments do not overwrite existing assignments in CRMs.
unassign/api/prospect /version/3 /do/unassign/ email/<email>?...user_key, api_key, emailUnassigns the prospect specified by <email>. Returns an updated version of the prospect. **Note:**Prospect assignments and reassignments do not overwrite existing assignments in CRMs. Note: Prospect assignments and reassignments do not overwrite existing assignments in CRMs.
unassign/api/prospect /version/3 /do/unassign/ id/<id>?...user_key, api_key, idUnassigns the prospect specified by <id>. Returns an updated version of the prospect. Note: Prospect assignments and reassignments do not overwrite existing assignments in CRMs. Note: Prospect assignments and reassignments do not overwrite existing assignments in CRMs.
create/api/prospect /version/3 /do/create/ email/<email>?...user_key, api_key, emailCreates a new prospect using the specified data. <email> must be a unique email address. Email list subscriptions and custom field data may also be added with this request. Refer to the Updating Email List Subscriptions and Updating Field Values sections for more details. Note: The prospect may be assigned to a user by supplying a value for the optional <user_id> parameter.
batchCreate/api/prospect /version/3 /do/batchCreate? prospects=<data>...user_key, api_key, prospectsCreates new prospects using the provided <data> in either XML or JSON. See Endpoints for Batch Processing Note: The prospect may be assigned to a user by supplying a value for the optional <user_id> parameter.
read/api/prospect /version/3 /do/read/ email/<email>?...user_key, api_key, emailReturns data for the prospect specified by <email>, including campaign assignment, profile criteria matching statuses, associated visitor activities, email list subscriptions, and custom field data. <email> is the email address of the target prospect.
read/api/prospect /version/3 /do/read/ id/<id>?...user_key, api_key, idReturns data for the prospect specified by <id>, including campaign assignment, profile criteria matching statuses, associated visitor activities, email list subscriptions, and custom field data. <id> is the Account Engagement ID of the target prospect.
update/api/prospect /version/3 /do/update/ email/<email>?...user_key, api_key, emailUpdates the provided data for a prospect specified by <email>. <email> is the email address of the prospect. Fields that are not updated by the request remain unchanged. Email list subscriptions and custom field data may also be updated with this request. Refer to the Updating Email List Subscriptions and Updating Field Values sections for more details. Returns an updated version of the prospect. Note: Prospect email addresses cannot be updated using this method.
update/api/prospect /version/3 /do/update/ id/<id>?...user_key, api_key, idUpdates the provided data for a prospect specified by <id>. <id> is the Account Engagement ID of the prospect. Fields that are not updated by the request remain unchanged. Email list subscriptions and custom field data may also be updated with this request. Refer to the Updating Email List Subscriptions and Updating Field Values sections for more details. Returns an updated version of the prospect.
batchUpdate/api/prospect /version/3 /do/batchUpdate? prospects=<data>...user_key, api_key, prospectsUpdates prospects using the provided <data> in either XML or JSON. See Endpoints for Batch Processing
upsert/api/prospect /version/3 /do/upsert/ email/<email>?...user_key, api_key, emailUpdates the provided data for the prospect specified by <email>. If a prospect with the provided email address does not yet exist, a new prospect is created using the <email> value. Fields that are not updated by the request remain unchanged. Email list subscriptions and custom field data may also be updated with this request. Refer to the Updating Email List Subscriptions and Updating Field Values sections for more details. Returns an updated version of the prospect. Note: The prospect may be assigned to a user by supplying a value for the optional <user_id> parameter.
upsert/api/prospect /version/3 /do/upsert/ id/<id>?...user_key, api_key, (id OR email)Updates the provided data for the prospect specified by <id>. If an <email> value is provided, it is used to update the prospect's email address. If a prospect with the provided ID is not found, Account Engagement searches for a prospect identified by <email>. If a prospect with the provided email address does not yet exist, a new prospect is created using <email> value. Fields that are not updated by the request remain unchanged. Email list subscriptions and custom field data may also be updated with this request. Refer to the Updating Email List Subscriptions and Updating Field Values sections for more details. Returns an updated version of the prospect. Note: The prospect may be assigned to a user by supplying a value for the optional <user_id> parameter.
batchUpsert/api/prospect /version/3 /do/batchUpsert? prospects=<data>...user_key, api_key, prospectsUpdates prospects using the provided <data> in either XML or JSON. See Endpoints for Batch Processing. Note: The prospect may be assigned to a user by supplying a value for the optional <user_id> parameter.
delete/api/prospect /version/3 /do/delete/ email/<email>?...user_key, api_key, emailDeletes the prospect specified by <email>. Returns HTTP 204 No Content on success. Note: Prospects may only be deleted using HTTP methods POST or DELETE.
delete/api/prospect /version/3 /do/delete/ id/<id>?...user_key, api_key, idDeletes the prospect specified by <id>. Returns HTTP 204 No Content on success. Note: Prospects may only be deleted using HTTP methods POST or DELETE.

For output=full:

For output=simple:

For output=mobile:

TagDescription
<prospect>Parent tag. Contains data fields for the target prospect (including custom fields). For complete field listing, see Prospect in Object Field References.
<value>Child tag of data fields with multiple values. Only appears with custom fields that have multiple values.
<campaign>Contains <id> and <name> of the campaign to which this prospect has been assigned. This leaf only appears if the prospect has been assigned to a campaign.
<assigned_to>Contains a <user> node detailing the user to whom this prospect has been assigned. This leaf only appears if the prospect has been assigned to a user. See User in Object Field References.
<last_activity>Contains a <visitor_activity> node detailing this prospect's most recent activity. This leaf only appears if the prospect has visitor activities associated with it. For complete field listing, see Visitor Activity in Object Field References.
<profile>Contains all data fields for the profile associated with this prospect. Also contains several <profile_criteria> tags. For complete field listing, see Profile in Object Field References.
<profile_criteria>Contains all data fields for the profile criteria associated with the prospect's assigned profile. For complete field listing, see Profile Criteria in Object Field References.
<visitors>Contains all visitors associated with this prospect. Contains only <visitor> tags.
<visitor>Contains data fields for a visitor activity, as well as an <identified_company> and a <visitor_referrer> tag. For complete field listing, see Visitor in Object Field References.
<identified_company>Contains data field for a visitor's identified company. For complete field listing, see Identified Company in Object Field References.
<visitor_referrer>Contains data fields for a visitor's referrer. For complete field listing, see Visitor Referrer in Object Field References.
<visitor_activities>Contains all visitor activities associated with this prospect. Contains only <visitor_activity> tags.
<visitor_activity>Contains data fields for a visitor activity. For complete field listing, see Visitor Activity in Object Field References.
<lists>Contains all email list subscriptions for this prospect. Contains only <list_subscription> tags.
<list_subscription>Contains data fields for an email list subscription, as well as a <list> tag. For complete field listing, see Email List Subscription in Object Field References.
<list>Contains data fields for an email list. For complete field listing, see Email List in Object Field References.

To assign/reassign a prospect, both the prospect to be assigned and the target user or group of the assignment must be defined. Prospects can be specified by their Account Engagement ID or email address. Users or groups can be specified by their Account Engagement user ID, email address, or Account Engagement group ID. Possible combinations of parameters are shown below. Developers are responsible for substituting specific values for parameters denoted by <carets>.

Examples:

/api/prospect/version/3/do/assign/email/?user_email=

/api/prospect/version/3/do/assign/email/?user_id=

/api/prospect/version/3/do/assign/email/?group_id=

/api/prospect/version/3/do/assign/id/?user_email=

/api/prospect/version/3/do/assign/id/?user_id=

/api/prospect/version/3/do/assign/id/?group_id=

XML responses to assign requests are identical to read requests, but reflect the new prospect assignment in the <assigned_to> node.

To create a prospect via the API, only a valid and unique email address is required. Values for any other prospect fields may also be provided in the create request. Developers are responsible for substituting specific values for parameters denoted by <carets>.

Example: Creating a new prospect/api/prospect/version/3/do/create/email/new_prospect@company.com?first_name=New&last_name=Prospect

XML responses to create requests are identical to update and read requests. If no campaign_id value is provided, the new prospect will be automatically assigned to the oldest existing campaign.

There are 3 endpoints available for batch processing up to 50 prospects at a time:

/api/prospect/version/3/do/batchCreate

/api/prospect/version/3/do/batchUpdate

/api/prospect/version/3/do/batchUpsert

These endpoints expect a query variable called "prospects" which holds either JSON or XML encoded data. Each prospect should have a unique identifier which will be used in the return output.

JSON Example:

XML Example:

If using batchCreate, you'll need to provide a valid and unique email address for each prospect. The batchUpdate and batchUpsert endpoints allow the use of a prospect ID or prospect email address.

Example:

/api/prospect/version/3/do/batchUpdate?prospects={"prospects":{"some@email.com":{"first_name":"New first name","last_name":"New last name"},"1234":{"first_name":"New first name","last_name":"New last name"}}}

The return value will either be XML or JSON (XML by default. If you want JSON, then add "&format=json" to your HTTP query).

Modifying values of prospect data fields is done by submitting an update request with parameters for each field to be updated. Each parameter is formatted as <field_name>=<value>. Custom field values are updated using the same syntax.

Example: Updating the phone number of a prospect whose email address is bob@company.com: /api/prospect/version/3/do/update/email/bob@company.com?phone=888-123-4567

Only values that are specifically named in the request are updated. All others are left unchanged. To clear a value, submit an update request containing a parameter with no specified value, such as phone=.

Any field that is set to record multiple responses cannot have its values cleared this way.

Modifying values of prospect data fields with predefined values is accomplished through an update request with parameters for each field to be updated. Each parameter is formatted as <field_name>=<value> where <value> matches the predefined field value. Custom field values are updated using the same syntax.

Example: Updating the category of a prospect whose email address is bob@company.com *to the category consumer: /api/prospect/version/3/do/update/email/bob@company.com?category=consumer

Updating field values with multiple values follows the same convention as fields with predefined values, but requires a different parameter naming scheme to allow multiplicity. An update request is submitted with parameters formatted as <field_name>_<count>=<field_value> where <count> is an integer denoting the current parameter's place in sequence. <count> must start at 0 and increase by 1 until all desired values are submitted.

Example: Modifying the values of a custom field with field name past_jobs for a prospect with a Account Engagement ID of 5: /api/prospect/version/3/do/update/id/5?past_jobs_0=janitor&past_jobs_1=security

Checkbox and multi-select fields are the only field types that can be updated in this manner. To clear all of the values for a checkbox or multi-select field, use <field_name>_0=. To clear specific values, just set the values that should remain in the prospect record using the method above.

To modify email list subscriptions for a prospect, the Account Engagement ID of the email list is required. Once the ID is obtained, an update is submitted with parameters formatted as list_<list_id>=1 to create a subscription and list_<list_id>=0 to end a subscription.

Example: Adding a prospect whose email address is bob@company.com to an email list with Account Engagement ID 8: /api/prospect/version/3/do/update/email/bob@company.com?list_8=1

Requests that attempt to subscribe a prospect to lists that it is already subscribed to are ignored. Unsubscribe requests are handled similarly.

To modify a prospect's matching status for associated profile criteria, the Account Engagement ID of the profile criteria is required. Once the ID is obtained, an update is submitted with parameters formatted as profile_criteria_<profile_criteria_id>=<status>. The value of <status> may be either match, nomatch, or unknown.

Example: Setting a profile criteria for a prospect whose email address is bob@company.com to match: /api/prospect/version/3/do/update/email/bob@company.com?profile_criteria_8=match

Example: Setting a profile criteria for a prospect with Account Engagement ID 58 to nomatch: /api/prospect/version/3/do/update/id/58?profile_criteria_8=nomatch

Only profile criteria that belong to the profile associated with the prospect can be updated using this method. Requests to update profile criteria not associated with the assigned profile will be ignored. Using any matching status values other than match, nomatch, or unknown will result in an error message. See Error Codes & Messages for details.

To modify a prospect's matching status for associated prospect account, the Account Engagement ID of the prospect account is required. Once the ID is obtained, an update is submitted with parameters formatted as prospect_account_id=<id>.

Example: Setting a prospect account for a prospect whose email address is bob@company.com to match: /api/prospect/version/3/do/update/email/bob@company.com?prospect_account_id=

A prospect account with the id must exist, and can not be set if a CRM connector is set up in the account.