Skip Navigation
Show nav
Heroku Dev Center Dev Center
  • Get Started
  • Documentation
  • Changelog
  • Search
Heroku Dev Center Dev Center
  • Get Started
    • Node.js
    • Ruby on Rails
    • Ruby
    • Python
    • Java
    • PHP
    • Go
    • Scala
    • Clojure
    • .NET
  • Documentation
  • Changelog
  • More
    Additional Resources
    • Home
    • Elements
    • Products
    • Pricing
    • Careers
    • Help
    • Status
    • Events
    • Podcasts
    • Compliance Center
    Heroku Blog

    Heroku Blog

    Find out what's new with Heroku on our blog.

    Visit Blog
  • Log in or Sign up
View categories

Categories

  • Heroku Architecture
    • Compute (Dynos)
      • Dyno Management
      • Dyno Concepts
      • Dyno Behavior
      • Dyno Reference
      • Dyno Troubleshooting
    • Stacks (operating system images)
    • Networking & DNS
    • Platform Policies
    • Buildpacks
    • Platform Principles
  • Developer Tools
    • Command Line
    • Heroku VS Code Extension
  • Deployment
    • Deploying with Git
    • Deploying with Docker
    • Deployment Integrations
  • Continuous Delivery & Integration (Heroku Flow)
    • Continuous Integration
  • Language Support
    • Node.js
      • Working with Node.js
      • Node.js Behavior in Heroku
      • Troubleshooting Node.js Apps
    • Ruby
      • Rails Support
        • Working with Rails
      • Working with Bundler
      • Working with Ruby
      • Ruby Behavior in Heroku
      • Troubleshooting Ruby Apps
    • Python
      • Working with Python
      • Background Jobs in Python
      • Python Behavior in Heroku
      • Working with Django
    • Java
      • Java Behavior in Heroku
      • Working with Java
      • Working with Maven
      • Working with Spring Boot
      • Troubleshooting Java Apps
    • PHP
      • PHP Behavior in Heroku
      • Working with PHP
    • Go
      • Go Dependency Management
    • Scala
    • Clojure
    • .NET
      • Working with .NET
  • Databases & Data Management
    • Heroku Postgres
      • Postgres Basics
      • Postgres Getting Started
      • Postgres Performance
      • Postgres Data Transfer & Preservation
      • Postgres Availability
      • Postgres Special Topics
      • Migrating to Heroku Postgres
    • Heroku Key-Value Store
    • Apache Kafka on Heroku
    • Other Data Stores
  • AI
    • Working with AI
    • Heroku Inference
      • Inference Essentials
      • Inference API
      • Heroku Inference Quick Start Guides
      • AI Models
    • Tool Use
    • Vector Database
    • AI Integrations
  • Monitoring & Metrics
    • Logging
  • App Performance
  • Add-ons
    • All Add-ons
  • Collaboration
  • Security
    • App Security
    • Identities & Authentication
      • Single Sign-on (SSO)
    • Private Spaces
      • Infrastructure Networking
    • Compliance
  • Heroku Enterprise
    • Enterprise Accounts
    • Enterprise Teams
  • Patterns & Best Practices
  • Extending Heroku
    • Platform API
    • App Webhooks
    • Heroku Labs
    • Building Add-ons
      • Add-on Development Tasks
      • Add-on APIs
      • Add-on Guidelines & Requirements
    • Building CLI Plugins
    • Developing Buildpacks
    • Dev Center
  • Accounts & Billing
  • Troubleshooting & Support
  • Integrating with Salesforce
    • Heroku AppLink
      • Heroku AppLink Reference
      • Getting Started with Heroku AppLink
      • Working with Heroku AppLink
    • Heroku Connect (Salesforce sync)
      • Heroku Connect Administration
      • Heroku Connect Reference
      • Heroku Connect Troubleshooting
    • Other Salesforce Integrations
  • Add-ons
  • All Add-ons
  • Trustifi

Trustifi

Table of Contents [expand]

  • Installing the Trustifi add-on
  • Local setup
  • Using with cURL
  • Using with jQuery
  • Using with Ruby
  • Using with Python
  • Using with Node
  • Using with PHP
  • Using with Go
  • Use templates with dynamic data
  • Dashboard
  • Troubleshooting
  • Migrating between plans
  • Removing the add-on
  • GDPR
  • Support

Last updated July 17, 2023

Trustifi

This add-on is operated by Trustifi

Trustifi gives you complete control of your email communications.

Trustifi is your comprehensive email tool-box:

  • Easily send secured, tracked and encrypted emails using your address (or one of our dedicated addresses) - in order to maintain compliance (HIPAA, GDPR, PCI, etc.) and keep the data of your users/recipients secure and private.
  • Secured and encrypted storage for your files - easy to access, upload and download.
  • Dynamic templates - send highly customized emails with dynamic fields to fit your purpose and recipients.
  • Most importantly - never lose your data. All info is kept secure and encrypted in our easy-to-use web app. All sent emails, attachments, contacts, and templates are accessible at any point.

Installing the Trustifi add-on

Installation through Heroku CLI

heroku addons:create trustifi --app your-app-name --wait

Installation through the Heroku Dashboard

  • From your application’s “Resources” tab, scroll down to the “Add-ons” section and search for “Trustifi”:

Trustifi add-on search

  • A pop-up will open, choose the relevant plan from the list and click “Submit Order Form”:

Add Trustifi add-on

After installation, Trustifi will automatically provide you with an email address that you can use immediately with the add-on. If you want to use your own email address instead, it will require a quick extra step of verifying your address.

Local setup

Environment setup

After you provision the add-on, it’s necessary to locally replicate its config vars so your development environment can operate against the service.

Use the Heroku Local command-line tool to configure, run and manage process types specified in your app’s Procfile. Heroku Local reads configuration variables from a .env file. To view all of your app’s config vars, type heroku config. Use the following command for each value that you want to add to your .env file:

$ heroku config:get TRUSTIFI_KEY --app your-app-name -s  >> .env
$ heroku config:get TRUSTIFI_SECRET --app your-app-name -s  >> .env
$ heroku config:get TRUSTIFI_URL --app your-app-name -s  >> .env

Credentials and other sensitive configuration values should not be committed to source-control. In Git exclude the .env file with: echo .env >> .gitignore.

For more information, see the Heroku Local article.

Using with cURL

The following code example will send an email using the Trustifi API to a single recipient.

$ heroku run bash

~ $ curl -k -L -X POST "$TRUSTIFI_URL/api/i/v1/email" \
-H "x-trustifi-key: $TRUSTIFI_KEY" \
-H "x-trustifi-secret: $TRUSTIFI_SECRET" \
-H "content-type: application/json" \
-d \
 "{
\"recipients\":[{
    \"email\":\"test@trustificorp.org\"
}],
\"title\":\"Title\",
\"html\":\"Body\"
}"

For more code samples, response samples and additional information, see https://api.trustifi.com/

Using with jQuery

The following code example will send an email using the Trustifi API to a single recipient.

let settings = {
  "url": TRUSTIFI_URL+"/api/i/v1/email",
  "method": "POST",
  "headers": {
    "x-trustifi-key": TRUSTIFI_KEY,
    "x-trustifi-secret": TRUSTIFI_SECRET,
    "content-type": "application/json"
  },
  "data": JSON.stringify({"recipients":[{"email":"test@trustificorp.org"}],"title":"Title","html":"Body"})
};

$.ajax(settings).done(function (response) {
  console.log(response);
});

For more code samples, response samples and additional information, see https://api.trustifi.com/

Using with Ruby

The following code example will send an email using the Trustifi API to a single recipient.

require "uri"
require "net/http"
require "json"

url = URI.parse(ENV['TRUSTIFI_URL'] + "/api/i/v1/email")
https = Net::HTTP.new(url.host, url.port)
https.use_ssl = true

request = Net::HTTP::Post.new(url)
request["x-trustifi-key"] = ENV['TRUSTIFI_KEY']
request["x-trustifi-secret"] = ENV['TRUSTIFI_SECRET']
request["content-type"] = "application/json"
request.body = "{\"recipients\": [{\"email\": \"test@trustificorp.org\"}],\"title\":\"Title\",\"html\":\"Body\"}"

response = https.request(request)
puts response.read_body

For more code samples, response samples and additional information, see https://api.trustifi.com/

Using with Python

The following code example will send an email using the Trustifi API to a single recipient.

import  requests, os

url = os.environ['TRUSTIFI_URL']+'/api/i/v1/email'

payload = "{\"recipients\":[{\"email\":\"test@trustificorp.org\"}],\"title\":\"Title\",\"html\":\"Body\"}"
headers = {
  'x-trustifi-key': os.environ['TRUSTIFI_KEY'],
  'x-trustifi-secret': os.environ['TRUSTIFI_SECRET'],
  'Content-Type': 'application/json'
}

response = requests.request('POST', url, headers = headers, data = payload)
print(response.json())

For more code samples, response samples and additional information, see https://api.trustifi.com/

Using with Node

The following code example will send an email using the Trustifi API to a single recipient.

const request = require('request');

request.post(process.env.TRUSTIFI_URL + '/api/i/v1/email', {
   headers: {
    'x-trustifi-key': process.env.TRUSTIFI_KEY,
    'x-trustifi-secret': process.env.TRUSTIFI_SECRET
  },
  json:{"recipients":[{"email":"test@trustificorp.org"}],"title":"Title","html":"Body"}
}, (err, res, body) => {
   console.log(body);
});

For more code samples, response samples and additional information, see https://api.trustifi.com/

Using with PHP

The following code example will send an email using the Trustifi API to a single recipient.

<?php
$curl = curl_init();
curl_setopt_array($curl, array(
    CURLOPT_URL => $_ENV['TRUSTIFI_URL'] . "/api/i/v1/email",
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_ENCODING => "",
    CURLOPT_MAXREDIRS => 10,
    CURLOPT_TIMEOUT => 0,
    CURLOPT_FOLLOWLOCATION => true,
    CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
    CURLOPT_CUSTOMREQUEST => "POST",
    CURLOPT_POSTFIELDS =>"{\"recipients\":[{\"email\":\"test@trustificorp.org\"}],\"title\":\"Title\",\"html\":\"Body\"}",
    CURLOPT_HTTPHEADER => array(
        "x-trustifi-key: " . $_ENV['TRUSTIFI_KEY'],
        "x-trustifi-secret: " . $_ENV['TRUSTIFI_SECRET'],
        "content-type: application/json"
    )
));

$response = curl_exec($curl);
$err = curl_error($curl);
curl_close($curl);
if ($err) {
    echo "cURL Error #:" . $err;
} else {
    echo $response;
}
?>

For more code samples, response samples and additional information, see https://api.trustifi.com/

Using with Go

The following code example will send an email using the Trustifi API to a single recipient.

package main
import (
    "fmt"
    "strings"
    "net/http"
    "io/ioutil"
    "os"
)

func main() {
    url := os.Getenv("TRUSTIFI_URL") + "/api/i/v1/email"
    method := "POST"
    payload := strings.NewReader("{\"recipients\":[{\"email\":\"test@trustificorp.org\"}],\"title\":\"Title\",\"html\":\"Body\"}")
    client := &http.Client {}
    req, err := http.NewRequest(method, url, payload)
    req.Header.Add("x-trustifi-key", os.Getenv("TRUSTIFI_KEY"))
    req.Header.Add("x-trustifi-secret", os.Getenv("TRUSTIFI_SECRET"))
    req.Header.Add("Content-Type", "application/json")
    res, err := client.Do(req)
    if err != nil {
        panic(err)
    }
    defer res.Body.Close()
    body, _ := ioutil.ReadAll(res.Body)
    fmt.Println(string(body))
}

For more code samples, response samples and additional information, see https://api.trustifi.com/

Use templates with dynamic data

Trustifi allows you to create customized email templates that can be used for customer engagement. You can make use of dynamic fields (see explanation below) to personalize the emails to your company and recipients.

To view a more detailed guide about creating and using email templates click here - Customized templates guide

Creating a template

Below is an example of creating a Trustifi template - fields surrounded by curly braces are dynamic fields.

For example, {{REC.NAME}} will refer to the specific recipient of the email and {{SENDER_EMAIL}} will refer to the sender’s email address.

Dynamic fields can be used in the email’s body and subject.

const request = require('request');

var postData =  {
      "name": "my_template",
      "title": "template title",
      "html": "<p>Hello&nbsp;{{REC.NAME}}, this is an email from&nbsp;{{SENDER_EMAIL}}!</p><p>{{first_field}}</p><p>{{second_field}}<br></p>"
 };

request.post(process.env.TRUSTIFI_URL+'/api/i/v1/template', {
   headers: {
      'x-trustifi-key': process.env.TRUSTIFI_KEY,
      'x-trustifi-secret': process.env.TRUSTIFI_SECRET
   },
   json: postData
}, (err, res, body) => {
   console.log(body);
})

Here’s a customized template in the Trustifi dashboard. Notice the dynamic fields (surrounded by curly braces); these fields will display the relevant information when the email arrives in the recipient’s inbox:

Trustifi template sender side

See our API documentation for a more detailed example.

Sending a template with dynamic fields

To send an email with a predefined template, you can refer to it by name in your “Compose email” (POST) request. Custom dynamic fields can be declared here. In this example, {{first_field}} translates to “hello” and {{second_field}} translates to “world”.

const request = require('request');

var postData =  {
  "template": {
    "name": "my_template",
    "fields": {
      "first_field": "hello",
      "second_field": "world"
    },
  },
  "recipients": [{
    "email": "recipient@trustificorp.org"
  }]
};

request.post(process.env.TRUSTIFI_URL+'/api/i/v1/email', {
   headers: {
      'x-trustifi-key': process.env.TRUSTIFI_KEY,
      'x-trustifi-secret': process.env.TRUSTIFI_SECRET
   },
   json: postData
}, (err, res, body) => {
   console.log(body);
})

Here is how the same template from before would look once it arrives in the recipient’s inbox. Notice that the dynamic fields like {{REC.NAME}} display the relevant information:

Trustifi template recipient side

See our API documentation for more information.

Dashboard

$ heroku addons:open trustifi --app your-app-name

Trustifi Dashboard

You can also access the dashboard by visiting the Heroku Dashboard and selecting Trustifi from the Add-ons menu:

Trustifi SSO

By clicking on the Trustifi add-on, you will be logged in to your account using Single Sign On

Features and capabilities of the Trustifi dashboard

View tracking information for sent emails

  • Who opened the email, where from, and with which device and browser?
  • Were any of the links in the email body clicked?
  • Were any of the email’s attachments downloaded?
  • Did the recipient(s) pass or fail Multi-Factor-Authentication?
  • Was the email printed?
  • …and more.

Tracking information

Control sent emails

  • Block recipients from accessing the email or block the email for everyone
  • Recall the email to edit the the content after it was sent
  • Set or change an expiration date for the email
  • …and more.

Upload a custom logo

You can upload a custom logo from the “Settings” page. The logo will be used in all of your encrypted emails sent with Trustifi.

Add additional “from” addresses

You can add and verify additional email addresses to be used as the “from” address in your emails. Addresses can be added from the “Settings” page.

Add account email

Email addresses must be verified before they can be used. To verify, click on the provided link in the email received from Trustifi Service.

Sending an email with a custom “from” address

After the email address has been verified, you may add the “from” object to your POST request and set the “email” field as the new email address:

const request = require('request');

var postData =  {
  "from":{
    "email": "your-app-name@heroku.trustifi.com"
  },
  "recipients": [{
    "email": "recipient@trustificorp.org"
  }],
  "template": {
    "name": "my_template",
    "fields": {
      "first_field": "hello",
      "second_field": "world"
    }
  }
};

request.post(process.env.TRUSTIFI_URL+'/api/i/v1/email', {
   headers: {
      'x-trustifi-key': process.env.TRUSTIFI_KEY,
      'x-trustifi-secret': process.env.TRUSTIFI_SECRET
   },
   json: postData
}, (err, res, body) => {
   console.log(body);
})

Secure attachments storage

Every attachment sent with Trustifi is saved in an encrypted database and can be accessed from the “Secure Storage” page of the dashboard.

Secure Storage

Information available for your attachments:

  • When was it uploaded?
  • Which email(s) contain this attachment?
  • Does this attachment contain sensitive information?
  • What kind of sensitive content does the attachment contain?

Here’s an example of uploading an attachment using the Trustifi add-on:

const request = require('request');

request.post(process.env.TRUSTIFI_URL+'/api/i/v1/attachment', {
   headers: {
      'x-trustifi-key': process.env.TRUSTIFI_KEY,
      'x-trustifi-secret': process.env.TRUSTIFI_SECRET
   },
   formData: {
      file: {
         value: "text content buffer",
         options: {contentType: "text/plain", filename: "filename.txt"}
      }
   }
}, (err, res, body) => {
   console.log(body);
})

For more information on the features available within the Trustifi dashboard, please see the documentation at Trustifi docs.

Troubleshooting

See https://api.trustifi.com for more information about correct usage and responses

Email address is not verified (error code 400 - bad request)

You must verify your email address by clicking on the provided link in the email sent from Trustifi Support.

User plan is blocked (error code 400 - bad request)

Contact support at heroku-support@trustificorp.com.

User plan is expired (error code 400 - bad request)

Can be solved by upgrading your plan.

Migrating between plans

Use the heroku addons:upgrade trustifi command to migrate to a new plan.

$ heroku addons:upgrade trustifi trustifi:newplan --app your-app-name
-----> Upgrading trustifi:newplan to sharp-mountain-4005... done, v18 ($49/mo)
       Your plan has been updated to: trustifi:newplan

A list of all plans available can be found here.

Removing the add-on

You can remove Trustifi via the CLI:

This will destroy all associated data and cannot be undone!

$ heroku addons:destroy trustifi --app your-app-name
-----> Destroying trustifi-cylindrical-60858 on app-name... done

GDPR

Information about GDPR can be found here: https://trustifi.com/gdpr.pdf

Support

All Trustifi support and runtime issues should be submitted via one of the Heroku Support channels. Any non-support related issues or product feedback is welcome at our support email.

Keep reading

  • All Add-ons

Feedback

Log in to submit feedback.

Information & Support

  • Getting Started
  • Documentation
  • Changelog
  • Compliance Center
  • Training & Education
  • Blog
  • Support Channels
  • Status

Language Reference

  • Node.js
  • Ruby
  • Java
  • PHP
  • Python
  • Go
  • Scala
  • Clojure
  • .NET

Other Resources

  • Careers
  • Elements
  • Products
  • Pricing
  • RSS
    • Dev Center Articles
    • Dev Center Changelog
    • Heroku Blog
    • Heroku News Blog
    • Heroku Engineering Blog
  • Twitter
    • Dev Center Articles
    • Dev Center Changelog
    • Heroku
    • Heroku Status
  • Github
  • LinkedIn
  • © 2025 Salesforce, Inc. All rights reserved. Various trademarks held by their respective owners. Salesforce Tower, 415 Mission Street, 3rd Floor, San Francisco, CA 94105, United States
  • heroku.com
  • Legal
  • Terms of Service
  • Privacy Information
  • Responsible Disclosure
  • Trust
  • Contact
  • Cookie Preferences
  • Your Privacy Choices