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

@manufac/browserprint

v1.1.7

Published

A [device fingerprint](https://en.wikipedia.org/wiki/Device_fingerprint) or machine fingerprint is information collected about the software and hardware of a remote computing device for the purpose of identification. A browser fingerprint is collected spe

Downloads

6

Readme

Client Side Browser Fingerprinting

A device fingerprint or machine fingerprint is information collected about the software and hardware of a remote computing device for the purpose of identification. A browser fingerprint is collected specifically by interaction with the web browser of the device.

It is mainly used for web tracking: collection and sharing of information about an individual’s activity on the internet. It's hard to control how this information gets used by the entities who collect them. However, as users there are multiple tools available at our disposal to help make these fingerprint as less unique/reliable as possible.

The intent behind this library is mainly to study how browser fingerprinting works rather than indulging in web tracking. The uniqueness of the fingerprint isn't high in that 2 identical iPhones using the same browser (vendor & version) should reap indentical fingerprints.

Usage

  • Install

yarn add @manufac/browserprint

  • Import
import { getBrowserFingerprint } from "@manufac/browserprint";

getBrowserFingerprint().then((fingerprint) => {
  console.log(fingerprint);
})
  • The fingerprint that this library generates looks like:
{
  "hash": "-1129309543",
  "data": {
    "navigator": {
      "languages": [
        "en-GB",
        "en-US",
        "en"
      ],
      "userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36",
      "vendor": "Google Inc.",
      "platform": "MacIntel",
      "hardwareConcurrency": 16,
      "maxTouchPoints": 0
    },
    "window": {
      "sessionStorage": true,
      "localStorage": true,
      "indexedDB": true,
      "colorDepth": 24,
      "resolution": [
        1920,
        1080
      ],
      "rtc": true,
      "webSocket": true
    },
    "css-media": {
      "any-hover": [
        "hover"
      ],
      "any-pointer": [
        "fine"
      ],
      "color-gamut": [
        "srgb"
      ],
      "prefers-contrast": [
        "no-preference"
      ],
      "forced-colors": [
        "none"
      ],
      "prefers-reduced-motion": [
        "no-preference"
      ],
      "inverted-colors": [],
      "dynamic-range": [
        "standard"
      ],
      "grid": [
        "0"
      ],
      "hover": [
        "hover"
      ],
      "overflow-block": [],
      "overflow-inline": [],
      "pointer": [
        "fine"
      ],
      "prefers-color-scheme": [
        "light"
      ],
      "scripting": [],
      "update": [],
      "video-dynamic-range": [],
      "device-height": [
        "1080px"
      ],
      "device-width": [
        "1920px"
      ],
      "resolution": [
        "96dpi"
      ],
      "color": [
        "8"
      ],
      "color-index": [
        "0"
      ],
      "monochrome": [
        "0"
      ]
    },
    "math": {
      "acos": 1.4473588658278522,
      "acosh": 709.889355822726,
      "asin": 0.12343746096704435,
      "asinh": 0.881373587019543,
      "atan": 0.4636476090008061,
      "atanh": 0.5493061443340548,
      "sin": 0.8178819121159085,
      "sinh": 1.1752011936438014,
      "cos": -0.8390715290095377,
      "cosh": 1.5430806348152437,
      "tan": -1.4214488238747245,
      "tanh": 0.7615941559557649,
      "exp": 2.718281828459045,
      "expm1": 1.718281828459045,
      "log1p": 2.3978952727983707,
      "cbrt": 1.4422495703074083,
      "sqrt": 1.4142135623730951
    },
    "fonts": [
      "Arial Unicode MS",
      "Gill Sans",
      "Helvetica Neue",
      "Menlo"
    ],
    "canvas": {
      "winding": true,
      "geometry": "....",
      "textImage": "....."
    },
    "audio": "1240202222"
  }
}
  • The hash property contains the hash of the data object.

Strategies used for browser fingerprinting

Audio

Audio fingerprinting appears conceptually similar to canvas fingerprinting. Audio signals processed on different machines or browsers may have slight differences due to hardware or software differences between the machines. Our implementation uses OfflineAudioContext to generate and process the audio signals. Eventually, the processed audio signal is used for creating a hash that in turn is used for the unique identification of the browser. Reference: Audio fingerprinting

Canvas

Canvas is an HTML5 API used to draw graphics and animations on a web page via scripting in JavaScript. The technique is based on the fact that the same canvas image may be rendered differently on different computers. This happens for several reasons:

  • At the image format level: Web browsers use different image processing engines, image export options, compression levels, etc.
  • At the OS level: Different OS have different fonts and use different rendering algorithms and settings.

In this strategy, we render two images, one consisting of text and emoji and the other of geometrical shapes. The generated images are converted into data URLs. These URLs are then used for creating fingerprint of the browser. We also determine if the browser supports winding or not. Reference: Canvas

Clock-Cycle

Hardware features have also been introduced to identify web users and perform web tracking. Hardware fingerprint exploits differences in the computer internal clock signals. For fingerprint generation we compute the time required to execute different invocation of a target function. Disclaimer: fingerprint generated using this strategy is not stable and hence, not included in the final signature.

CSS Media

Media queries allow us to apply CSS styles depending on a device's characteristics, such as screen resolution, browser viewport width, etc. In this strategy, we generate a dictionary that contains information about various CSS Media features and their values supported by the browser.

Fonts

The font fingerprinting technique is based on identifying the fonts available in the browser under consideration. A basic text string has been chosen consisting of alphabets, numbers, and special characters in this fingerprinting technique ("mmMwWLliI0O&1"). The text string is then rendered with different font families to identify if the given font is available in the browser or not. Eventually, all the available font names are combined together to create the fingerprint. Reference: Fonts Fingerprint

Math

Modern CPUs and Operating systems follow IEEE standards when it comes to computing math equations, however, these standards do not clearly define how certain functions such as SIN, COS, TAN, etc. should be computed. Errors crop up as these functions often require multiple steps and intermediary values could be defined as floats, doubles, or something else, and with each round of calculations rounding errors alter the LSB ever so slightly. This allows you to determine the browser and OS in many cases.

Adopted from Math Routine Fingerprint.

Navigator

The window.navigator object contains information about the visitor's browser, system, platform, languages and many more. Some of this information is unique to a system and can help create a fingerprint for the browser under consideration.

For example, this is a portion of a window.navigator object:

  {
    appCodeName: "Mozilla",
    appName: "Netscape",
    appVersion: "5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36",
    language: "en-US",
  }

Some properties used in this library: languages, userAgent, platform etc. Reference: Navigator Fingerprint

Windows

In a browser environment, the window object represents the browser window containing a web page. It can tell us details like the dimensions and the color depth of the parent screen, which pages have been visited before the current page, and many more. Some of these values add to the uniqueness of a browser and can be used for generating its fingerprint.

For example, this is a portion of a window object:

  {
    screen: {
    availHeight: 624,
    availWidth: 1175,
    colorDepth: 24,
    height: 661,
    },
    scrollX: 0,
    scrollY: 775.53515625,
    pixelDepth: 24
  }

Libraries/Research from which the source code is inspired