ua-parser-js VS goggles.mozilla.org

Compare ua-parser-js vs goggles.mozilla.org and see what are their differences.

ua-parser-js

UAParser.js - Free & open-source JavaScript library to detect user's Browser, Engine, OS, CPU, and Device type/model. Runs either in browser (client-side) or node.js (server-side). (by faisalman)

goggles.mozilla.org

Update: This project is no longer maintained and has been archived. See https://foundation.mozilla.org/blog/putting-away-our-x-ray-goggles/ for more information. (by mozilla)
Our great sponsors
  • SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
ua-parser-js goggles.mozilla.org
29 2
8,604 85
- -
8.4 10.0
about 1 month ago over 4 years ago
JavaScript JavaScript
GNU Affero General Public License v3.0 -
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

ua-parser-js

Posts with mentions or reviews of ua-parser-js. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-02-20.
  • Tell HN: Microsoft Teams is blocking Firefox Nightly
    1 project | news.ycombinator.com | 5 Mar 2023
    Just look at all the big companies doing it

    https://faisalman.github.io/ua-parser-js/

  • Liguard - The Linode Guard
    4 projects | dev.to | 20 Feb 2023
    This project is backed under MIT License, special shout out to project UA-Parser, as liguard uses a piece of its source-code.
  • Modern PHP
    10 projects | news.ycombinator.com | 27 Mar 2022
    With NPM, what's actually published is not what's in the git repo, so it's harder to inspect/review vulnerabilities or hijacking. With composer, what's in git _is_ what composer pulls (with the exception of rules in .gitattributes to exclude files etc), making it much easier to trace. One such example: https://github.com/faisalman/ua-parser-js/issues/536

    Composer packages are vendor namespaced, so hijacking an abandoned package is not possible (and it is with NPM), some examples like https://www.theregister.com/2021/08/10/github_npm_package/

  • Some developers are fouling up open-source software
    1 project | /r/linux | 25 Mar 2022
    Sure, I suppose in theory it could happen with other ecosystems, but for some reason it doesn't. It sure seems to just keep happening in NPM though.
  • Vulnerable and Outdated Components
    1 project | /r/reactjs | 9 Jan 2022
    From the other side, npm package may be hijacked(as it happened recently for ua-parser-js and to other packages earlier). To mitigate that, I don't know, probably, subscribing to some security digest would be the most helpful.
  • Red Hat response to Java release cadence change
    1 project | /r/java | 7 Dec 2021
  • Secure software supply chain: why every link matters
    3 projects | dev.to | 16 Nov 2021
    On Oct. 22, 2021, developers of a very common NPM package, ua-parser-js, discovered that some attackers uploaded a compromised version of the package containing malware for Linux and Windows, and were capable of stealing data (at least passwords and cookies from the browser).
  • Thoughts on improving security of Neovim plugins
    7 projects | /r/neovim | 15 Nov 2021
    Since Neovim 0.5 release (which has full Lua support) I see more and more amazing Lua plugins being developed, and I think this trend will likely to continue. But I recently got more concerned about security risks associated with the way Neovim plugins being installed and used (especially after seeing recent compromises like ua-parser-js or coa). Installing typical Neovim plugin is basically downloading and executing random code from the internet on your machine with your user privileges, so hijacked or deliberately malicious plugin could potentially do a lot of damage (like stealing keys/passwords, installing keylogger or just rm -rf / for fun).
  • Hidden XMRig miner malware discovered in hijacked versions of popular ua-parser-js npm library
    1 project | /r/Monero | 24 Oct 2021
    thread about compromise https://github.com/faisalman/ua-parser-js/issues/536
  • Malware Discovered in Popular NPM Package, ua-parser-js
    1 project | /r/cybersecurity | 23 Oct 2021

goggles.mozilla.org

Posts with mentions or reviews of goggles.mozilla.org. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-10-22.
  • NPM package ‘ua-parser-JS’ with more than 7M weekly download is compromised
    13 projects | news.ycombinator.com | 22 Oct 2021
    > check out the Web X-Ray repo <https://github.com/mozilla/goggles.mozilla.org/>.

    Thanks for example. Peeking a bit under the hood, it appears to be due to transitive dependencies referencing github urls (and transient ones at that) instead of semver, which admittedly is neither standard nor good practice...

    FWIW, simply removing `"grunt-contrib-jshint": "~0.4.3",` from package.json and related jshint-related code from Gruntfile was sufficient to get `npm install` to complete successfully. The debugging just took me a few minutes grepping package-lock.json for the 404 URL in question (https://github.com/ariya/esprima/tarball/master) and tracing that back to a top-level dependency via recursively grepping for dependent packages. I imagine that upgrading relevant dependencies might also do the trick, seeing as jshint no longer depends on esprima[0].

    I'm not sure how representative this particular case is to the sort of issues you run into, but I'll tell that reproducibility issues can get a lot worse in ways that committing deps doesn't help (for example, issues like this one[1] are nasty to narrow down).

    But assuming that installation in your link just happens to have a simple fix and that others are not as forgiving, how is committing node_modules supposed to help here if you're saying you can't even get it to a working state in the first place? DO you own the repo in order to be able to make the change? Or are you mostly just saying that hindsight is 20-20?

    [0] https://github.com/jshint/jshint/blob/master/package.json#L4...

    [1] https://github.com/node-ffi-napi/node-ffi-napi/issues/143

What are some alternatives?

When comparing ua-parser-js and goggles.mozilla.org you can also consider the following projects:

react-device-detect - Detect device, and render view according to detected device type.

pnpm - Fast, disk space efficient package manager

bowser - a browser detector

JSHint - JSHint is a tool that helps to detect errors and potential problems in your JavaScript code

remarkable - Markdown parser, done right. Commonmark support, extensions, syntax plugins, high speed - all in one. Gulp and metalsmith plugins available. Used by Facebook, Docusaurus and many others! Use https://github.com/breakdance/breakdance for HTML-to-markdown conversion. Use https://github.com/jonschlinkert/markdown-toc to generate a table of contents.

rfcs - Public change requests/proposals & ideation

enquirer - Stylish, intuitive and user-friendly prompts, for Node.js. Used by eslint, webpack, yarn, pm2, pnpm, RedwoodJS, FactorJS, salesforce, Cypress, Google Lighthouse, Generate, tencent cloudbase, lint-staged, gluegun, hygen, hardhat, AWS Amplify, GitHub Actions Toolkit, @airbnb/nimbus, and many others! Please follow Enquirer's author: https://github.com/jonschlinkert

Secure-Supply-Chain

Serilog - Simple .NET logging with fully-structured events

esprima - ECMAScript parsing infrastructure for multipurpose analysis

handlebars-helpers - 188 handlebars helpers in ~20 categories. Can be used with Assemble, Ghost, YUI, express.js etc.