Skip to main content

All about suppression

Updated this week

Suppression is the term we use for any scenario where you want to prevent Retention.com from identifying and collecting contacts.

The main reasons you would do this are:

  1. To avoid paying Retention.com for contacts you already have. You likely have an existing database of customer emails, many of whom visit your site repeatedly. Since you already have those email addresses, there is no reason for us to identify or deliver those to you.

  2. To prevent collection of contacts on your website where they are voluntarily giving you an email address. If you collect newsletter signups, have an e-commerce site, or use any other type of conversion event involving an email address, you don't need us to identify or deliver that email address to you.

To solve for both of these scenarios, we have multiple ways to suppress contacts in Retention.com.

Example Scenario:

If user, jane@janedoe.com, is already on your list and visits your website, Retention.com will not collect that email address and include it in your acquired contacts or charge you for it.


1. Suppress existing contacts via integration

When you set up an integration in Retention.com, there is a separate section specifically for Suppression.

Not all integrations offer contact suppression! For these integrations, you would need to manually suppress those contacts (See section 2) or set up suppression via API (See Section 3).

Once this section has been set up, saved, and the integration itself is Enabled, Retention.com will automatically run a suppression of your full list from the system you've integrated with.

Please note - the integration must be enabled for suppression to run!

As long as the integration is Enabled, the suppression feature will run once per day to check for any newly added contacts in your email app. If any are found, we will update your suppression list in Retention.com.**

Go to the Suppression Lists tab to ensure the number of unique records being suppressed matches the number in your ESP.

**Retention.com automatically suppresses any contact we collect for you so that we do not deliver duplicates.


2. Suppression via a manual list upload

This option lets you manually upload a CSV file of email addresses in case you have additional lists/databases of email addresses that you do not want us to identify or collect.

We also recommend using this method if:

  • You are uploading your first suppression file (new account)

  • Your CSV list has 250,000 emails or more

Example Scenario
You might use this option if you go to a trade show and collect signups that do not end up in your email app.

Suppression lists uploaded are converted into encoded MD5s for security reasons. We do not use, share, or resell this data for any purpose other than to prevent our customers from collecting and paying for contacts they already have.

Instructions

Navigate to your Retention.com dashboard and click on Suppression Lists from the left-hand navigation menu.

Here are the file requirements for upload:

  • PLAIN TEXT EMAILS: Your file should only contain ONE column, labeled "email" of plain text emails OR

  • MD5 HASHES: Your file should contain ONE column, labeled "MD5" of properly formatted MD5 hashes. You must also click the checkbox for "File contains MD5 encoded emails" to load a file of MD5s

  • The file will need to be an Excel .CSV file.

  • The maximum file size is 500MB. If your file is larger than this, please split it up into several smaller files.

Once the file has uploaded, it will be sent to a queue to be processed. When complete, you'll see the stored file listed under the corresponding date.

Please ensure the number of unique records being suppressed in the dashboard matches the number in your ESP.


3. Suppression via Upload using our API

This option lets you upload a CSV file of email addresses/MD5s via our suppression API.


We recommend proceeding with this option if your integration does not offer automatic contact suppression.

The API has certain limitations and should not be used for the following purposes:

  • Uploading your initial suppression list (new accounts)

  • Upload large lists (250,000 emails or more)

If any of the conditions mentioned above apply to your situation, please proceed with the manual upload method outlined in Step 2.



We implement API throttling to ensure optimal performance and resource management. If the default limits do not meet your specific requirements, please contact your R! representative for further details on our throttle limits and potential solutions.

You can find more information about using our API here -> API Documentation


4. Suppression via Upload from SFTP Server

This option lets you setup an SFTP server connection to upload a CSV file of email addresses/MD5s to then be suppressed.

This option uses an integration within the app to facilitate the suppression (exclusion) of email addresses by importing CSV files from your SFTP server, this is not an ESP integration. It exclusively handles suppression functionalities and does not support the syncing of contact or events, for either Grow or Reclaim.

Requirements

  • SFTP Details: Host, Port (default 22), Username, and Password are required

  • Account Setting: Integration Suppression must be activated on your account

  • Required SFTP Folders: The following directories must exist on your SFTP server:

    • /suppressions

    • /suppressions/daily

File Specifications

File Locations & Naming

  • Historical (Optional, One-time Bulk):

    • /suppressions/suppressions_historical.csv

  • Daily Files (One per day):

    • /suppressions/daily/suppressions_YYYYMMDD.csv

    • Example: suppressions_20250810.csv

CSV Format

  • Encoding: UTF-8

  • Required Header: The CSV file must include an "email" header

  • Content: Each row must contain a single email address

  • Handling: Blank email entries will be disregarded, and duplicate entries will be de-duplicated

Example CSV

email
alice@example.com
bob@example.org
carol@shop.com

Operational Procedures

  1. Confirm Credentials: Verify SFTP access and the existence of the required folders within the application interface

  2. Historical Import: Initiate this process without a specified start date to import the historical file

  3. Daily Backfill: Set a start date (YYYY-MM-DD) to process daily files up to the preceding day

  4. Ongoing: Upload each day's file to /suppressions/daily/; the system will process it according to its schedule

Automatic Error Handling

  • File Not Found: The system will attempt up to 3 retries (at 1-hour intervals) and subsequently send a support email notification

  • SFTP Connection Error: Up to 5 retries will be attempted (every 10 minutes), followed by a support email notification

  • Missing/Invalid Credentials: Suppression will be disabled, accompanied by a clear error message. Correction of credentials and a subsequent retry are required

Quick Checklist

  • Host, Port (22 if uncertain), Username, and Password have been configured

  • The /suppressions and /suppressions/daily folders exist

  • Files are precisely named as stipulated above

  • The CSV includes an "email" header and contains valid email addresses

  • Integration Suppression is enabled

  • Credentials have been confirmed within the application

Sample SFTP Directory Structure

/suppressions   ├─ suppressions_historical.csv        # optional   └─ daily/        ├─ suppressions_20250808.csv        ├─ suppressions_20250809.csv        └─ suppressions_20250810.csv

How do I manually add suppression to my site?

1. Suppression script

This option is used to prevent collection of contacts on your website where they are voluntarily giving you an email address. It does this in real-time.

The Suppression Script can be added to your website on any pages where you do NOT want Retention.com to collect email addresses. Generally speaking, you would put this script on landing pages where the person has already converted, and therefore you have already collected their email address.

Examples of pages you would want to add the suppression script to are:

  • Post-checkout pages*

  • Post sign-up "Thank you" pages

  • Confirmation pages

  • Pop ups that involve entering an email

The Suppression Script can be found in your Retention.com dashboard under Code Script > View script. Next to Suppression script, click Copy code to save it to your clipboard.

Place the code on the pages you want the suppression script to run.

Please note that if you use this script, make sure you do not place it on pages you want the Retention.com Collection Snippet to work. If both scripts are on the same page, the Suppression snippet will override the Collection snippet.

*If you are using our Revenue Tracking script, you do not need to include the Suppression script—our revenue tracking script will automatically invoke it.


2. Set suppression rules

You can also set rules to automatically trigger a suppression event on your site, which will prevent the collection of contacts from that page(s). The base Retention.com script still needs to be loaded on any page you want to suppress.

You will need to manually add the suppression script for sign-up or login forms. See section 3 below.

Instructions

  1. From your Retention.com Dashboard, click Code Script > Settings.

  2. Scroll down to Suppression rules, and set them up using the rules shown below.

URL CONTAINS EMAIL UTM

We automatically prevent the collection of contacts that come to your site from email campaigns. We do this because you will have existing contacts who own more than one email address, and will not want to add them to a new email marketing flow if they are already in your system.

These contacts are identified by checking the referring URL that brought them to your site; if that URL contains UTM parameters with the word "email" in them, we will ignore/suppress those contacts. To disable that function, toggle to No.

URL TRIGGERS - SKIP COLLECTION ON THIS PAGE (RECOMMENDED)

To skip collection on specific URLs where the base script is already present, add the full or portion of the URL in the first text box. Example: /blog. Any URL that contains that text will prevent collection from firing on this page. If the visitor later navigates to a collectable page, they'll still be eligible for collection.

URL TRIGGERS - SUPPRESS ALL FUTURE COLLECTION

To trigger the suppression script on specific URLs where the base script is already present, add the full or portion of the URL in the first text box. Example: /recall. Any URL that contains that text will trigger the suppression event, and any visitor who lands on this page will be permanently suppressed, regardless of where they go next.

URLS with SPECIFIC PARAMETERS

You can also set the suppression script to trigger on URLs with specific parameters. For example, you can use this to exclude traffic sources like Facebook, or other UTM identifiers. Any URL parameter with this text will trigger the suppression event.

3. When you've set your Suppression Rules, click Save in the bottom right for your changes to apply.


3. How to suppress via button clicks

If you have buttons and/or pop-ups on your site where visitors can submit their email addresses, you will need to add the suppression script to fire when that action occurs.

Some JavaScript/HTML knowledge is required in order to target the correct elements and fire the script when appropriate.

The exact structure and script will vary depending on the platform you're using for your button/pop-up.

Please let your IM or CSM know of any instances where you plan on implementing the solutions below.

Here's an example of what an "on-click" event looks like based on an HTML ID:

<script> document.getElementById("SpecialButtonHere").addEventListener('submit',function (){  
geq.suppress(); // this is the call to our suppression script
}); </script>

You can also set up an "on-click" event to fire based on the HTML ClassName:

<script>
var classname = document.getElementsByClassName("FormName");
for (var i = 0; i < classname.length; i++) { classname[i].addEventListener("submit", function () { geq.suppress(); // this is the call to our suppression script
});
}
</script>

This is an example using Klaviyo forms (further Klaviyo pop-up suppression docs can be found here) :

<script>
  window.addEventListener("klaviyoForms", function (e) {
    if (e.detail.type == "submit") {
      geq.suppress();
    }
  });
</script>

After integrating the suppression script into your on-click event, use our verification tool (Retention.com Dashboard > Code Script > Test Script) to confirm its presence. It will indicate that the script is correctly installed but not yet activated, ensuring proper setup before activation.

Optional: If you have access to the user's email entered on the site, you can pass it into our Suppression function using the following format:

geq.suppress(emailEntered); // "emailEntered" is a string variable


How can I confirm my suppression script is working?

In the graph in the Trends tab, you can look for real-time suppression script events to confirm it's firing. The red line represents your number of suppressed contacts. If you hover your cursor over a specific day, it will show the exact number of suppressed contacts.

Once you've installed your suppression script, it may take anywhere from minutes to days to see these events show up, depending on your overall website traffic.

Have questions? Email us at support(at)retention(dot)com, or message us on chat!

Did this answer your question?