Commit 911c9475 authored by Pedro Henrique de Assis's avatar Pedro Henrique de Assis
Browse files

Fixed bug where defaults does not work

parent ce2bc9d6
Loading
Loading
Loading
Loading
+49 −5
Original line number Diff line number Diff line
@@ -25,9 +25,10 @@ function rp(options) {
    return buildPromise(c);
}

function buildPromise (c) {
function buildPromise (c, requester) {
    var _requester = requester || request;
    return new Promise(function (resolve, reject) {
            request(c, function (error, response, body) {
            _requester(c, function (error, response, body) {
            if (error) {
                reject({
                    error: error,
@@ -71,7 +72,7 @@ var methodNameLookup = {
};

Object.keys(request).filter(function(key){
    return typeof(request[key]) === "function" && !wrapMethods.indexOf(key) +1;
    return typeof(request[key]) === "function" && !wrapMethods.indexOf(key) +1 && key !== 'defaults';
}).forEach(function(key){
    rp[key] = request[key].bind(request);
});
@@ -82,11 +83,54 @@ Object.keys(request).filter(function(key){
    rp[key] = defaultHttpMethod;
});

function defaultHttpMethod(){
rp.defaults =  function (options, requester) {
    var def = function (method) {
        var d = function (uri, opts, callback) {
            var params = request.initParams(uri, opts, callback)
            Object.keys(options).forEach(function (key) {
                if (key !== 'headers' && params.options[key] === undefined) {
                    params.options[key] = options[key]
                }
            })
            if (options.headers) {
                var headers = {}
                util._extend(headers, options.headers)
                util._extend(headers, params.options.headers)
                params.options.headers = headers
            }
            if(typeof requester === 'function') {
                if(method === request) {
                    method = requester
                } else {
                    params.options._requester = requester
                }
            }
            return buildPromise(params.options, method);
        }
        return d
    }
    var de = def(request)
    de.get = def(request.get)
    de.patch = def(request.patch)
    de.post = def(request.post)
    de.put = def(request.put)
    de.head = def(request.head)
    de.del = def(request.del)
    de.cookie = def(request.cookie)
    de.jar = request.jar
    return de
}

function getParams(){
    var args = Array.prototype.slice.call(arguments, 0);
    var params = request.initParams.apply(request, args);
    params.method = methodNameLookup[key];
    return buildPromise(params);
    return params;
}

function defaultHttpMethod(){

    return buildPromise(getParams.apply(null, arguments));
}

module.exports = rp;