Skip to content
This repository has been archived by the owner on Oct 12, 2023. It is now read-only.

Working title for the core component of a proposed joint effort to make a cross-vendor version of Insights.js

License

Notifications You must be signed in to change notification settings

cbsinteractive/openinsights

 
 

Repository files navigation

Open Insights

This repository is no longer maintained.

For current Doppler client work, see https://github.com/cbsinteractive/doppler-client.

Lint

Open Insights is a framework for constructing browser-based RUM clients.

Why Use It

  • Product of collaboration by industry members to measure, and ultimately improve, the internet as a whole.
  • Designed to work with multiple vendors.
  • Meant to be self-hosted, unlike many vendor-centric, browser-based RUM clients.
  • Gives the site owner control over code compilation and included functionality.

Example

import * as openinsights from "@tacoherd/openinsights"

const openinsightsFetchDependencies = {
  clearTimeout: (timeoutID) => clearTimeout(timeoutID),
  fetch: (url, options) => fetch(url, options),
  newAbortController: () => new AbortController(),
  newDate: () => new Date(),
  performanceEntryManager: new openinsights.PerformanceEntryManager({
    newDate: () => new Date(),
    newPerformanceObserver: (callback) => new PerformanceObserver(callback),
  }),
  setTimeout: (fn, timeout) => setTimeout(fn as TimerHandler, timeout),
}

const customFetchBehavior = (sessionConfiguration, url) => async () => {
  console.log(sessionConfiguration)
  openinsights.fetch(
    openinsightsFetchDependencies,
    url,
    /**
     * fetchTimeoutInMilliseconds
     */
    8000,
    /**
     * requestHeaders
     */
    null,
    /**
     * beforeTest
     */
    async () => ({ timeout: false }),
    /**
     * beforeBeacon
     *
     * Optional processing before sending a beacon (e.g. obtain client DNS resolver IP)
     */
    async (result, response, performanceEntry) => {},
    /**
     * sendBeacon
     *
     * Clients can beacon data any way they like here (Beacon API, Fetch API, <img src="...">, etc.)
     *
     * @param result An object containing the HTTP status and the Resource Timing entry from which to produce a beacon payload
     */
    (result) => {
      navigator.sendBeacon(
        "https://some.beacon.ingest.service/",
        new Blob(
          [
            JSON.stringify({
              /* some encoded data */
            }),
          ],
          { type: "application/json" },
        ),
      )
    },
    /**
     * afterTest
     */
    (result) => {},
    /**
     * onError
     */
    (error) => {},
  )
}

const sessionStartupFuncs = [
  {
    fetchSessionConfiguration: async () => {
      return await fetch(
        "https://some.session.config.service/sessionconfig.json",
      ).then((response) => response.json())
    },
    produceExecutables: (sessionConfiguration) => {
      // Produce any number of tests to be run sequentially
      return [
        {
          execute: customFetchBehavior(
            sessionConfiguration,
            /**
             * A test object served with:
             * - `access-control-allow-origin: *`
             * - `timing-allow-origin: *`
             */
            "https://some.service.to.test/test.png",
          ),
        },
        /* ... */
      ]
    },
  },
  /* ... */
]

openinsights.init(
  /**
   * getDocumentReadyState
   */
  () => document.readyState,
  /**
   * addDocumentReadyStateChangeListener
   */
  (callback) => document.addEventListener("readystatechange", callback),
  /**
   * sessionConfigDelayInMilliseconds
   */
  10000,
  /**
   * sessionStartupFuncs
   */
  sessionStartupFuncs,
)

Development

In most cases, developers will reference the core module as a dependency, using it to compile a customized client for use on their sites. These instructions are for working on the core module itself.

Install Dependencies

Within the project root directory:

npm install

Run Linter

npm run lint

Run Tests

npm test

Build Code Documentation

npm run build:doc

Publish

Install prerequesite:

npm install --global np

Build release and publish to npm:

np --branch main-forked

About

Working title for the core component of a proposed joint effort to make a cross-vendor version of Insights.js

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 94.3%
  • JavaScript 5.7%