Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
js-restructure
Advanced tools
This package provides a nifty way to match against regular expressions. Construct objects and match against regular expressions.
Based on https://github.com/alexflint/go-restructure
This package allows you to express regular expressions by defining an object, and then capture matched sub-expressions into object's fields.
Here is a very simple email address parser:
var parser = matcher({
_ : "^",
user : "\\w+", // can also pass a JS RegExp here
_2 : "@",
host : "[^@]+",
_3 : "$"
});
var parts = parser("benji@somewhere.com");
console.log(parts.user); // benji
console.log(parts.host); // somewhere.com
Example primitive URL parser:
var m = matcher({
protocol : "http|https",
_1 : "://", // can also pass a RegExp here
host : "[^/]+",
_2 : "/",
path : ".+",
_3 : "$"
})("http://www.google.com/search?foo=bar");
m.protocol; // http
m.host; // www.google.com
m.path; // search?foo=bar
Note: In "real code" use the built-in parsing capabilities of browsers/node to parse real URLs.
Matching nested RegExps is hard to read. The goal of this package is to allow users to match common patterns without having to parse the capturing groups of complex regular expressions and put those in object fields. This "shims" the lack of named capturing groups in JavaScript.
npm install js-restructure
Or in the browser:
<script src='https://wzrd.in/standalone/js-restructure@latest'></script>
Usage in script tag:
var matcher = window.jsRestructure(...);
Any ES5 capable browser is supported meaning IE9+, Firefox, Chrome, Safari and all modern mobile browsers.
Contribution is very welcome and friendliness is a project goal. Feel free to open issues and feature requests. Pull requests are also very welcome.
We indent with two spaces and the code is ES5.
FAQs
This package provides a nifty way to match against regular expressions. Construct objects and match against regular expressions.
The npm package js-restructure receives a total of 0 weekly downloads. As such, js-restructure popularity was classified as not popular.
We found that js-restructure demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.