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

zami

v1.0.4

Published

Typescript/Node.js library to send and receive messages across popular chat networks like WhatsApp and Instagram

Downloads

4

Readme

Zami Node.js SDK

Node.js Library for the Zami API. Currently supports WhatsApp and Instagram. Support for LinkedIn, X, Telegram, Signal and Messenger is coming soon.

Install

npm install --save zami
# or
yarn add zami

Setup

First you need to get an API secret, you can get one by clicking here

import { Zami } from "zami";
const zami = new Zami("om-secret-abcdefhijklmnopqrstuvwxyz");

Once you have an API secret and you've logged in to the dashboard you should create your first connection, a connection represents an account you've connected to Zami to send and receive messages, it could be a WhatsApp number or Instagram account.

Usage

Sending text messages

import { Zami } from "zami";
const zami = new Zami("om-secret-abcdefhijklmnopqrstuvwxyz");

zami.sendText({
  connection_id: "<connection_id>",
  recipient: "+18096968926",
  body: "Hello from Zami",
});

Sending media messages (image/video/audio)

import { Zami } from "zami";
import fs from "fs/promises";
const zami = new Zami("om-secret-abcdefhijklmnopqrstuvwxyz");

async function send() {
  const buffer = await readFile("path/to/image.png");
  await zami.sendMedia({
    connection_id: "<connection_id>",
    media: buffer,
    content_type: "image/png",
    recipient: "+18096968926",
  });
}

send();

Receiving incoming messages

import { Zami } from "zami";
import fs from "fs/promises";
const zami = new Zami("om-secret-abcdefhijklmnopqrstuvwxyz");

zami.listen((message) => {
  console.log("New message: " + JSON.stringify(message));
});

Alternatively you can register a webhook in the dashboard, Zami will call the webhook URL and pass new message data.

If you decide with the webhook route, it's likely during development your server will be running in localhost and not be publicly accesible, we recommend using ngrok during development to create a publicly accesible tunnel to your development server.

The sample script below creates a /webhook endpoint which you can register in the dashboard to test and see incoming message data.

const express = require("express");
const app = express();

app.use(express.json());

app.post("/webhook", (req, res) => {
  console.log("Received webhook:", req.body);
  res.status(200).send("Data received");
});

const PORT = process.env.PORT || 3000;
app.listen(PORT, () => {
  console.log(`Server is running on port ${PORT}`);
});