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.
@swyftx/express-unless-and
Advanced tools
Conditionally add a middleware to express with some common patterns.
Conditionally skip a middleware when a condition is met. Conditions are ANDed instead of ORed like express-unless.
npm i express-unless-and --save
With existing middlewares:
const unless = require('express-unless-and')
const static = express.static(__dirname + '/public')
static.unless = unless
app.use(static.unless({ method: 'OPTIONS' }))
If you are authoring a middleware you can support unless as follow:
module.exports = function (middlewareOptions) {
let mymid = function (req, res, next) {
}
mymid.unless = require('express-unless-and')
return mymid
}
method
it could be an string or an array of strings. If the request method match the middleware will not run.path
it could be an string, a regexp or an array of any of those. It also could be an array of object which is url and methods key-pairs. If the request path or path and method match, the middleware will not run. Check Examples for usage.ext
it could be an string or an array of strings. If the request path ends with one of these extensions the middleware will not run.custom
it must be a function that accepts req
and returns true
/ false
. If the function returns true for the given request, ithe middleware will not run.useOriginalUrl
it should be true
or false
, default is true
. if false, path
will match against req.url
instead of req.originalUrl
. Please refer to Express API for the difference between req.url
and req.originalUrl
.Require authentication for every request unless the path is index.html.
app.use(requiresAuth.unless({
path: [
'/index.html',
{ url: '/', methods: ['GET', 'PUT'] }
]
}))
Avoid an fstat for request to routes that don't end with a given extension.
app.use(static.unless(function (req) {
let ext = url.parse(req.originalUrl).pathname.substr(-4)
return !~['.jpg', '.html', '.css', '.js'].indexOf(ext)
}))
MIT 2014 - Jose Romaniello
FAQs
Conditionally add a middleware to express with some common patterns.
The npm package @swyftx/express-unless-and receives a total of 0 weekly downloads. As such, @swyftx/express-unless-and popularity was classified as not popular.
We found that @swyftx/express-unless-and demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 open source maintainers 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.