aboutsummaryrefslogtreecommitdiff
path: root/node_modules/clean-css/lib/reader/is-allowed-resource.js
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2017-05-03 15:35:00 +0200
committerFlorian Dold <florian.dold@gmail.com>2017-05-03 15:35:00 +0200
commitde98e0b232509d5f40c135d540a70e415272ff85 (patch)
treea79222a5b58484ab3b80d18efcaaa7ccc4769b33 /node_modules/clean-css/lib/reader/is-allowed-resource.js
parente0c9d480a73fa629c1e4a47d3e721f1d2d345406 (diff)
node_modules
Diffstat (limited to 'node_modules/clean-css/lib/reader/is-allowed-resource.js')
-rw-r--r--node_modules/clean-css/lib/reader/is-allowed-resource.js77
1 files changed, 77 insertions, 0 deletions
diff --git a/node_modules/clean-css/lib/reader/is-allowed-resource.js b/node_modules/clean-css/lib/reader/is-allowed-resource.js
new file mode 100644
index 000000000..043066e42
--- /dev/null
+++ b/node_modules/clean-css/lib/reader/is-allowed-resource.js
@@ -0,0 +1,77 @@
+var path = require('path');
+var url = require('url');
+
+var isRemoteResource = require('../utils/is-remote-resource');
+var hasProtocol = require('../utils/has-protocol');
+
+var HTTP_PROTOCOL = 'http:';
+
+function isAllowedResource(uri, isRemote, rules) {
+ var match;
+ var absoluteUri;
+ var allowed = isRemote ? false : true;
+ var rule;
+ var isNegated;
+ var normalizedRule;
+ var i;
+
+ if (rules.length === 0) {
+ return false;
+ }
+
+ if (isRemote && !hasProtocol(uri)) {
+ uri = HTTP_PROTOCOL + uri;
+ }
+
+ match = isRemote ?
+ url.parse(uri).host :
+ uri;
+
+ absoluteUri = isRemote ?
+ uri :
+ path.resolve(uri);
+
+ for (i = 0; i < rules.length; i++) {
+ rule = rules[i];
+ isNegated = rule[0] == '!';
+ normalizedRule = rule.substring(1);
+
+ if (isNegated && isRemote && isRemoteRule(normalizedRule)) {
+ allowed = allowed && !isAllowedResource(uri, true, [normalizedRule]);
+ } else if (isNegated && !isRemote && !isRemoteRule(normalizedRule)) {
+ allowed = allowed && !isAllowedResource(uri, false, [normalizedRule]);
+ } else if (isNegated) {
+ allowed = allowed && true;
+ } else if (rule == 'all') {
+ allowed = true;
+ } else if (isRemote && rule == 'local') {
+ allowed = allowed || false;
+ } else if (isRemote && rule == 'remote') {
+ allowed = true;
+ } else if (!isRemote && rule == 'remote') {
+ allowed = false;
+ } else if (!isRemote && rule == 'local') {
+ allowed = true;
+ } else if (rule === match) {
+ allowed = true;
+ } else if (rule === uri) {
+ allowed = true;
+ } else if (isRemote && absoluteUri.indexOf(rule) === 0) {
+ allowed = true;
+ } else if (!isRemote && absoluteUri.indexOf(path.resolve(rule)) === 0) {
+ allowed = true;
+ } else if (isRemote != isRemoteRule(normalizedRule)) {
+ allowed = allowed && true;
+ } else {
+ allowed = false;
+ }
+ }
+
+ return allowed;
+}
+
+function isRemoteRule(rule) {
+ return isRemoteResource(rule) || url.parse(HTTP_PROTOCOL + '//' + rule).host == rule;
+}
+
+module.exports = isAllowedResource;