This integration is powered by Singer's Yotpo tap and certified by Stitch. Check out and contribute to the repo on GitHub.
For support, contact Stitch support.
Yotpo integration summary
Stitch’s Yotpo integration replicates data using the Yotpo Core API. Refer to the Schema section for a list of objects available for replication.
Yotpo feature snapshot
A high-level look at Stitch's Yotpo (v2) integration, including release status, useful links, and the features supported in Stitch.
STITCH | |||
Release status |
Released on September 20, 2019 |
Supported by | |
Stitch plan |
Standard |
API availability |
Available |
Singer GitHub repository | |||
REPLICATION SETTINGS | |||
Anchor Scheduling |
Supported |
Advanced Scheduling |
Supported |
Table-level reset |
Unsupported |
Configurable Replication Methods |
Unsupported |
DATA SELECTION | |||
Table selection |
Supported |
Column selection |
Unsupported |
Select all |
Supported |
||
TRANSPARENCY | |||
Extraction Logs |
Supported |
Loading Reports |
Supported |
Connecting Yotpo
Yotpo setup requirements
To set up Yotpo in Stitch, you need:
-
To be the Account Administrator in Yotpo. This is required to access your Yotpo API credentials.
Step 1: Retrieve your Yotpo API credentials
- Sign into your Yotpo account.
- Click the user menu (person icon) in the top right corner.
- Click Account Settings.
- On the Account Settings page, click the Store tab.
-
Locate the API Credentials section:
- The App Key field contains your API Key, and the Secret Key is your API Secret.
Leave this page open for now - you’ll need it to complete the next step.
Step 2: Add Yotpo as a Stitch data source
- Sign into your Stitch account.
-
On the Stitch Dashboard page, click the Add Integration button.
-
Click the Yotpo icon.
-
Enter a name for the integration. This is the name that will display on the Stitch Dashboard for the integration; it’ll also be used to create the schema in your destination.
For example, the name “Stitch Yotpo” would create a schema called
stitch_yotpo
in the destination. Note: Schema names cannot be changed after you save the integration. - In the Yotpo API Key field, paste the value from the App Key field in your Yotpo account.
- In the Yotpo API Secret field, paste the value from the Secret Key field in your Yotpo account.
Step 3: Define the historical replication start date
The Sync Historical Data setting defines the starting date for your Yotpo integration. This means that:
- For tables using Key-based Incremental Replication, data equal to or newer than this date will be replicated to your destination.
- For tables using Full Table Replication, all data - including records that are older, equal to, or newer than this date - will be replicated to your destination.
Change this setting if you want to replicate data beyond Yotpo’s default setting of 1 year. For a detailed look at historical replication jobs, check out the Syncing Historical SaaS Data guide.
Step 4: Create a replication schedule
In the Replication Frequency section, you’ll create the integration’s replication schedule. An integration’s replication schedule determines how often Stitch runs a replication job, and the time that job begins.
Yotpo integrations support the following replication scheduling methods:
-
Advanced Scheduling using Cron (Advanced or Premium plans only)
To keep your row usage low, consider setting the integration to replicate less frequently. See the Understanding and Reducing Your Row Usage guide for tips on reducing your usage.
Step 5: Set objects to replicate
The last step is to select the tables you want to replicate. Learn about the available tables for this integration.
Note: If a replication job is currently in progress, new selections won’t be used until the next job starts.
For Yotpo integrations, you can select:
-
**Individual tables **
-
All tables and columns
Click the tabs to view instructions for each selection method.
- In the integration’s Tables to Replicate tab, locate a table you want to replicate.
-
To track a table, click the checkbox next to the table’s name. A blue checkmark means the table is set to replicate.
- Repeat this process for all the tables you want to replicate.
- When finished, click the Finalize Your Selections button at the bottom of the screen to save your selections.
- Click into the integration from the Stitch Dashboard page.
-
Click the Tables to Replicate tab.
- In the list of tables, click the box next to the Table Names column.
-
In the menu that displays, click Track all Tables and Fields:
- Click the Finalize Your Selections button at the bottom of the page to save your data selections.
Initial and historical replication jobs
After you finish setting up Yotpo, its Sync Status may show as Pending on either the Stitch Dashboard or in the Integration Details page.
For a new integration, a Pending status indicates that Stitch is in the process of scheduling the initial replication job for the integration. This may take some time to complete.
Initial replication jobs with Anchor Scheduling
If using Anchor Scheduling, an initial replication job may not kick off immediately. This depends on the selected Replication Frequency and Anchor Time. Refer to the Anchor Scheduling documentation for more information.
Free historical data loads
The first seven days of replication, beginning when data is first replicated, are free. Rows replicated from the new integration during this time won’t count towards your quota. Stitch offers this as a way of testing new integrations, measuring usage, and ensuring historical data volumes don’t quickly consume your quota.
Yotpo replication
Every time Stitch runs a replication job for Yotpo, the last 30 days’ worth of data will be replicated for these tables:
-
emails
-
reviews
Stitch replicates data in this way to account for updates made to existing records within the default attribution window of 30 days, thus ensuring you won’t make decisions based on stale (or false) data. As a result, you may see a higher number of replicated rows than what’s being generated in Yotpo.
Setting the Replication Frequency to a higher frequency - like 30 minutes - can result in re-replicating recent data and contribute to greater row usage. Replicating fewer tables or selecting a lower frequency can help keep your row count low.
Refer to the documentation for each of these tables in the next section for more info.
Attribution window examples
In the tabs below are examples of attribution windows behave during historical (initial) and ongoing replication jobs.
For historical and full re-replications of Yotpo data, Stitch will query for and extract data newer than or equal to the date defined in the Start Date field in the Integration Settings page.
The Start Date, in conjunction with the Attribution Window, defines the minimum date Stitch should query for when extracting historical data. This is calculated as:
Start Date - Attribution Window = Minimum Extraction Date
Example
During the initial set up, the Start Date field is set to 06/03/2017
, or June 3, 2017
.
To account for the Attribution Window, Stitch would calculate the Minimum Extraction Date value as: 2017-07-03 00:00:00 - 30 days = 2017-06-03 00:00:00
If you were to write a SQL query using this date for the reviews
table, it might look like this:
SELECT *
FROM yotpo.reviews
WHERE created_at >= '2017-06-03 00:00:00' /* Min. Extraction Date */
ORDER BY created_at
For ongoing replication jobs, Stitch will query for and extract data using the last saved maximum value in the table’s Replication Key column and the Attribution Window for the table.
Note: This applies to every replication job that takes place after the historical replication job.
Example
The last maximum saved Replication Key value for the reviews
table is 2017-10-01 00:00:00
.
To account for the Attribution Window of 30 days, we’d subtract this from the last maximum saved Replication Key value:
2017-10-01 00:00:00 - 30 days = 2017-09-01 00:00:00
In this case, Stitch would query for and extract data that is newer than or equal to 2017-09-01 00:00:00
and older than or equal to 2017-10-01 00:00:00
.
If this were a SQL query, it might look like this:
SELECT *
FROM reviews
WHERE created_at >= '2017-09-01 00:00:00'
/* max Replication Key value - Attribution Window */
AND created_at <= '2017-10-01 00:00:00'
/* max Replication Key value from previous job */
ORDER BY created_at
Yotpo table reference
Schemas and versioning
Schemas and naming conventions can change from version to version, so we recommend verifying your integration’s version before continuing.
The schema and info displayed below is for version 2 of this integration.
This is the latest version of the Yotpo integration.
Table and column names in your destination
Depending on your destination, table and column names may not appear as they are outlined below.
For example: Object names are lowercased in Redshift (CusTomERs
> customers
), while case is maintained in PostgreSQL destinations (CusTomERs
> CusTomERs
). Refer to the Loading Guide for your destination for more info.
collections
Replication Method : |
Key-based Incremental |
Replication Key |
updated_at |
Primary Key |
yotpo_id |
API endpoint : |
The collections
table contains data about your store’s product groupings - collections - in your Yotpo account.
yotpo_id
The ID generated by Yotpo for the collection. |
updated_at
The time the collection was last updated. |
created_at
|
external_id
|
name
|
emails
Replication Method : |
Key-based Incremental |
Replication Key |
email_sent_timestamp |
Primary Key |
email_address : email_sent_timestamp |
API endpoint : |
The emails
table contains data about every email sent from Yotpo.
Attribution window
When Stitch replicates data for this table, it will use an attribution window of 30 days to fetch updated email statistics such as opens, clicks, etc. This means that every time a replication job runs, the last 30 days’ worth of data will be replicated for this table.
Refer to the Replication section for more info and examples of how the attribution window is used to query for data.
email_address
The email address of the recipient. Reference: |
email_sent_timestamp
The time the email was sent to the recipient. |
order_id
If applicable, the ID of the order the email is associated with. |
order_timestamp
|
product_id
If applicable, the ID of the product the email is associated with. Reference: |
sku
|
email_type
|
reminder_num
|
trr_bundle_id
|
trr_bundle_subject
|
review_type
|
coupon_code
|
opened_timestamp
|
clicked_through_timestamp
|
content_creation_timestamp
|
review_form
|
platform
|
invalid_address_timestamp
|
failed_timestamp
|
unsubscribed_timestamp
|
marked_spam_timestamp
|
arrived_early_timestamp
|
orders
Replication Method : |
Key-based Incremental |
Replication Key |
order_date |
Primary Key |
yotpo_id |
API endpoint : |
The orders
table contains data about orders in your Yotpo account.
yotpo_id
The ID generated by Yotpo for the order. This value is read-only. Reference: |
|||||||||||
order_date
The date the order was created in the store. It is not possible to send an automatic email request for orders older than six months. |
|||||||||||
billing_address
|
|||||||||||
cancellation
|
|||||||||||
checkout_token
|
|||||||||||
created_at
|
|||||||||||
currency
|
|||||||||||
custom_properties
|
|||||||||||
customer
|
|||||||||||
external_id
|
|||||||||||
fulfillments
|
|||||||||||
landing_site_url
|
|||||||||||
line_items
|
|||||||||||
order_name
|
|||||||||||
payment_method
|
|||||||||||
payment_status
|
|||||||||||
shipping_address
|
|||||||||||
source
|
|||||||||||
subtotal_price
|
|||||||||||
total_price
|
|||||||||||
updated_at
|
order_fulfillments
Replication Method : |
Key-based Incremental |
Replication Key |
updated_at |
Primary Key |
id |
API endpoint : |
The order_fulfillments
table contains data about fulfilled store orders in your Yotpo account.
id
The order fulfillment ID. |
||||
updated_at
The time the fulfillment was last updated. |
||||
created_at
|
||||
external_id
|
||||
fulfilled_items
|
||||
fulfillment_date
|
||||
order_id
|
||||
shipment_info
|
||||
status
|
products
Replication Method : |
Full Table |
Primary Key |
yotpo_id |
API endpoint : |
The products
table contains data about products in your Yotpo account.
yotpo_id
The Yotpo ID for the product. Reference: |
|||
brand
|
|||
compare_at_price
|
|||
created_at
|
|||
currency
|
|||
custom_properties
|
|||
description
|
|||
external_created_at
|
|||
external_id
|
|||
external_updated_at
|
|||
group_name
|
|||
gtins
|
|||
handle
|
|||
image_url
|
|||
inventory_quantity
|
|||
is_discontinued
|
|||
is_valid_url_format
|
|||
mpn
|
|||
name
|
|||
price
|
|||
sku
|
|||
status
|
|||
updated_at
|
|||
url
|
product_reviews
Replication Method : |
Key-based Incremental |
Replication Key |
created_at |
Primary Key |
id |
API endpoint : |
The product_reviews
table contains data about reviews for a certain product.
Note: This table is similar to the reviews
table, but also contains custom fields. If you don’t have or need custom product fields, you may only want to replicate the reviews
table to prevent redundant data.
id
The review ID. Reference: |
|||||
created_at
The time the review was created. |
|||||
comment
|
|||||
content
|
|||||
custom_fields
|
|||||
deleted
|
|||||
domain_key
|
|||||
images_data
|
|||||
name
|
|||||
product_id
|
|||||
product_yotpo_id
|
|||||
score
|
|||||
sentiment
|
|||||
source_review_id
|
|||||
title
|
|||||
user
|
|||||
verified_buyer
|
|||||
votes_down
|
|||||
votes_up
|
product_variants
Replication Method : |
Key-based Incremental |
Replication Key |
updated_at |
Primary Key |
yotpo_id |
API endpoint : |
The product_variants
table contains data about product variations in your Yotpo account.
yotpo_id
The ID generated by Yotpo for the product variant. |
updated_at
The time the product variant was last updated. |
compare_at_price
|
created_at
|
currency
|
description
|
external_id
|
gtins
|
image_url
|
inventory_quantity
|
is_discontinued
|
is_valid_url_format
|
name
|
options
|
price
|
sku
|
url
|
yotpo_product_id
The product ID. Reference: |
reviews
Replication Method : |
Key-based Incremental |
Replication Key |
updated_at |
Primary Key |
id |
API endpoint : |
The reviews
table contains data about reviews.
Note: This table is similar to the product_reviews
table, but doesn’t contain custom fields. If you have or need custom fields, you may want to only replicate the product_reviews
table to prevent redundant data.
Attribution window
When Stitch replicates data for this table, it will use an attribution window of 30 days to fetch updated (or deleted) reviews. This means that every time a replication job runs, the last 30 days’ worth of data will be replicated for this table.
Refer to the Replication section for more info and examples of how the attribution window is used to query for data.
id
The ID of the review. Reference: |
updated_at
The time the review was last updated. |
archived
|
content
|
created_at
|
deleted
|
email
|
escalated
|
name
|
reviewer_type
|
score
|
sentiment
|
sku
|
title
|
user_reference
|
votes_down
|
votes_up
|
unsubscribers
Replication Method : |
Full Table |
Primary Key |
id |
API endpoint : |
The unsubscribers
table contains data about customers who unsubscribed from one of Yotpo’s emails.
id
The unsubscriber ID. |
user_email
The email address of the unsubscriber. Reference: |
email_type_id
|
unsubscirbed_by_name
Note: The misspelling in this field name originates in Yotpo’s API. Stitch doesn’t have the ability to rename it. |
Related | Troubleshooting |
Questions? Feedback?
Did this article help? If you have questions or feedback, feel free to submit a pull request with your suggestions, open an issue on GitHub, or reach out to us.