npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@contiguity/javascript

v2.1.0

Published

Contiguity's JavaScript SDK

Downloads

33

Readme

Installation 🏗 & Setup 🛠

You can install the SDK using NPM.

$ npm install @contiguity/javascript

Then, import & initialize it like this:

const contiguity = require('@contiguity/javascript')
const client = contiguity.login("your token here")

You can also initialize it with the optional 'debug' flag:

const client = contiguity.login("your token here", true)

You can get your token from the Contiguity dashboard.

Sending your first email 📤

As long as you provided Contiguity a valid token, and provide valid inputs, sending emails will be a breeze!

To begin sending an email with an HTML body, you can define a JSON object with all the required fields.

const object = {
    to: "[email protected]",
    from: "Contiguity",
    subject: "My first email!",
    html: "<b>I sent an email using Contiguity</b>"
}

await client.send.email(object)

To send an email with a text body, it's very similar. Just switch "html" to "text".

const object = {
    to: "[email protected]",
    from: "Contiguity",
    subject: "My first email!",
    text: "I sent an email using Contiguity"
}

await client.send.email(object)

async/await is recommend, but technically not required.

Optional fields:

  • replyTo allows you set a reply-to email address.
  • cc allows you to CC an email address

You can also fetch a local email template using client.template.local(file):

const template = await client.template.local('templates/first_email.html')

const object = {
    to: "[email protected]",
    from: "Contiguity",
    subject: "My first email!",
    html: template,
}

await client.send.email(object)

Sending your first text message 💬

As long as you provided Contiguity a valid token, and will provide valid inputs, sending texts will be a breeze!

To begin sending a text message, you can define a JSON object with all the required fields.

const object = {
    to: "+15555555555",
    message: "My first text using Contiguity"
}

await client.send.text(object)

Note: Contiguity expects the recipient phone number to be formatted in E.164. You can attempt to pass numbers in formats like NANP, and the SDK will try its best to convert it. If it fails, it will throw an error!

Sending your first OTP 🔑

Contiguity aims to make communications extremely simple and elegant. In doing so, we're providing an OTP API to send one time codes - for free (no additional charge, the text message is still billed / added to quota)

To send your first OTP, first create one:

const otp_id = await client.otp.send({ 
    to: "+15555555555", 
    language: "en", 
    name: "Contiguity" 
})

Contiguity supports 33 languages for OTPs, including English (en), Afrikaans (af), Arabic (ar), Catalan (ca), Chinese / Mandarin (zh), Cantonese (zh-hk), Croatian (hr), Czech (cs), Danish (da), Dutch (nl), Finnish (fi), French (fr), German (de), Greek (el), Hebrew (he), Hindi (hi), Hungarian (hu), Indonesian (id), Italian (it), Japanese (ja), Korean (ko), Malay (ms), Norwegian (nb), Polish (pl), Portuguese - Brazil (pt-br), Portuguese (pt), Romanian (ro), Russian (ru), Spanish (es), Swedish (sv), Tagalog (tl), Thai (th), Turkish (tr), and Vietnamese (vi)

The name parameter is optional, it customizes the message to say "Your [name] code is ..."

To verify an OTP a user has inputted, simply call client.otp.verify():

const verify = await client.otp.verify({
    otp_id: otp_id // you received this when you called client.otp.send(),
    otp: input // the 6 digits your user inputted.
})

It will return a boolean (true/false). The OTP expires 15 minutes after sending it.

Want to resend an OTP? Use client.otp.resend():

const resend = await client.otp.resend({
    otp_id: otp_id // you received this when you called client.otp.send(),
})

OTP expiry does not renew.

Verify formatting

Contiguity provides two functions that verify phone number and email formatting, which are:

client.verify.number("number")

and

client.verify.email("[email protected]")

They return a boolean (true/false)

Note: This occurs locally, and is not part of Contiguity's online verification service.

Email analytics

If you sent an HTML email, and chose Contiguity to track it, you can fetch an email's status (delivered/read) using:

await client.email_analytics.retrieve("email_id")

Quota

If you'd like to retrieve your quota, whether you're on our free tier or Unlimited, you can fetch it using:

await client.quota.retrieve()

You'll receive an object similar to the crumbs the API provides on completion of every request.

Errors

The SDK really loves to throw errors when things don't go its way, like if a field isn't provided or the API returns a 500. It is recommended to wrap everything in a try/catch block.

Roadmap 🚦

  • Contiguity Identity will be supported
  • Adding support for calls
  • Adding support for webhooks
  • Adding support for online templates
  • and way more.

See complete examples in examples/