Integrating Topsort and Algolia
Introduction
Algolia is a powerful search engine that provides fast, relevant results for navigating catalogs. By integrating Topsort, you can monetize your catalog search by including auction-powered listings that promote specific products.
This guide outlines two integration options for Topsort and Algolia:
- Option 1: Single-Index Integration: Use your existing Algolia index (primary index) to serve both organic and auctioned products.
- Option 2: Dual-Index Integration: Use a separate index (secondary index) for promoted products alongside your organic index.
Each option has different implementation steps, pros, and cons to help you choose the most suitable method for your use case.
Prerequisites
- Your catalog is stored in an Algolia index
- You have a Topsort account
- You are using the Algolia SDK to query your Algolia index
- You have an Algolia API key with the required permissions (
search
,browse
,listIndexes
,addObject
,deleteObject
, depending on the integration path chosen)
Option 1: Single-Index Integration
In this option, Topsort will work directly with your primary Algolia index, which contains both organic and auctionable products. This is the simpler integration method, ideal if you want to keep everything within one index.
Integration Steps:
-
Reach out to Topsort with your Algolia index name.
-
Create an API key with
browse
andlistIndexes
permissions so Topsort can access your Algolia index to import your catalog.- The
browse
permission enables efficient, paginated downloading of your entire catalog - The
listIndexes
permission allows Topsort to check the index’s last modification date to avoid unnecessary updates
- The
-
Topsort Proxy Configuration: You will need to adjust the Algolia SDK to point to the Topsort proxy. The proxy will augment search results with auction data automatically. Example code:
-
Auction Winners: Topsort will automatically include a
resolvedBidId
attribute in the search results to identify auction winners. You can use this to display sponsored products alongside organic results. -
Events: You will need to integrate Topsort’s event tracking (impressions, clicks, purchases) using
analytics.js
or any of the Topsort SDK’s.
Option 2: Dual-Index Integration
This option introduces a secondary index in Algolia for promoted products. This method allows for more fine-grained control over the integration by separating the organic and promoted products into different indices. This approach is ideal if you want more control over how promoted products are handled and auctioned.
Integration Steps:
-
Primary Index Configuration: The primary index holds your organic products and should be kept in sync with your catalog in Topsort.
- API Key: You need an Algolia API key with
search
,browse
andlistIndexes
permissions for the primary index.- The
browse
permission enables efficient, paginated downloading of your entire catalog - The
listIndexes
permission allows Topsort to check the index’s last modification date to avoid unnecessary updates
- The
- Ensure Consistency: The
objectID
in Algolia should match the productid
field in Topsort.
- API Key: You need an Algolia API key with
-
Create a Promoted Products Secondary Index:
- Topsort will create a secondary index for promoted products.
- Whenever a campaign is created or updated, the secondary index is populated with promoted products, keeping the same structure as the primary index.
- API Key: You need an Algolia API key with
search
,browse
,addObject
, anddeleteObject
permissions for the secondary index.
-
Multi-query Setup: Your system will need to query both the primary and secondary indices at the same time. Example:
This request retrieves results from both indices, allowing Topsort to merge auction winners into the organic results.
-
Auction Winners: Topsort will run an auction on the promoted products retrieved from the secondary index. Winning products will be merged with the organic results from the primary index, appearing at the top of the search results.
-
Events: As in Option 1, you need to track impressions, clicks, and purchases using
analytics.js
or any of the Topsort SDK’s.