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 🙏

© 2025 – Pkg Stats / Ryan Hefner

@peermetrics/sdk

v2.7.2

Published

The peer metrics javascript SDK

Downloads

1,497

Readme

PeerMetrics SDK

This is the repo for the PeerMetrics JS SDK.

Peer metrics is a service that helps you collect events and metrics for your WebRTC connections.

You can read more about the service on peermetrics.io.

Contents

  1. Install
  2. Usage
    1. Options
    2. API
    3. Static methods
  3. SDK integrations
    1. LiveKit
    2. Twilio Video
    3. Mediasoup
    4. Janus
    5. Vonage
    6. Agora
    7. Pion
    8. SimplePeer
  4. Browser support
  5. Use cases
  6. License

Install

To use the sdk you can install the package through npm:

npm install @peermetrics/sdk

Then

import { PeerMetrics } from '@peermetrics/sdk'

Or load it directly in the browser:

<script src="//cdn.peermetrics.io/js/sdk/peermetrics.min.js"></script>

Usage

To use the sdk you need a peer metrics account. Once you've created an organization and an app you will receive an apiKey

let peerMetrics = new PeerMetrics({
    apiKey: '7090df95cd247f4aa735779636b202',
    userId: '1234',
    userName: 'My user',
    conferenceId: 'conference-1',
    conferenceName: 'Conference from 4pm',
    appVersion: '1.0.1'
})
// initialize the sdk
await peerMetrics.initialize()

In order to start tracking a connection, use the .addConnection() method:

let pc1 = new RTCPeerConnection({...})
await peerMetrics.addConnection({
    pc: pc1,
    peerId: '1' # any string that helps you identify this peer
})

Options

To instantiate the sdk you have the following options:

let peerMetrics = new PeerMetrics({
    // the api key associated to the app created inside your account
    apiKey: '', // String, mandatory

    // a string that will help you indentify this user inside your peer metrics account
    userId: '1234', // String, mandatory

    // a readable name for this user
    userName: 'My user', // String, optional

    // an ID to identify this conference
    conferenceId: 'conference-1', // String, mandatory

    // a readable name for this conference
    conferenceName: 'Conference from 4pm', // String, optional

    // the version of your app. this helps you filter conferecens/stats/issues for a specific version
    appVersion: '0.0.1', // String, optional

    // if the sdk can't be run on the other side of the call (for example a SFU) you can still collect some stats for that using this flag
    remote: true, // Boolean, optional, Default: true

    // Object, optional: if you would like to save some additional info about this user
    // there is a limit of 5 attributes that can be added. only string, number, boolean supported as values
    meta: {
        isRegistered: true,
        plan: 'premium'
    },

    // if you would like to save events from some page events
    pageEvents: {
        pageVisibility: false // when the user focuses on another tab
    }
})

API

.initialize()

Used to initialize the SDK. Returns a promise that rejects if any problems were encountered (for example invalid apiKey, over quota, etc)

.addSdkIntegration(options)

Used to integrate with different SDKs. See here list for options.

.addConnection(options)

Adds a connection to the watch list. options

{
	`pc`: pc, // RTCPeerConnection instance
	`peerId`: 'peer-1' // String, a unique Id to identify this peer
}

Note: Monitoring of a peer will automatically end when the connection is closed.

.endCall()

The helper method stops listening to events on all connections and also ends the current session of this user.

This is useful for the case when multiple conferences happen consecutively without the user refreshing the page.

.removeConnection(options)

Stop listening for events on a specific connection.

options can be one of two options:

{
	'connectionId': '123' // the one returned after calling `.addConnection()`
}

OR

{
	'pc': pc // the `RTCPeerConnection` instance
}

.removePeer(peerId)

Stop listening for events/stats on all the connections for this peer

.addEvent(object)

Add a custom event for this participant. Example:

{
    eventName: 'open settings',
    description: 'user opened settings dialog'
}

object doesn't require a specific structure, but if the eventName attribute is present, it will be displayed on the event timeline in your dashboard.

This helps you get a better context of the actions the user took that might have impacted the WebRTC experience.

.mute()/.unmute()

Save event that user muted/unmuted the microphone

Static methods

.getPageUrl()

Method used to get the peer metrics page url for a conference or a participants. Useful if you would like to link to one of these pages in your internal website/tool.

await PeerMetrics.getPageUrl({
    apiKey: 'you-api-key', // mandatory

    userId: 'my-user-id', // the userId provided to peer metrics during a call
    // or
    conferenceId: 'confence-id' // an ID provided for a past conference
})

SDK integrations

You can use PeerMetrics with many well known WebRTC SDKs.

In order to integrate you can initialize the SDK as usually and then call .addSdkIntegration() with special options:

let peerMetrics = new PeerMetrics({
    apiKey: '7090df95cd247f4aa735779636b202',
    userId: '1234',
    userName: 'My user',
    conferenceId: 'room-1',
    conferenceName: 'Call from 4pm'
})

// initialize the SDK
await peerMetrics.initialize()

// call addSdkIntegration() with the appropriate options for each SDK
await peerMetrics.addSdkIntegration(options)

// That's it

The options object differs depending on the integration.

Note: There's no need to call addConnection() anymore, the PeerMetrics SDK will take care of adding connection listeners and sending events.

List of SDKs that PeerMetrics supports:

LiveKit

To integrate with LiveKit' js sdk you need to pass an instance of Room.

Note You need at least version v0.16.2 of livekit-client.

import { Room } from 'livekit-client'

const room = new Room(roomOptions)

peerMetrics.addSdkIntegration({
	livekit: {
        room: room, // mandatory, the livekit client Room instance
        serverId: '', // string, optional, an ID to indentify the SFU server the user connects to (default: livekit-sfu-server)
        serverName: '' // string, optional, a more readable name for this server (default: LiveKit SFU Server)
    }
})

Twilio Video

You can integrate with v2 of Twilio Video SDK. To do that, you need to pass the instance of Room. For example:

import Video from 'twilio-video'

Video.connect('$TOKEN', { name: 'room-name' }).then(room => {
    peerMetrics.addSdkIntegration({
        twilioVideo: {
            room: room, // mandatory, the twilio video Room instance
        }
    })
})

Mediasoup

To integrate with mediasoup you need to pass in the device instance:

import * as mediasoupClient from 'mediasoup-client'

let device = new mediasoupClient.Device({
    handlerName : this._handlerName
})

peerMetrics.addSdkIntegration({
	mediasoup: {
        device: device, // mandatory, the mediasoupClient.Device() instance
        serverId: '', // string, optional, an ID to indentify the SFU server the user connects to (default: mediasoup-sfu-server)
        serverName: '' // string, optional, a more readable name for this server (default: MediaSoup SFU Server)
    }
})

Janus

If you are using the Janus javascript sdk to create connections to Janus server, you can integrate by sending the plugin handler that result from calling .attach(). First thing:

let peerMetrics = new PeerMetrics({
    ...
})
await peerMetrics.initialize()

And then:

let janus = new Janus({
    server: server,
    success: function() {
        // Attach to VideoCall plugin
        janus.attach({
            plugin: "janus.plugin.videocall",
            opaqueId: opaqueId,
            success: function(pluginHandle) {
                peerMetrics.addSdkIntegration({
					janus: {
                        plugin: pluginHandle, // mandatory
                        serverId: '', // string, optional, an ID for this SFU server (default: janus-sfu-server)
                        serverName: '' // string, optional, a more readable name for this server (default: Janus SFU Server)
                    }
                })

                ...
            }
        })
    }
})

Vonage

To integrate with Vonage SDK (previously Tokbox) you will need to load PeerMetrics before it. For example:

<!-- First we need to set a special global option -->
<script>
    var PeerMetricsOptions = {
        wrapPeerConnection: true
    }
</script>

<!-- Load the sdk -->
<script src="//cdn.peermetrics.io/js/sdk/peermetrics.min.js"></script>

<!-- Then setup PeerMetrics. This can alse be done later, but before calling OT.initSession() -->
<script>
    (async () => {
        let peerMetrics = new PeerMetrics({
            ...
        })
        await peerMetrics.initialize()

        peerMetrics.addSdkIntegration({
            vonage: true
        })
    })()
</script>

<!-- Load the OpenTok sdk -->
<script src="https://static.opentok.com/v2/js/opentok.min.js"></script>

Agora

To integrate with Agora SDK you will need to load PeerMetrics before it. For example:

<!-- First we need to set a special global option -->
<script>
    var PeerMetricsOptions = {
        wrapPeerConnection: true
    }
</script>

<!-- Load the sdk -->
<script src="//cdn.peermetrics.io/js/sdk/peermetrics.min.js"></script>

<!-- Then setup PeerMetrics. This can alse be done later, but before calling OT.initSession() -->
<script>
    (async () => {
        let peerMetrics = new PeerMetrics({
            ...
        })
        await peerMetrics.initialize()

        peerMetrics.addSdkIntegration({
            agora: true
        })
    })()
</script>

<!-- Load the Agora sdk -->
<script src="https://download.agora.io/sdk/release/AgoraRTC_N.js"></script>

Or, if you are using a bundler:

import { PeerMetrics } from '@peermetrics/sdk'
// call wrapPeerConnection as soon as possible
PeerMetrics.wrapPeerConnection()

let peerMetrics = new PeerMetrics({...})
await peerMetrics.initialize()

peerMetrics.addSdkIntegration({
    agora: true
})

Pion

Integrating with Pion is dead simple. If for example you are using ion sdk js, just initialize peer metrics first and you are good to go:

import { Client, LocalStream, RemoteStream } from 'ion-sdk-js';
import { IonSFUJSONRPCSignal } from 'ion-sdk-js/lib/signal/json-rpc-impl';
import { PeerMetrics } from '@peermetrics/sdk'

let peerMetrics = new PeerMetrics({...})
await peerMetrics.initialize()

peerMetrics.addSdkIntegration({
    pion: true
})

// then continue with the usual things
const signal = new IonSFUJSONRPCSignal("wss://ion-sfu:7000/ws");
const client = new Client(signal);
signal.onopen = () => client.join("test session", "test uid")

You can pass additional details to addSdkIntegration() to better identify the SFU server the user is connecting to:

peerMetrics.addSdkIntegration({
    pion: {
        serverId: 'pion-sfu-na',
        serverName: 'Pion SFU North America'
    }
})

SimplePeer

To integrate with SimplePeer you would just need to pass the RTCPeerConnection to PeerMetrics. For example:

var peer = new SimplePeer({
    initiator: true,
    config: iceServers,
    stream: stream,
    trickle: true
})

peerMetrics.addConnection({
    pc: peer._pc,
    peerId: peerId
})

Browser support

Right now, the SDK is compatible with the latest version of Chromium based browsers (Chrome, Edge, Brave, etc), Firefox and Safari.

Use cases

Multiple calls on a page

If you app permits the user to have multiple calls on page you'll need to initialize the PeerMetrics instance every time.

For example:

  1. On page load initialize the SDK as mentioned in the docs

    let peerMetrics = new PeerMetrics({
        apiKey: '7090df95cd247f4aa735779636b202',
        userId: '1234',
        userName: 'My user',
        conferenceId: 'conference-1',
        conferenceName: 'Conference from 4pm',
        appVersion: '1.0.1'
    })
  2. Call initialize()

    await peerMetrics.initialize()
  3. Call addConnection() or if you use one of our SDK integration, follow the steps for that specific case

    await peerMetrics.addConnection({
        pc: pc1,
        peerId: '1' # any string that helps you identify this peer
    })
  4. At the end of the current call/conference, call .endCall()

    await peerMetrics.endCall()
  5. To start monitoring again, call initialize() again with details for the new conference

    await peerMetrics.initialize({
        conferenceId: 'conference-2',
        conferenceName: 'Second Conference',
    })
  6. Continue from step 3

License

MIT