Only API keys on our Conversations PRR platform are eligible to use this API version. Refer to the Platforms section of our Platform & API Concepts documentation to learn which platform your API keys are on.

The Conversations API lets you programmatically retrieve and submit Bazaarvoice Conversations data for use in your applications. To learn more, go to the Conversations API documentation home page.

Contents

(+ show- hide)

Submit reviews on a product.

Overview

Submission is divided into the following three HTTP operations controlled by the Action parameter:

Action Description HTTP Method
Action= Response represents fields necessary to create a submission form. The Action parameter is optional for this operation. GET, POST
Action=Preview Used to validate a submission. Response will include errors on failure. Data will not be stored. GET, POST
Action=Submit On success data will be stored and response will include a submission ID. On failure response will contain errors. POST

Action=Submit may occur without first performing Action= and Action=Preview.

Examples

View a review submission form

https://[stg.]api.bazaarvoice.com/data/submitreview.[FORMAT]?ApiVersion=[latestApiVersion]&ProductId=[productId]&PassKey=[yourKey]

This action may be done with an HTTP POST or GET.

View a review submission form prepopulated with user data

https://[stg.]api.bazaarvoice.com/data/submitreview.[FORMAT]?ApiVersion=[latestApiVersion]&ProductId=[productId]&PassKey=[yourKey]&User|UserId=[valueOfUserOrUserId]

Use either the User or UserId parameter depending on your API key configuration. This action may be done with an HTTP POST or GET.

Preview a review submission

https://[stg.]api.bazaarvoice.com/data/submitreview.[FORMAT]?ApiVersion=[latestApiVersion]&ProductId=[productId]&Action=Preview&Rating=[rating]&ReviewText=[reviewText]&Title=[title]&UserNickname=[nickname]&PassKey=[yourKey]

This action may be done with an HTTP POST or GET.

Submit a review

POST /data/submitreview.json HTTP/1.1
Host: [stg.]api.bazaarvoice.com
Content-Type: application/x-www-form-urlencoded
X-Forwarded-For: [AuthorIPAddress]
...

ApiVersion=[latestApiVersion]&ProductId=[productId]&Action=submit&Rating=[rating]&ReviewText=[reviewText]&Title=[title]&UserNickname=[nickname]&PassKey=[yourKey]&fp=[deviceFingerprint]

Ellipses (...) in above example indicate that your app may generate other headers.

This action must take the form of an HTTP POST.

Headers

Name Description
Content-Type

The media-type type of the request body. Value must be application/x-www-form-urlencoded.

Required This field is required in all API requests.

X-Forwarded-For

IP address of content author. This header is only necessary when performing submissions from your server. See Authenticity Tutorial for more information.

Per the Bazaarvoice Authenticity Policy, you must send author IP address attached to each submission. If you fail to send author IP address with your submission, Bazaarvoice may take any action deemed necessary in Bazaarvoice’s sole discretion to protect the integrity of the network. Such actions may include but are not limited to: rejection of your content, halting syndication of your content on the Bazaarvoice network, revocation of your API key, or revocation of your API license.

Alert Failure to submit this field will result in your content being ineligible for syndication, authenticity or other business processes.

Your app may generate other headers.

Parameters

Name Description
[FORMAT]

Response format (xml or json)

Required This field is required in all API requests.

Action

The submission action to take -- either 'Action=', 'Action=Preview' or 'Action=Submit'. 'Action=' will show information that can be used to build a submission form, 'Action=Preview' will show a draft of the content to be submitted; 'Action=Submit' will submit the content. If 'Action=Submit', the request must be an HTTP POST. Learn more.

AdditionalField_<Dimension-External-Id>

A concrete example of the parameter might be 'AdditionalField_Seat' with a value of '24F' (describing the seat number at a stadium or on a plane).

Caution This field may be required depending on per client configurations.

AgreedToTermsAndConditions

Boolean indicating whether or not the user agreed to the terms and conditions. Required depending on the client's settings.

Caution This field may be required depending on per client configurations.

ApiVersion

The API version, e.g. 5.4.

Required This field is required in all API requests.

CampaignId

Arbitrary text that may be saved alongside content to indicate vehicle by which content was captured, e.g. “post-purchase email”.

Cons

Legacy free text tags allow a user to submit a delimited string of negative words or phrases. This field does not support filtering or sorting and is only available to clients with it enabled already. All other clients should use tag dimensions.

PRR This feature is only available to clients on our Conversations PRR platform. Learn more.

Caution This field may be required depending on per client configurations.

ContextDataValue_<Dimension-External-Id>

Some examples of this parameter include the following. Each is followed by possible values.

  • ContextDataValue_PurchaserRank - "top", "top10", "top100", "top1000"
  • ContextDataValue_Purchaser - "yes", "no"
  • ContextDataValue_Age - "under21", "21to34", "35to44", "45to54", "55to64", "over65"
  • ContextDataValue_Gender - "male", "female"

Caution This field may be required depending on per client configurations.

fp

Fingerprint of content author's device. See the Authenticity Tutorial for more information.

Per the Bazaarvoice Authenticity Policy, you must send a device fingerprint attached to each submission. If you fail to send a device fingerprint with your submission, Bazaarvoice may take any action deemed necessary in Bazaarvoice’s sole discretion to protect the integrity of the network. Such actions may include but are not limited to: rejection of your content, halting syndication of your content on the Bazaarvoice network, revocation of your API key, or revocation of your API license.

Alert Failure to submit this field will result in your content being ineligible for syndication, authenticity or other business processes.

HostedAuthentication_AuthenticationEmail

Email address where the submitter will receive the confirmation email. If you are configured to use hosted email authentication, this parameter is required. See the Authenticate User method for more information on hosted authentication.

Caution This field may be required depending on per client configurations.

HostedAuthentication_CallbackUrl

URL of the link contained in the user authentication email. This should point to a landing page where a web application exists to complete the user authentication process. The host for the URL must be one of the domains configured for the client. The link in the email will contain a user authentication token (authtoken) that is used to verify the submitter. If you are configured to use hosted email authentication, this parameter is required. See the hosted authentication tutorial for more information.

Caution This field may be required depending on per client configurations.

IsRecommended

Value is true or false; default is null – "true" or "false" answer to "I would recommend this to a friend".

Caution This field may be required depending on per client configurations.

Locale

Locale to display Labels, Configuration, Product Attributes and Category Attributes in. The default value is the locale defined in the display associated with the API key.

Alert Failure to submit this field will result in your content being ineligible for syndication, authenticity or other business processes.

NetPromoterComment

Value is text representing a user comment to explain numerical Net Promoter score.

NetPromoterScore

Value is positive integer between 1 and 10 representing a numerical rating in response to “How would you rate this company?”

PassKey

API key is required to authenticate API user and check permission to access particular client's data.

Required This field is required in all API requests.

PhotoCaption_<n>

Value is caption text for the photo URL with the same value of <n>.

Caution This field may be required depending on per client configurations.

PhotoUrl_<n>

Value is a Bazaarvoice URL of a photo uploaded using the Data API, where <n> is a non-negative integer. See our photo upload tutorial for more information.

Caution This field may be required depending on per client configurations.

ProductId

The ID of the product that this content is being submitted on.

Required This field is required in all API requests.

ProductRecommendationId_<n>

Value is non-negative integer representing the product external ID of the <n>'th product recommendation (for Social Recommendations)

PRR This feature is only available to clients on our Conversations PRR platform. Learn more.

Pros

Legacy free text tags allow a user to submit a delimited string of positive words or phrases. This field does not support filtering or sorting and is only available to clients with it enabled already. All other clients should use tag dimensions.

PRR This feature is only available to clients on our Conversations PRR platform. Learn more.

Caution This field may be required depending on per client configurations.

Rating

Value is positive integer between 1 and 5, and represents review overall rating. Required depending on client settings.

Caution This field may be required depending on per client configurations.

Rating_<Dimension-External-Id>

A concrete example might be Rating_Quality where the value would represent the user's opinion of the quality of the product. The value is a positive integer between 1 and 5 and represents rating dimension value.

Caution This field may be required depending on per client configurations.

ReviewText

Value is review body text.

Caution This field may be required depending on per client configurations.

SendEmailAlertWhenCommented

Boolean indicating whether or not the user wants to be notified when a comment is posted on the content.

SendEmailAlertWhenPublished

Boolean indicating whether or not the user wants to be notified when his/her content is published.

tag_<Dimension-External-Id>_<n>

A concrete example of the parameter might be 'tag_Pro_1'. Valid values could be any free-form text. <n> should be a non-negative integer starting at the number 1.

tagid_<Dimension-External-Id>/<Tag-Label>

Boolean indicating whether or not the tag applies to the user. A concrete example might be 'tagid_Pro/EasyToUse=true'.

Caution This field may be required depending on per client configurations.

Title

Value is content title text.

Caution This field may be required depending on per client configurations.

User

Value of the encrypted user. This parameter demonstrates that a user has been authenticated. Note that the UserId parameter does not contain authentication information and should not be used for hosted authentication. See the Authenticate User method for more information.

Caution This field may be required depending on per client configurations.

UserEmail

User's email address.

Caution This field may be required depending on per client configurations.

UserId

User's external ID. This value should come from your authentication system. See Client-Mastered Authentication for more information.

Alert Do not use an email address for this value.

Caution This field may be required depending on per client configurations.

UserLocation

User location text.

Caution This field may be required depending on per client configurations.

UserNickname

User nickname display text.

Caution This field may be required depending on per client configurations.

VideoCaption_<n>

Value is caption text for the video URL with the same value of <n>.

Caution This field may be required depending on per client configurations.

VideoUrl_<n>

Value is valid URL to a YouTube video or a Bazaarvoice hosted video where <n> is a non-negative integer.

Caution This field may be required depending on per client configurations.

Response format

Do not reuse the API passkey below in your application.

Preview a review submission:

https://stg.api.bazaarvoice.com/data/submitreview.json?apiversion=5.4&ProductId=1000001&passkey=2cpdrhohmgmwfz8vqyo48f52g&Action=Preview

The following is an example of a review submission response after submitting the form by HTTP POST:

{
  "Data":{},
  "HasErrors":false,
  "Form":[],
  "FormErrors":{},
  "TypicalHoursToPost":72,
  "SubmissionId":"3bjfuudsrjt516vitpvwnqrli",
  "Review":{
    "SendEmailAlertWhenPublished":false,
    "SendEmailAlertWhenCommented":false,
    "SubmissionTime":"2011-11-16T13:51:01.196-00:00",
    "Rating":5,
    "IsRecommended":false,
    "ReviewText":"testtesttesttesttesttestesttest",
    "TypicalHoursToPost":null,
    "Id":null,
    "SubmissionId":null,
    "Title":"This product is really nifty"
  },
  "Locale":"en_US",
  "Errors":[]
}

Response elements

Name Description
Data

Section containing the fields and field groups.

HasErrors

Boolean value indicating if there are errors present.

Form

Section containing an array of field and group references.

FormErrors

Section containing an object whose properties represent user input errors. For example, failure to submit the minimum required characters for a particular field.

TypicalHoursToPost

Usual time it takes for the content to get posted.

SubmissionId

Unique submission event ID referring to successful submission events such as submission, update, and others

Review

Section containing the review data.

Locale

The locale that will be associated with this submission.

Errors

Error section is populated instead of other fields if there is an error with a query syntax or problem executing a query.

Error codes

Value Description
ERROR_ACCESS_DENIED

Insufficient privileges to perform the operation

ERROR_FORM_DUPLICATE

The nickname is already in use.

ERROR_FORM_DUPLICATE_NICKNAME

The nickname is already in use.

ERROR_FORM_EMOJI

Emoji are not supported.

ERROR_FORM_INVALID_EMAILADDRESS

Email address is not in the proper format.

ERROR_FORM_INVALID_IPADDRESS

The IP address is invalid.

ERROR_FORM_INVALID_OPTION

The selected option has been removed.

ERROR_FORM_PATTERN_MISMATCH

This field is not in the correct format.

ERROR_FORM_PROFANITY

The content contains inappropriate language.

ERROR_FORM_REJECTED

The submission was rejected.

ERROR_FORM_REQUIRED

A required field was not supplied.

ERROR_FORM_REQUIRED_EITHER

Both of the required hosted authentication parameters are missing.

ERROR_FORM_REQUIRED_NICKNAME

You must enter a nickname.

ERROR_FORM_REQUIRES_TRUE

A field requires a value of true. (e.g., "You must agree to the terms and conditions.")

ERROR_FORM_RESTRICTED

Content provider's age is too young. (e.g., "Content cannot be accepted from minors under age 13.")

ERROR_FORM_SUBMITTED_NICKNAME

This nickname has already been submitted.

ERROR_FORM_TOO_FEW

There must be a minimum number of items contributed for this field.

ERROR_FORM_TOO_HIGH

This field has too many items.

ERROR_FORM_TOO_LONG

The field has too many characters.

ERROR_FORM_TOO_LOW

This field has too few items.

ERROR_FORM_TOO_SHORT

The field doesn't have enough characters.

ERROR_FORM_UPLOAD_IO

The item could not be uploaded. Ensure that it is a valid file type.

ERROR_DUPLICATE_SUBMISSION

Duplicate submissions are not allowed for this client

ERROR_PARAM_INVALID_API_KEY

Invalid API Key value

ERROR_PARAM_INVALID_LOCALE

Invalid locale code

ERROR_PARAM_INVALID_PARAMETERS

Invalid parameter in content submission

ERROR_PARAM_MISSING_SUBJECT_ID

Submission is missing a product to submit against. A product id is REQUIRED for review submission.

ERROR_PARAM_MISSING_USER_ID

This client does not allow unauthenticated submissions. A valid UserId is required.

ERROR_REQUEST_LIMIT_REACHED

Rate limiting error, i.e. too many requests per time interval

ERROR_UNKNOWN

Unknown error (internal server error, for instance)

ERROR_UNSUPPORTED

For unsupported features, clients etc.