@qelos/assets
Version:
manage assets like images and static files on remote servers
163 lines (146 loc) • 4.7 kB
JavaScript
;
// eslint-disable-next-line import/order
var config = require("../config");
var https = /^http:/.test(config().upload_prefix) ? require('http') : require('https');
var querystring = require("querystring");
var Q = require('q');
var url = require('url');
var utils = require("../utils");
var ensureOption = require('../utils/ensureOption').defaults(config());
var ProxyAgent = utils.optionalRequire('proxy-agent');
var extend = utils.extend,
includes = utils.includes,
isEmpty = utils.isEmpty;
function execute_request(method, params, auth, api_url, callback) {
var options = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : {};
method = method.toUpperCase();
var deferred = Q.defer();
var query_params = void 0,
handle_response = void 0; // declare to user later
var key = auth.key;
var secret = auth.secret;
var oauth_token = auth.oauth_token;
var content_type = 'application/x-www-form-urlencoded';
if (options.content_type === 'json') {
query_params = JSON.stringify(params);
content_type = 'application/json';
} else {
query_params = querystring.stringify(params);
}
if (method === "GET") {
api_url += "?" + query_params;
}
var request_options = url.parse(api_url);
request_options = extend(request_options, {
method: method,
headers: {
'Content-Type': content_type,
'User-Agent': utils.getUserAgent()
}
});
if (oauth_token) {
request_options.headers.Authorization = `Bearer ${oauth_token}`;
} else {
request_options.auth = key + ":" + secret;
}
if (options.agent != null) {
request_options.agent = options.agent;
}
var proxy = options.api_proxy || config().api_proxy;
if (!isEmpty(proxy)) {
if (!request_options.agent) {
if (ProxyAgent === null) {
throw new Error("Proxy value is set, but `proxy-agent` is not installed, please install `proxy-agent` module.");
}
request_options.agent = new ProxyAgent(proxy);
} else {
console.warn("Proxy is set, but request uses a custom agent, proxy is ignored.");
}
}
if (method !== "GET") {
request_options.headers['Content-Length'] = Buffer.byteLength(query_params);
}
handle_response = function handle_response(res) {
if (includes([200, 400, 401, 403, 404, 409, 420, 500], res.statusCode)) {
var buffer = "";
var error = false;
res.on("data", function (d) {
buffer += d;
return buffer;
});
res.on("end", function () {
var result = void 0;
if (error) {
return;
}
try {
result = JSON.parse(buffer);
} catch (e) {
result = {
error: {
message: "Server return invalid JSON response. Status Code " + res.statusCode
}
};
}
if (result.error) {
result.error.http_code = res.statusCode;
} else {
result.rate_limit_allowed = parseInt(res.headers["x-featureratelimit-limit"]);
result.rate_limit_reset_at = new Date(res.headers["x-featureratelimit-reset"]);
result.rate_limit_remaining = parseInt(res.headers["x-featureratelimit-remaining"]);
}
if (result.error) {
deferred.reject(Object.assign({
request_options,
query_params
}, result));
} else {
deferred.resolve(result);
}
if (typeof callback === "function") {
callback(result);
}
});
res.on("error", function (e) {
error = true;
var err_obj = {
error: {
message: e,
http_code: res.statusCode,
request_options,
query_params
}
};
deferred.reject(err_obj.error);
if (typeof callback === "function") {
callback(err_obj);
}
});
} else {
var err_obj = {
error: {
message: "Server returned unexpected status code - " + res.statusCode,
http_code: res.statusCode,
request_options,
query_params
}
};
deferred.reject(err_obj.error);
if (typeof callback === "function") {
callback(err_obj);
}
}
};
var request = https.request(request_options, handle_response);
request.on("error", function (e) {
deferred.reject(e);
return typeof callback === "function" ? callback({ error: e }) : void 0;
});
request.setTimeout(ensureOption(options, "timeout", 60000));
if (method !== "GET") {
request.write(query_params);
}
request.end();
return deferred.promise;
}
module.exports = execute_request;