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

fiftyone.devicedetection.onpremise

v4.4.166

Published

Device detection on-premise services for the 51Degrees Pipeline API

Downloads

2,156

Readme

51Degrees Node Device Detection On-Premise

Developer Documentation

Introduction

This project contains 51Degrees Device Detection engines that can be used with the Pipeline API.

The Pipeline is a generic web request intelligence and data processing solution with the ability to add a range of 51Degrees and/or custom plug ins (Engines)

This package - fiftyone.devicedetection.onpremise

This package provides a On-Premise implementation of Device Detection engine which makes use of a local data file. This includes a builder used to build a pipeline for On-Premise Device Detection engine.

This package requires the following additional packages:

Installation

Using NPM call:

npm install fiftyone.devicedetection.onpremise

On-Premise

When running on-premise, a local Hash V4.1 data file is required.

Hash: A large binary file populated with User-Agent signatures allowing very fast detection speeds.

51Degrees provides multiple options, some of which support automatic updates through the Pipeline API.

If the module is installed directly from Git then the binaries are also required. These binaries are native module which contains the core engine of device detection. Below are the steps to build these binaries:

Pre-requisites

  • Install Node.js.
  • Install node-gyp by running.
    • npm install node-gyp --global
  • Install C build tools:
    • Windows:
      • You will need either Visual Studio 2019 or the C++ Build Tools installed.
        • Minimum platform toolset version is v142
        • Minimum Windows SDK version is 10.0.18362.0
    • Linux/MacOS:
      • sudo apt-get install g++ make libatomic1
  • Pull git submodules:
    • git submodule update --init --recursive

Build Steps

  • Navigate to fiftyone.devicedetection.onpremise
  • Rename the binding.51d to binding.gyp
  • Run npm install
    • Alternatively this step can be replaced by the followings:
      • Create a folder named build.
      • Run node-gyp configure
      • Run node-gyp build
    • Platform specific:
      • Windows
        • By default this will look for Visual Studio 2019 and a minimum Windows SDK version 10.0.18362.0.
        • This can be overwritten by include --msvs_version=[VS version] and --msvs_target_platform_version=[Windows SDK Version] as part of the npm install command.
          • NOTE: This is not recommended. Also, some time the latest SDK version is selected instead, as observed in environment with multiple SDK versions installed. Thus, only install the correct Visual Studio version and the minimum required Windows SDK version as recommended.
  • This will build the FiftyOneDeviceDetectionHashV4.node under build/Release folder.
  • Copy the FiftyOneDeviceDetectionHashV4.node to build directory (which is one level up) and rename it using the following convention.
    • Windows:
      • FiftyOneDeviceDetectionHashV4-win32-[ Node version ].node
        • e.g. FiftyOneDeviceDetectionHashV4-win32-10.node for Node 10.
    • Linux:
      • FiftyOneDeviceDetectionHashV4-linux-[ Node version ].node
        • e.g. FiftyOneDeviceDetectionHashV4-linux-10.node for Node 10.
    • MacOS:
      • FiftyOneDeviceDetectionHashV4-darwin-[ Node version ].node
        • e.g. FiftyOneDeviceDetectionHashV4-darwin-10.node for Node 10.
    • Please see the tested versions page for Node versions that we currently test against. The software may run fine against other versions, but extra caution should be applied.
    • You can optionally clear up by removing all the build files and folders except for the *.node file that's been created.
    • WARNING: npm install removes this copied file, so you will need to do the above steps again after running npm install

Examples

For details of how to run the examples, please refer to run examples. The tables below describe the examples that are available.

| Example | Description | |----------------------------------------|-------------| | automaticupdates/dataFileSystemWatcher.js | How to configure automatic updates using the file system watcher to monitor for changes to the data file. | | automaticupdates/updateOnStartUp.js | How to configure the Pipeline to automatically update the device detection data file on startup. | | automaticupdates/updatePollingInterval.js | Ho to configure and verify the various automatic data file update settings. | | gettingstarted-console | How to use the 51Degrees on-premise device detection API to determine details about a device based on its User-Agent and User-Agent Client Hints HTTP header values. | | gettingstarted-web | How to use the 51Degrees Cloud service to determine details about a device as part of a simple web server. | | matchmetrics-console | How to view metrics associated with the results of processing with a Device Detection engine. | | metadata-console | How to access the meta-data that relates to the device detection algorithm. | | offlineprocessing-console | How to process data for later viewing using a Device Detection Hash data file. | | performance-console | How to configure the various performance options and run a simple performance test. | | updatedatafile-console | This example illustrates various parameters that can be adjusted when using the on-premise device detection engine, and controls when a new data file is sought and when it is loaded by the device detection software. | | useragentclienthints-web | This is now deprecated. Kept for testing purposes. Please see gettingstarted-web instead. |

Tests

In this repository, there are tests for the examples. You will need to install jest to run them:

npm install jest --global

You will also need to install any required packages for the examples in the Examples section.

To run the tests, navigate to the module directory and execute:

npm test

Native code updates

Process for rebuilding SWIG interfaces following an update to the device detection cxx code (This is only intended to be run by 51Degrees developers internally):

  1. Ensure Swig is installed.
    1. At the time when this README was updated, the current stable version of Swig did not support new changes in Node 12 and above.
    2. The Swig version being used is built from the following branch.
      1. https://github.com/yegorich/swig/tree/pr/new-node-fixes.
      2. There had been an active Pull Request created to merge the changes to the main Swig master branch.
      3. Once the Pull Request is completed, the consequent Swig releases should be used.
  2. Update the device-detection-cxx submodule to reference the relevant commit.
  3. From terminal, navigate to fiftyone.pipeline.devicedetection and run: a) swig -c++ -javascript -node hash_node.i
  4. Commit changes to repository.
  5. Run the 'Build Device Detection Binaries for Node.js' Azure CI Pipeline.
  6. Copy the produced artifacts into the fiftyone.pipeline.devicedetection/build directory.
  7. Commit changes to repository.