rip-hunter
Version:
JS utilities for AJAX and GraphQL
281 lines (243 loc) • 26.9 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.Hunter = void 0;
var Immutable = _interopRequireWildcard(require("immutable"));
var _isArray = _interopRequireDefault(require("lodash/isArray"));
var _isNull = _interopRequireDefault(require("lodash/isNull"));
var _isPlainObject = _interopRequireDefault(require("lodash/isPlainObject"));
var _isString = _interopRequireDefault(require("lodash/isString"));
var _isUndefined = _interopRequireDefault(require("lodash/isUndefined"));
var _omit = _interopRequireDefault(require("lodash/omit"));
var _ApiError = require("./errors/ApiError");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
if (typeof window === 'undefined') {
// require('es6-promise/auto');
require('fetch-everywhere');
}
/**
* Copyright (c) 2017-Present, Nitrogen Labs, Inc.
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
*/
/**
* Hunter: JS utilities for GraphQL
*/
var Hunter =
/*#__PURE__*/
function () {
function Hunter() {
_classCallCheck(this, Hunter);
}
_createClass(Hunter, null, [{
key: "get",
// AJAX
value: function get(url, params, options) {
return Hunter.ajax(url, 'GET', params, options);
}
}, {
key: "post",
value: function post(url, params, options) {
return Hunter.ajax(url, 'POST', params, options);
}
}, {
key: "put",
value: function put(url, params, options) {
return Hunter.ajax(url, 'PUT', params, options);
}
}, {
key: "del",
value: function del(url, params, options) {
return Hunter.ajax(url, 'DELETE', params, options);
}
}, {
key: "ajax",
value: function ajax(url, method, params) {
var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
var headers = options.headers,
token = options.token;
var isImmutable = options.isImmutable;
url = (url || '').trim();
var formatToken = (token || '').trim();
var formatHeaders = headers || new Headers(); // Method
method = (method || 'GET').toUpperCase(); // Parameters
if (params && method === 'GET') {
url = "".concat(url, "?").concat(Hunter.queryString(params));
params = null;
} else if (params) {
params = JSON.stringify(params);
} // Authentication token
if (formatToken !== '') {
formatHeaders.set('Authorization', "Bearer ".concat(formatToken));
}
var isJSON;
return fetch(url, {
body: params,
headers: formatHeaders,
method: method
}).then(function (response) {
var regex = /application\/json/i; // Check if response is json
isJSON = regex.test(response.headers.get('Content-Type') || '');
if (isJSON) {
return response.json();
} else {
return response.text();
}
}).then(function (results) {
if (isJSON) {
return isImmutable ? Immutable.fromJS(results) : results;
} else {
return results;
}
}).catch(function (error) {
if ((error || {}).message === 'only absolute urls are supported') {
error = new _ApiError.ApiError([{
message: 'invalid_url'
}], error);
}
throw new _ApiError.ApiError([{
message: 'network_error'
}], error);
});
}
}, {
key: "queryString",
value: function queryString(json) {
return Object.keys(json).map(function (key) {
return "".concat(encodeURIComponent(key), "=").concat(encodeURIComponent(json[key]));
}).join('&');
} // GraphQL
}, {
key: "toGQL",
value: function toGQL(obj) {
if (Immutable.Iterable.isIterable(obj)) {
return Hunter.toGQL(obj.toJS());
} else if ((0, _isString.default)(obj)) {
return JSON.stringify(obj);
} else if ((0, _isPlainObject.default)(obj)) {
var cleanObj = (0, _omit.default)(obj, _isUndefined.default);
cleanObj = (0, _omit.default)(cleanObj, _isNull.default);
var props = [];
Object.keys(cleanObj).map(function (key) {
var item = obj[key];
if ((0, _isPlainObject.default)(item)) {
props.push(Hunter.toGQL(item));
} else if ((0, _isArray.default)(item)) {
var list = item.map(function (o) {
return Hunter.toGQL(o);
});
props.push("".concat(key, ": [").concat(list.join(', '), "]"));
} else {
var val = JSON.stringify(item);
if (val) {
props.push("".concat(key, ": ").concat(val));
}
}
});
var values = props.join(', ');
if (values === '') {
return '""';
} else {
return "{".concat(props.join(', '), "}");
}
} else if ((0, _isArray.default)(obj)) {
return "[".concat(obj.map(function (o) {
return Hunter.toGQL(o);
}).toString(), "]");
} else {
return obj;
}
}
}, {
key: "query",
value: function query(url, body, options) {
body = "query ".concat(body);
return Hunter.getGraph(url, body, options);
}
}, {
key: "mutation",
value: function mutation(url, body, options) {
body = "mutation ".concat(body);
return Hunter.getGraph(url, body, options);
}
}, {
key: "getGraph",
value: function getGraph(url, body) {
var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var isImmutable = options.isImmutable;
var headers = options.headers,
token = options.token;
url = url ? url.trim() : '';
var formatToken = (token || '').trim();
var formatHeaders = headers || new Headers({
'Content-Type': 'application/graphql'
});
if (formatToken !== '') {
formatHeaders.set('Authorization', "Bearer ".concat(formatToken));
}
return fetch(url, {
body: body,
headers: formatHeaders,
method: 'post'
}).then(function (response) {
var regex = /application\/json/i;
var isJSON = regex.test(response.headers.get('Content-Type') || '');
if (isJSON) {
return response.json();
} else {
return {
data: {}
};
}
}).catch(function (error) {
if ((error || {}).message === 'only absolute urls are supported') {
return Promise.reject(new _ApiError.ApiError([{
message: 'invalid_url'
}], error));
}
return Promise.reject(new _ApiError.ApiError([{
message: 'network_error'
}], error));
}).then(function (json) {
if (!json || json.errors) {
if (!json) {
json = {
errors: [{
message: 'api_error'
}]
};
} else if ((json.errors || []).some(function (o) {
return o.message === 'Must provide query string.';
})) {
return Promise.reject(new _ApiError.ApiError([{
message: 'required_query'
}], new Error()));
}
return Promise.reject(new _ApiError.ApiError(json.errors, new Error()));
} else {
var results = json.data || {};
return isImmutable ? Immutable.fromJS(results) : results;
}
}).catch(function (error) {
if (!error.source) {
error = new _ApiError.ApiError([{
message: 'network_error'
}], error);
}
return Promise.reject(error);
});
}
}, {
key: "removeSpaces",
value: function removeSpaces(str) {
return str.replace(/\s+(?=(?:[^'"]*['"][^'"]*['"])*[^'"]*$)/gm, '');
}
}]);
return Hunter;
}();
exports.Hunter = Hunter;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Hunter.ts"],"names":["window","require","Hunter","url","params","options","ajax","method","headers","token","isImmutable","trim","formatToken","formatHeaders","Headers","toUpperCase","queryString","JSON","stringify","set","isJSON","fetch","body","then","response","regex","test","get","json","text","results","Immutable","fromJS","catch","error","message","ApiError","Object","keys","map","key","encodeURIComponent","join","obj","Iterable","isIterable","toGQL","toJS","cleanObj","isUndefined","isNull","props","item","push","list","o","val","values","toString","getGraph","data","Promise","reject","errors","some","Error","source","str","replace"],"mappings":"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","sourcesContent":["import * as Immutable from 'immutable';\nimport isArray from 'lodash/isArray';\nimport isNull from 'lodash/isNull';\nimport isPlainObject from 'lodash/isPlainObject';\nimport isString from 'lodash/isString';\nimport isUndefined from 'lodash/isUndefined';\nimport omit from 'lodash/omit';\n\nimport {ApiError} from './errors/ApiError';\n\nif(typeof window === 'undefined') {\n  // require('es6-promise/auto');\n  require('fetch-everywhere');\n}\n\n/**\n * Copyright (c) 2017-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\n\nexport interface HunterOptionsType {\n  readonly headers?: Headers;\n  readonly isImmutable?: boolean;\n  readonly token?: string;\n}\n\n/**\n * Hunter: JS utilities for GraphQL\n */\nexport class Hunter {\n  // AJAX\n  static get(url: string, params?, options?: HunterOptionsType): Promise<any> {\n    return Hunter.ajax(url, 'GET', params, options);\n  }\n\n  static post(url: string, params?, options?: HunterOptionsType): Promise<any> {\n    return Hunter.ajax(url, 'POST', params, options);\n  }\n\n  static put(url: string, params?, options?: HunterOptionsType): Promise<any> {\n    return Hunter.ajax(url, 'PUT', params, options);\n  }\n\n  static del(url: string, params?, options?: HunterOptionsType): Promise<any> {\n    return Hunter.ajax(url, 'DELETE', params, options);\n  }\n\n  static ajax(url: string, method: string, params?, options: HunterOptionsType = {}): Promise<any> {\n    const {headers, token} = options;\n    const {isImmutable} = options;\n\n    url = (url || '').trim();\n    const formatToken: string = (token || '').trim();\n    const formatHeaders: Headers = headers || new Headers();\n\n    // Method\n    method = (method || 'GET').toUpperCase();\n\n    // Parameters\n    if(params && method === 'GET') {\n      url = `${url}?${Hunter.queryString(params)}`;\n      params = null;\n    } else if(params) {\n      params = JSON.stringify(params);\n    }\n\n    // Authentication token\n    if(formatToken !== '') {\n      formatHeaders.set('Authorization', `Bearer ${formatToken}`);\n    }\n\n    let isJSON: boolean;\n\n    return fetch(url, {body: params, headers: formatHeaders, method})\n      .then((response: Response) => {\n        const regex = /application\\/json/i;\n\n        // Check if response is json\n        isJSON = regex.test(response.headers.get('Content-Type') || '');\n\n        if(isJSON) {\n          return response.json();\n        } else {\n          return response.text();\n        }\n      })\n      .then((results) => {\n        if(isJSON) {\n          return isImmutable ? Immutable.fromJS(results) : results;\n        } else {\n          return results;\n        }\n      })\n      .catch((error) => {\n        if((error || {}).message === 'only absolute urls are supported') {\n          error = new ApiError([{message: 'invalid_url'}], error);\n        }\n\n        throw new ApiError([{message: 'network_error'}], error);\n      });\n  }\n\n  static queryString(json: object): string {\n    return Object\n      .keys(json)\n      .map((key: string) => `${encodeURIComponent(key)}=${encodeURIComponent(json[key])}`).join('&');\n  }\n\n  // GraphQL\n  static toGQL(obj): string {\n    if(Immutable.Iterable.isIterable(obj)) {\n      return Hunter.toGQL(obj.toJS());\n    } else if(isString(obj)) {\n      return JSON.stringify(obj);\n    } else if(isPlainObject(obj)) {\n      let cleanObj = omit(obj, isUndefined);\n      cleanObj = omit(cleanObj, isNull);\n      const props = [];\n\n      Object.keys(cleanObj).map((key: string) => {\n        const item = obj[key];\n\n        if(isPlainObject(item)) {\n          props.push(Hunter.toGQL(item));\n        } else if(isArray(item)) {\n          const list = item.map((o) => Hunter.toGQL(o));\n          props.push(`${key}: [${list.join(', ')}]`);\n        } else {\n          const val = JSON.stringify(item);\n\n          if(val) {\n            props.push(`${key}: ${val}`);\n          }\n        }\n      });\n\n      const values = props.join(', ');\n\n      if(values === '') {\n        return '\"\"';\n      } else {\n        return `{${props.join(', ')}}`;\n      }\n    } else if(isArray(obj)) {\n      return `[${obj.map((o) => Hunter.toGQL(o)).toString()}]`;\n    } else {\n      return obj;\n    }\n  }\n\n  static query(url: string, body?, options?: HunterOptionsType): Promise<any> {\n    body = `query ${body}`;\n    return Hunter.getGraph(url, body, options);\n  }\n\n  static mutation(url: string, body?, options?: HunterOptionsType): Promise<any> {\n    body = `mutation ${body}`;\n    return Hunter.getGraph(url, body, options);\n  }\n\n  static getGraph(url: string, body?, options: HunterOptionsType = {}): Promise<any> {\n    const {isImmutable} = options;\n    const {headers, token} = options;\n    url = url ? url.trim() : '';\n    const formatToken: string = (token || '').trim();\n    const formatHeaders: Headers = headers || new Headers({'Content-Type': 'application/graphql'});\n\n    if(formatToken !== '') {\n      formatHeaders.set('Authorization', `Bearer ${formatToken}`);\n    }\n\n    return fetch(url, {body, headers: formatHeaders, method: 'post'})\n      .then((response: Response) => {\n        const regex: RegExp = /application\\/json/i;\n        const isJSON: boolean = regex.test(response.headers.get('Content-Type') || '');\n\n        if(isJSON) {\n          return response.json();\n        } else {\n          return {data: {}};\n        }\n      })\n      .catch((error) => {\n        if((error || {}).message === 'only absolute urls are supported') {\n          return Promise.reject(new ApiError([{message: 'invalid_url'}], error));\n        }\n\n        return Promise.reject(new ApiError([{message: 'network_error'}], error));\n      })\n      .then((json) => {\n        if(!json || json.errors) {\n          if(!json) {\n            json = {errors: [{message: 'api_error'}]};\n          } else if((json.errors || []).some((o) => o.message === 'Must provide query string.')) {\n            return Promise.reject(new ApiError([{message: 'required_query'}], new Error()));\n          }\n\n          return Promise.reject(new ApiError(json.errors, new Error()));\n        } else {\n          const results = json.data || {};\n          return isImmutable ? Immutable.fromJS(results) : results;\n        }\n      })\n      .catch((error: ApiError) => {\n        if(!error.source) {\n          error = new ApiError([{message: 'network_error'}], error);\n        }\n\n        return Promise.reject(error);\n      });\n  }\n\n  static removeSpaces(str: string): string {\n    return str.replace(/\\s+(?=(?:[^'\"]*['\"][^'\"]*['\"])*[^'\"]*$)/gm, '');\n  }\n}\n"]}