Initial import with skill sheet working
This commit is contained in:
58
node_modules/less/lib/less-node/url-file-manager.js
generated
vendored
Normal file
58
node_modules/less/lib/less-node/url-file-manager.js
generated
vendored
Normal file
@ -0,0 +1,58 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
var tslib_1 = require("tslib");
|
||||
/* eslint-disable no-unused-vars */
|
||||
/**
|
||||
* @todo - remove top eslint rule when FileManagers have JSDoc type
|
||||
* and are TS-type-checked
|
||||
*/
|
||||
var isUrlRe = /^(?:https?:)?\/\//i;
|
||||
var url_1 = tslib_1.__importDefault(require("url"));
|
||||
var request;
|
||||
var abstract_file_manager_js_1 = tslib_1.__importDefault(require("../less/environment/abstract-file-manager.js"));
|
||||
var logger_1 = tslib_1.__importDefault(require("../less/logger"));
|
||||
var UrlFileManager = function () { };
|
||||
UrlFileManager.prototype = Object.assign(new abstract_file_manager_js_1.default(), {
|
||||
supports: function (filename, currentDirectory, options, environment) {
|
||||
return isUrlRe.test(filename) || isUrlRe.test(currentDirectory);
|
||||
},
|
||||
loadFile: function (filename, currentDirectory, options, environment) {
|
||||
return new Promise(function (fulfill, reject) {
|
||||
if (request === undefined) {
|
||||
try {
|
||||
request = require('needle');
|
||||
}
|
||||
catch (e) {
|
||||
request = null;
|
||||
}
|
||||
}
|
||||
if (!request) {
|
||||
reject({ type: 'File', message: 'optional dependency \'needle\' required to import over http(s)\n' });
|
||||
return;
|
||||
}
|
||||
var urlStr = isUrlRe.test(filename) ? filename : url_1.default.resolve(currentDirectory, filename);
|
||||
/** native-request currently has a bug */
|
||||
var hackUrlStr = urlStr.indexOf('?') === -1 ? urlStr + '?' : urlStr;
|
||||
request.get(hackUrlStr, { follow_max: 5 }, function (err, resp, body) {
|
||||
if (err || resp && resp.statusCode >= 400) {
|
||||
var message = resp && resp.statusCode === 404
|
||||
? "resource '".concat(urlStr, "' was not found\n")
|
||||
: "resource '".concat(urlStr, "' gave this Error:\n ").concat(err || resp.statusMessage || resp.statusCode, "\n");
|
||||
reject({ type: 'File', message: message });
|
||||
return;
|
||||
}
|
||||
if (resp.statusCode >= 300) {
|
||||
reject({ type: 'File', message: "resource '".concat(urlStr, "' caused too many redirects") });
|
||||
return;
|
||||
}
|
||||
body = body.toString('utf8');
|
||||
if (!body) {
|
||||
logger_1.default.warn("Warning: Empty body (HTTP ".concat(resp.statusCode, ") returned by \"").concat(urlStr, "\""));
|
||||
}
|
||||
fulfill({ contents: body || '', filename: urlStr });
|
||||
});
|
||||
});
|
||||
}
|
||||
});
|
||||
exports.default = UrlFileManager;
|
||||
//# sourceMappingURL=url-file-manager.js.map
|
Reference in New Issue
Block a user