Create, delete, and modify fastmail masked emails
Check out the Typedoc for Typescript definitions and documentation.
npm install fastmail-masked-email --save
or
yarn add fastmail-masked-email
In order to be able to make requests to the Fastmail API, you will need to create a Fastmail API Token.
This token should be created with the Masked Email
scope to allow for the creation and management of masked emails.
This library relies on the use of two environment variables to authenticate with Fastmail.
JMAP_TOKEN
JMAP_HOSTNAME
( Defaults toapi.fastmail.com
if not explicitly set )
You can set these environment variables in your shell, or in a .env
file in the root of your project and use something like the dotenv package to load them.
Getting a session is the first step in interacting with the Fastmail API. This is done by calling the getSession
function.
A session is an object that is returned containing the accountId
and apiUrl
for the authenticated user,
both of which are required when making more useful requests to Fastmail to interact with masked emails.
import { getSession } from 'fastmail-masked-email';
// Get a session and pass in your token and hostname directly (e.g. from using dotenv)
const session = await getSession(token, hostname);
// getSession will attempt to load the JMAP_TOKEN and JMAP_HOSTNAME
// environment variables if they are not directly passed in as arguments
session = await getSession();
// Getting a session also works with just passing in the token. In this case, the hostname will default to api.fastmail.com
session = await getSession(token);
Once you have a session, you can use it to retrieve a list of all of the masked emails that are currently configured for your account.
This includes enabled
, disabled
, pending
and deleted
masked emails.
All the masked emails are returned in an array of MaskedEmail
objects.
All methods require a session
object to be passed in as the first argument. This session object is used to interact with the
Fastmail API.
import { getAllEmails, getSession } from 'fastmail-masked-email';
const session = await getSession(token, hostname);
const myMaskedEmails = await getAllEmails(session);
console.log(myMaskedEmails);
If you know the unique ID of a masked email you want to retrieve, you can get it by its ID.
import { getEmailById, getSession } from 'fastmail-masked-email';
const session = await getSession(token, hostname);
const myMaskedEmail = await getEmailById('my-masked-email-id', session);
console.log(myMaskedEmail);
Creating a new masked email is done by calling the createEmail
method and passing in both the session
object and an optional options
parameter.
The options
parameter is an object that can contain the following properties:
state
:enabled
|disabled
|pending
( Defaults toenabled
)forDomain
: string ( This is the domain that you want associated with this masked email )description
: string ( This is a description of the masked email )
You can optionally pass in a state
to set the initial state of the masked email. The default state is enabled
.
import { createEmail, getSession } from 'fastmail-masked-email';
const session = await getSession(token, hostname);
// Create a new masked email for the domain 'example.com'
const newMaskedEmail = await createEmail(session, { forDomain: 'example.com' });
// Create a new masked email that is disabled by default
newMaskedEmail = await createEmail(session, { state: 'disabled' });
// Create a new masked email with a description
newMaskedEmail = await createEmail(session, { description: 'My new masked email' });
// Create a new masked email with all options present
newMaskedEmail = await createEmail(session, { forDomain: 'example.com', state: 'enabled', description: 'My new masked email' });
There are three masked email properties that can be updated:
forDomain
state
description
To update a masked email, call the updateEmail
method.
The updateEmail
method requires the id
of the masked email to updateEmail, the session
object, and an options
object.
The options
object can contain any of the above three properties, but MUST contain at least one of them.
updateEmail
returns a rejected promise if no properties are passed into the options object.
import { updateEmail, getSession } from 'fastmail-masked-email';
const session = await getSession(token, hostname);
await updateEmail('my-masked-email-id', session, {
forDomain: 'example.com',
description: 'My new masked email!',
state: 'disabled'
});
Enabling a masked email is done by calling the enableEmail
method and passing in the masked email id
and the session
object.
An enabled masked email will receive any email sent to it.
import { enableEmail, getSession } from 'fastmail-masked-email';
const session = getSession(token, hostname);
await enableEmail('my-masked-email-id', session);
Disabling a masked email is done by calling the disableEmail
method and passing in the masked email id
and the session
object.
When a masked email is disabled, any email sent to it will be sent to the trash.
import { disableEmail, getSession } from 'fastmail-masked-email';
const session = getSession(token, hostname);
await disableEmail('my-masked-email-id', session);
A masked email can be deleted by calling the deleteEmail
method and passing in the masked email id
and the session
object.
Any email sent to a deleted masked email will be sent to the trash.
A deleted email can be restored by enabling it again at which point it will continue to receive emails.
import { deleteEmail, getSession } from 'fastmail-masked-email';
const session = getSession(token, hostname);
await deleteEmail('my-masked-email-id', session);
A masked email that has not received any mail yet can be permanently deleted by calling the permanentlyDeleteEmail
method and passing in the masked email id
and the session
object.
This will permanently delete the masked email and it will no longer be able to be restored.
import { permanentlyDeleteEmail, getSession } from 'fastmail-masked-email';
const session = getSession(token, hostname);
await permanentlyDeleteEmail('my-masked-email-id', session);
- Note on using
async/await
:- In the code examples shown above, we are using
await
to handle asynchronous operations. To useawait
, you must be inside anasync
function. If you're using these examples in your own code, make sure to wrap them in anasync
function. Here's an example of how you can do that:import { getSession, getAllEmails } from 'fastmail-masked-email'; async function main() { const session = await getSession(token, hostname); const myMaskedEmails = await getAllEmails(session); console.log(myMaskedEmails); } main() .then(() => console.log('Done!')) .catch((error) => console.error('An error occurred:', error));
- In the code examples shown above, we are using