Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) Safe-mode: OFF (not secure) /usr/local/lib/node_modules/wonlog/node_modules/lusca/ drwxr-xr-x | |
| Viewing file: Select action/file-type: /*───────────────────────────────────────────────────────────────────────────*\
│ Copyright (C) 2016 PayPal │
│ │
│hh ,'""`. │
│ / _ _ \ Licensed under the Apache License, Version 2.0 (the "License"); │
│ |(@)(@)| you may not use this file except in compliance with the License. │
│ ) __ ( You may obtain a copy of the License at │
│ /,'))((`.\ │
│(( (( )) )) http://www.apache.org/licenses/LICENSE-2.0 │
│ `\ `)(' /' │
│ │
│ Unless required by applicable law or agreed to in writing, software │
│ distributed under the License is distributed on an "AS IS" BASIS, │
│ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. │
│ See the License for the specific language governing permissions and │
│ limitations under the License. │
\*───────────────────────────────────────────────────────────────────────────*/
'use strict';
var crypto = require('crypto');
/**
* Outputs all security headers based on configuration
* @param {Object} options The configuration object.
*/
var lusca = module.exports = function (options) {
var headers = [];
var nonce;
if (options) {
Object.keys(lusca).forEach(function (key) {
var config = options[key];
if (key === "csp" && options[key] && (options[key]['styleNonce'] || options[key]['scriptNonce'])) {
nonce = true;
}
if (config) {
headers.push(lusca[key](config));
}
});
}
return function lusca(req, res, next) {
var chain = next;
if (nonce) {
Object.defineProperty(res.locals, 'nonce', {
value: crypto.pseudoRandomBytes(36).toString('base64'),
enumerable: true
});
}
headers.forEach(function (header) {
chain = (function (next) {
return function (err) {
if (err) {
next(err);
return;
}
return header(req, res, next);
};
}(chain));
});
chain();
};
};
lusca.csrf = require('./lib/csrf');
lusca.csp = require('./lib/csp');
lusca.hsts = require('./lib/hsts');
lusca.p3p = require('./lib/p3p');
lusca.xframe = require('./lib/xframes');
lusca.xssProtection = require('./lib/xssprotection');
lusca.nosniff = require('./lib/nosniff');
lusca.referrerPolicy = require('./lib/referrerpolicy');
|
:: Command execute :: | |
--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0223 ]-- |