request-monitor
Version:
437 lines (395 loc) • 40.1 kB
JavaScript
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory();
else if(typeof define === 'function' && define.amd)
define([], factory);
else if(typeof exports === 'object')
exports["requestMonitor"] = factory();
else
root["requestMonitor"] = factory();
})(window, function() {
return /******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = "./src/index.js");
/******/ })
/************************************************************************/
/******/ ({
/***/ "./src/index.js":
/*!**********************!*\
!*** ./src/index.js ***!
\**********************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
;
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
/**
*
* @param {*} listener
*
http Info: {
__type: "fetch", // 使用底层库类型,有 fetch 和 xhr
url: "",
method: "",
timeout: 0, // 超时时间
params: {}, // 请求参数
responseStatus: 200, // 如果是 -1 ,代表网络异常
responseStatusText: "ok",
responseJson: {"code": 0},
responseText: "{"code": 0}",
requestTime: 100, 请求时间,单位为 ms
}
*/
var listeners = {};
var id = 1;
function getId() {
return id++;
}
function handleEndTime(info) {
var endTime = new Date().getTime();
info.requestTime = endTime - info.startTime;
info.endTime = endTime;
}
function handleDefaultApi(emit) {
if (window._requestMonitorIsLoad) return null;
window._requestMonitorIsLoad = true;
handleXhr(emit);
handleFetch(emit);
return true;
}
function handleHeader(xhr) {
try {
var headers = xhr.getAllResponseHeaders();
if (!headers) return;
if ((typeof headers === 'undefined' ? 'undefined' : _typeof(headers)) === 'object') {
return headers;
}
var newHeaders = {},
headers = headers.split(/[\r\n]/).forEach(function (header) {
var index = header.indexOf(":");
var name = header.substr(0, index);
var value = header.substr(index + 2);
if (name) {
newHeaders[name] = value;
}
});
return newHeaders;
} catch (e) {
return {};
}
}
function handleXhr(emit) {
var _open = XMLHttpRequest.prototype.open;
var _send = XMLHttpRequest.prototype.send;
XMLHttpRequest.prototype.open = function () {
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
var method = args[0];
var url = args[1];
this._monitor = {
__type: 'xhr'
};
_open.apply(this, args);
Object.assign(this._monitor, {
method: method,
url: url
});
};
XMLHttpRequest.prototype.send = function () {
var _this = this;
for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
args[_key2] = arguments[_key2];
}
_send.apply(this, args);
this._monitor.startTime = new Date().getTime();
this._monitor.timeout = this.timeout || 0;
try {
if (args.length > 0 && typeof args[0] === 'string') {
this._monitor.params = args[0];
}
} catch (err) {}
this.addEventListener('load', function () {
var contentType = this.getResponseHeader('Content-Type');
contentType = contentType || '';
contentType = contentType.toLowerCase();
var ignores = ['blob', 'arraybuffer', 'moz-chunked-arraybuffer', "ms-stream"];
if (this.responseType && ignores.indexOf(this.responseType) > -1) {
return; // ignore blob type
}
if (contentType.indexOf('application/json') !== -1) {
this._monitor.responseText = this.responseText;
try {
this._monitor.responseJson = JSON.parse(this.responseText);
} catch (e) {}
} else if (contentType.indexOf('text/plain') !== -1) {
this._monitor.responseText = this.responseText;
}
this._monitor.responseHeaders = handleHeader(this);
this._monitor.responseStatus = this.status;
this._monitor.responseStatusText = this.statusText;
emit(this._monitor);
}, false);
this.addEventListener('error', function () {
_this._monitor.responseStatusText = 'Xhr Network request exception';
_this._monitor.responseStatus = -1;
emit(_this._monitor);
});
this.addEventListener('timeout', function () {
emit(_this._monitor);
});
};
}
function getParams(options) {
var params = void 0;
try {
if (options.body && typeof options.body === 'string') {
params = options.body;
}
} catch (er) {}
return params;
}
function handleFetch(emit) {
if (window.fetch) {
var getHeaders = function getHeaders(response) {
try {
var headers = response.headers.entries();
var result = {};
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
try {
for (var _iterator = headers[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
var pair = _step.value;
result[pair[0]] = pair[1];
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator.return) {
_iterator.return();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
return result;
} catch (e) {
console.warn(e);
return {};
}
};
var monitorFetch = function monitorFetch(url) {
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
var params = getParams(options);
var _monitor = {
__type: 'fetch',
url: url,
method: options.method || 'GET',
params: params,
startTime: new Date().getTime(),
timeout: options.timeout || 0
};
var fetchRequest =
// _Promise
// .race ([
// new _Promise ((resolve, reject) => {
// setTimeout (() => {
// let err = new Error ('前端fetch Network request timeout: ' + options.timeout);
// err.status = 504;
// reject (err);
// }, timeout);
// }),
// ])
_fetch(url, options).then(function (response) {
var _text = response.text;
_monitor.responseStatus = response.status;
_monitor.responseHeaders = getHeaders(response);
_monitor.responseStatusText = response.statusText;
response.json = function () {
return new _Promise(function (resolve, reject) {
_text.call(response).then(function (text) {
try {
var json = JSON.parse(text);
_monitor.responseText = text;
_monitor.responseJson = json;
emit(_monitor);
resolve(json);
} catch (e) {
e.type = 'invalid-json';
_monitor.responseText = text;
emit(_monitor);
reject(e);
}
}).catch(function (err) {
reject(err);
});
});
};
response.text = function () {
return new _Promise(function (resolve, reject) {
_text.call(response).then(function (text) {
_monitor.responseText = text;
emit(_monitor);
resolve(text);
}).catch(function (err) {
reject(err);
});
});
};
return response;
});
return new _Promise(function (resolve, reject) {
fetchRequest.then(function (data) {
resolve(data);
}).catch(function (err) {
_monitor.responseStatus = err.status || -1;
_monitor.responseText = err.message || 'Fetch Network request exception';
emit(_monitor);
reject(err);
});
return fetchRequest;
});
};
var _Promise = window.fetch.Promise || Promise;
var _fetch = window.fetch;
monitorFetch.Promise = _Promise;
Object.defineProperty(monitorFetch, 'Promise', {
set: function set(value) {
// monitorFetch.Promise = value;
_fetch.Promise = value;
},
get: function get() {
return _fetch.Promise;
}
});
window.fetch = monitorFetch;
}
}
function emit(info) {
handleEndTime(info);
try {
Object.keys(info).forEach(function (key) {
if (typeof info[key] === 'undefined') {
delete info[key];
}
});
Object.keys(listeners).forEach(function (key) {
setTimeout(function () {
try {
listeners[key](info);
} catch (err) {
console.error(err);
}
});
});
} catch (e) {
console.error(e);
}
}
module.exports = requestMonitor;
function requestMonitor(listener) {
listener = listener || function (httpInfo) {
return httpInfo;
};
if (typeof listener !== 'function') {
throw new Error('The listener Type must be function');
}
var _id = getId();
listeners[_id] = listener;
handleDefaultApi(emit);
return {
cancel: function cancel() {
delete listeners[_id];
}
};
}
requestMonitor.handleDefaultApi = handleDefaultApi;
/***/ })
/******/ });
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://requestMonitor/webpack/universalModuleDefinition","webpack://requestMonitor/webpack/bootstrap","webpack://requestMonitor/./src/index.js"],"names":["listeners","id","getId","handleEndTime","info","endTime","Date","getTime","requestTime","startTime","handleDefaultApi","emit","window","_requestMonitorIsLoad","handleXhr","handleFetch","handleHeader","xhr","headers","getAllResponseHeaders","newHeaders","split","forEach","header","index","indexOf","name","substr","value","e","_open","XMLHttpRequest","prototype","open","_send","send","args","method","url","_monitor","__type","apply","Object","assign","timeout","length","params","err","addEventListener","contentType","getResponseHeader","toLowerCase","ignores","responseType","responseText","responseJson","JSON","parse","responseHeaders","responseStatus","status","responseStatusText","statusText","getParams","options","body","er","fetch","getHeaders","response","entries","result","pair","console","warn","monitorFetch","fetchRequest","_fetch","then","_text","text","json","_Promise","resolve","reject","call","type","catch","data","message","Promise","defineProperty","set","get","keys","key","setTimeout","error","module","exports","requestMonitor","listener","httpInfo","Error","_id","cancel"],"mappings":"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","file":"request-monitor.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"requestMonitor\"] = factory();\n\telse\n\t\troot[\"requestMonitor\"] = factory();\n})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/index.js\");\n","/**\n * \n * @param {*} listener \n * \nhttp Info: {\n   __type: \"fetch\",  // 使用底层库类型，有 fetch 和 xhr\n   url: \"\",\n   method: \"\",\n   timeout: 0, // 超时时间\n   params: {}, // 请求参数\n   responseStatus: 200,  // 如果是 -1 ，代表网络异常\n   responseStatusText: \"ok\",\n   responseJson: {\"code\": 0},\n   responseText: \"{\"code\": 0}\",\n   requestTime: 100,  请求时间，单位为 ms\n}\n */\n\nconst listeners = {};\nlet id = 1;\n\nfunction getId () {\n  return id++;\n}\n\nfunction handleEndTime(info){\n  let endTime = new Date ().getTime ();\n  info.requestTime = endTime - info.startTime;\n  info.endTime = endTime;\n}\n\n\nfunction handleDefaultApi (emit) {\n  if (window._requestMonitorIsLoad) return null;\n  window._requestMonitorIsLoad = true;\n  handleXhr (emit);\n  handleFetch (emit);\n  return true;\n}\n\nfunction handleHeader(xhr) {\n  try{\n    var headers = xhr.getAllResponseHeaders();\n    if (!headers) return;\n    if (typeof headers === 'object') {\n        return headers;\n    }\n    var newHeaders = {}, headers = headers.split(/[\\r\\n]/).forEach(function (header) {\n        var index = header.indexOf(\":\");\n        var name = header.substr(0, index);\n        var value = header.substr(index + 2);\n        if (name) {\n            newHeaders[name] = value;\n        }\n\n    })\n    return newHeaders;\n  }catch(e){\n    return {}\n  }\n}\n\nfunction handleXhr (emit) {\n  let _open = XMLHttpRequest.prototype.open;\n  let _send = XMLHttpRequest.prototype.send;\n  XMLHttpRequest.prototype.open = function (...args) {\n    const method = args[0];\n    const url = args[1];\n    this._monitor = {\n      __type: 'xhr',\n    };\n    _open.apply (this, args);\n    Object.assign (this._monitor, {\n      method,\n      url,\n    });\n  };\n\n  XMLHttpRequest.prototype.send = function (...args) {\n    _send.apply (this, args);\n    this._monitor.startTime = new Date ().getTime ();\n    this._monitor.timeout = this.timeout || 0;\n    try {\n      if (args.length > 0 && typeof args[0] === 'string') {\n        this._monitor.params = args[0];\n      }\n    } catch (err) {}\n    this.addEventListener (\n      'load',\n      function () {\n        let contentType = this.getResponseHeader (\n          'Content-Type'\n        );\n        contentType = contentType || '';\n        contentType = contentType.toLowerCase ();\n        const ignores = ['blob', 'arraybuffer', 'moz-chunked-arraybuffer', \"ms-stream\"];\n        if(this.responseType && ignores.indexOf(this.responseType) > -1){\n          return; // ignore blob type\n        }\n        if (contentType.indexOf ('application/json') !== -1) {\n          this._monitor.responseText = this.responseText;\n          try{\n            this._monitor.responseJson = JSON.parse (this.responseText);\n          }catch(e){}\n          \n        } else if (contentType.indexOf ('text/plain') !== -1) {\n          this._monitor.responseText = this.responseText;\n        }\n        this._monitor.responseHeaders = handleHeader(this);\n        this._monitor.responseStatus = this.status;\n        this._monitor.responseStatusText = this.statusText;\n        emit (this._monitor);\n      },\n      false\n    );\n    this.addEventListener ('error', () => {\n      this._monitor.responseStatusText = 'Xhr Network request exception';\n      this._monitor.responseStatus = -1;\n      emit (this._monitor);\n    });\n\n    this.addEventListener ('timeout', () => {\n      emit (this._monitor);\n    });\n\n  };\n}\n\nfunction getParams (options) {\n  let params;\n  try {\n    if (options.body && typeof options.body === 'string') {\n      params = options.body;\n    }\n  } catch (er) {}\n  return params;\n}\n\nfunction handleFetch (emit) {\n  if (window.fetch) {\n    const _Promise = window.fetch.Promise || Promise;\n    const _fetch = window.fetch;\n\n    function getHeaders(response){\n      try{\n        let headers = response.headers.entries();\n        let result = {};\n        for (var pair of headers) {\n          result[pair[0]] = pair[1];\n        }\n        return result;\n      }catch(e){\n        console.warn(e);\n        return {};\n      }\n    }\n\n    function monitorFetch (url, options = {}) {\n      const params = getParams (options);\n\n      const _monitor = {\n        __type: 'fetch',\n        url,\n        method: options.method || 'GET',\n        params,\n        startTime: new Date ().getTime (),\n        timeout: options.timeout || 0\n      };\n\n      const fetchRequest = \n        // _Promise\n        // .race ([\n          \n        //   new _Promise ((resolve, reject) => {\n        //     setTimeout (() => {\n        //       let err = new Error ('前端fetch Network request timeout: ' + options.timeout);\n        //       err.status = 504;\n        //       reject (err);\n        //     }, timeout);\n        //   }),\n        // ])\n        _fetch (url, options)\n        .then (response => {\n          let _text = response.text;\n          _monitor.responseStatus = response.status;\n          _monitor.responseHeaders = getHeaders(response)\n          _monitor.responseStatusText = response.statusText;\n          response.json = () => {\n            return new _Promise ((resolve, reject) => {\n              _text\n                .call (response)\n                .then (text => {\n                  try {\n                    let json = JSON.parse (text);\n                    _monitor.responseText = text;\n                    _monitor.responseJson = json;\n                    emit (_monitor);\n                    resolve (json);\n                  } catch (e) {\n                    e.type = 'invalid-json';\n                    _monitor.responseText = text;\n                    emit(_monitor);\n                    reject (e);\n                  }\n                })\n                .catch (err => {\n                  reject (err);\n                });\n            });\n          };\n\n          response.text = () => {\n            return new _Promise ((resolve, reject) => {\n              _text\n                .call (response)\n                .then (text => {\n                  _monitor.responseText = text;\n                  emit (_monitor);\n                  resolve (text);\n                })\n                .catch (err => {\n                  reject (err);\n                });\n            });\n          };\n\n          return response;\n        });\n\n      return new _Promise ((resolve, reject) => {\n        fetchRequest\n          .then (data => {\n            resolve (data);\n          })\n          .catch (err => {\n            _monitor.responseStatus = err.status || -1;\n            _monitor.responseText = err.message || 'Fetch Network request exception';\n            emit (_monitor);\n            reject (err);\n          });\n        return fetchRequest;\n      });\n    }\n\n    monitorFetch.Promise = _Promise;\n\n    Object.defineProperty (monitorFetch, 'Promise', {\n      set (value) {\n        // monitorFetch.Promise = value;\n        _fetch.Promise = value;\n      },\n      get () {\n        return _fetch.Promise;\n      },\n    });\n\n    window.fetch = monitorFetch;\n  }\n}\n\nfunction emit (info) {\n  handleEndTime(info)\n  try{\n    Object.keys (info).forEach (key => {\n      if (typeof info[key] === 'undefined') {\n        delete info[key];\n      }\n    });\n    Object.keys (listeners).forEach (key => {\n      setTimeout(()=> {\n        try{\n          listeners[key] (info)\n        }catch(err){\n          console.error(err)\n        }\n      })\n    });\n  }catch(e){\n    console.error(e)\n  }\n}\n\nmodule.exports = requestMonitor;\n\nfunction requestMonitor (listener) {\n  listener = listener || (httpInfo => httpInfo);\n\n  if (typeof listener !== 'function') {\n    throw new Error (`The listener Type must be function`);\n  }\n\n  let _id = getId ();\n  listeners[_id] = listener;\n  handleDefaultApi (emit);\n\n  return {\n    cancel: () => {\n      delete listeners[_id];\n    },\n  };\n}\n\nrequestMonitor.handleDefaultApi = handleDefaultApi;\n"],"sourceRoot":""}