You will often want to attach metadata to your contacts. For example, you might want to store their name, address, or the name of their company.
When tracking events, you can attach metadata to the contact. This metadata will be available to view in the dashboard, can be used to segment contacts, and can be used to personalize messages.
In this example, we will track the event project-created and attach the name of the project to the contact.
Metadata keys are case-sensitive!
await fetch('https://api.useplunk.com/v1/track', {
    method: "POST",
    headers: {
        "Content-Type": "application/json",
        "Authorization": "Bearer <API_KEY>"
    },
    body: JSON.stringify({
        "event": "new-project",
        "email": "hello@useplunk.com",
        "data": {
            "project": "Plunk"
        }
    })
});
{{data}} syntax to access the metadata. For example, if you wanted to use the name of the project in your template, you could use {{project}}.
You can also use metadata in your transactional emails. Use the {{data}} syntax to access the metadata. For example, if you wanted to use the name of the project in your email, you could use {{project}}.
await fetch('https://api.useplunk.com/v1/send', {
    method: "POST",
    headers: {
        "Content-Type": "application/json",
        "Authorization": "Bearer <API_KEY>"
    },
    body: JSON.stringify({
        "to": "hello@useplunk.com",
        "subject": "Welcome {{project}}",
        "body": "Welcome to Plunk, {{project}}!"
    })
});
Default values
You can also set default values for metadata keys. If a key does not exist on a contact, the default value will be used instead.
Extend the template with a default value using ??
Reserved keys
There are a few reserved keys that you cannot use as metadata keys. Plunk will ignore these keys and automatically set them for you.
- plunk_id: The ID of the contact.
- plunk_email: The email of the contact.
By default, metadata is persistent. This means that if you track an event and attach metadata, that data will be stored on the contact and will be available to use in the future.
This is not always desirable. For example, if you want to send a one-time password or expiring URL. In that case, you need to explicitly set the metadata to be non-persistent.await fetch('https://api.useplunk.com/v1/track', {
    method: "POST",
    headers: {
        "Content-Type": "application/json",
        "Authorization": "Bearer <API_KEY>"
    },
    body: JSON.stringify({
        "event": "new-project",
        "email": "hello@useplunk.com",
        "data": {
            "project": "Plunk",
            "one-time-password": {
                "value": "123456",
                "persistent": false
            }
        }
    })
});