|
|
@@ -0,0 +1,3579 @@
|
|
|
+/* axios v0.16.1 | (c) 2017 by Matt Zabriskie */
|
|
|
+(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["axios"] = factory();
|
|
|
+ else
|
|
|
+ root["axios"] = factory();
|
|
|
+})(this, 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] = {
|
|
|
+/******/ exports: {},
|
|
|
+/******/ id: moduleId,
|
|
|
+/******/ loaded: false
|
|
|
+/******/ };
|
|
|
+/******/
|
|
|
+/******/ // Execute the module function
|
|
|
+/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
|
|
+/******/
|
|
|
+/******/ // Flag the module as loaded
|
|
|
+/******/ module.loaded = 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;
|
|
|
+/******/
|
|
|
+/******/ // __webpack_public_path__
|
|
|
+/******/ __webpack_require__.p = "";
|
|
|
+/******/
|
|
|
+/******/ // Load entry module and return exports
|
|
|
+/******/ return __webpack_require__(0);
|
|
|
+/******/ })
|
|
|
+/************************************************************************/
|
|
|
+/******/ ([
|
|
|
+/* 0 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ module.exports = __webpack_require__(1);
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 1 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+ var bind = __webpack_require__(7);
|
|
|
+ var Axios = __webpack_require__(8);
|
|
|
+ var defaults = __webpack_require__(9);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Create an instance of Axios
|
|
|
+ *
|
|
|
+ * @param {Object} defaultConfig The default config for the instance
|
|
|
+ * @return {Axios} A new instance of Axios
|
|
|
+ */
|
|
|
+ function createInstance(defaultConfig) {
|
|
|
+ var context = new Axios(defaultConfig);
|
|
|
+ var instance = bind(Axios.prototype.request, context);
|
|
|
+
|
|
|
+ // Copy axios.prototype to instance
|
|
|
+ utils.extend(instance, Axios.prototype, context);
|
|
|
+
|
|
|
+ // Copy context to instance
|
|
|
+ utils.extend(instance, context);
|
|
|
+
|
|
|
+ return instance;
|
|
|
+ }
|
|
|
+
|
|
|
+ // Create the default instance to be exported
|
|
|
+ var axios = createInstance(defaults);
|
|
|
+
|
|
|
+ // Expose Axios class to allow class inheritance
|
|
|
+ axios.Axios = Axios;
|
|
|
+
|
|
|
+ // Factory for creating new instances
|
|
|
+ axios.create = function create(instanceConfig) {
|
|
|
+ return createInstance(utils.merge(defaults, instanceConfig));
|
|
|
+ };
|
|
|
+
|
|
|
+ // Expose Cancel & CancelToken
|
|
|
+ axios.Cancel = __webpack_require__(26);
|
|
|
+ axios.CancelToken = __webpack_require__(27);
|
|
|
+ axios.isCancel = __webpack_require__(23);
|
|
|
+
|
|
|
+ // Expose all/spread
|
|
|
+ axios.all = function all(promises) {
|
|
|
+ return Promise.all(promises);
|
|
|
+ };
|
|
|
+ axios.spread = __webpack_require__(28);
|
|
|
+
|
|
|
+ module.exports = axios;
|
|
|
+
|
|
|
+ // Allow use of default import syntax in TypeScript
|
|
|
+ module.exports.default = axios;
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 2 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ /* WEBPACK VAR INJECTION */(function(Buffer) {'use strict';
|
|
|
+
|
|
|
+ var bind = __webpack_require__(7);
|
|
|
+
|
|
|
+ /*global toString:true*/
|
|
|
+
|
|
|
+ // utils is a library of generic helper functions non-specific to axios
|
|
|
+
|
|
|
+ var toString = Object.prototype.toString;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is an Array
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is an Array, otherwise false
|
|
|
+ */
|
|
|
+ function isArray(val) {
|
|
|
+ return toString.call(val) === '[object Array]';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a Node Buffer
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a Node Buffer, otherwise false
|
|
|
+ */
|
|
|
+ function isBuffer(val) {
|
|
|
+ return ((typeof Buffer !== 'undefined') && (Buffer.isBuffer) && (Buffer.isBuffer(val)));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is an ArrayBuffer
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is an ArrayBuffer, otherwise false
|
|
|
+ */
|
|
|
+ function isArrayBuffer(val) {
|
|
|
+ return toString.call(val) === '[object ArrayBuffer]';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a FormData
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is an FormData, otherwise false
|
|
|
+ */
|
|
|
+ function isFormData(val) {
|
|
|
+ return (typeof FormData !== 'undefined') && (val instanceof FormData);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a view on an ArrayBuffer
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false
|
|
|
+ */
|
|
|
+ function isArrayBufferView(val) {
|
|
|
+ var result;
|
|
|
+ if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {
|
|
|
+ result = ArrayBuffer.isView(val);
|
|
|
+ } else {
|
|
|
+ result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);
|
|
|
+ }
|
|
|
+ return result;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a String
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a String, otherwise false
|
|
|
+ */
|
|
|
+ function isString(val) {
|
|
|
+ return typeof val === 'string';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a Number
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a Number, otherwise false
|
|
|
+ */
|
|
|
+ function isNumber(val) {
|
|
|
+ return typeof val === 'number';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is undefined
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if the value is undefined, otherwise false
|
|
|
+ */
|
|
|
+ function isUndefined(val) {
|
|
|
+ return typeof val === 'undefined';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is an Object
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is an Object, otherwise false
|
|
|
+ */
|
|
|
+ function isObject(val) {
|
|
|
+ return val !== null && typeof val === 'object';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a Date
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a Date, otherwise false
|
|
|
+ */
|
|
|
+ function isDate(val) {
|
|
|
+ return toString.call(val) === '[object Date]';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a File
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a File, otherwise false
|
|
|
+ */
|
|
|
+ function isFile(val) {
|
|
|
+ return toString.call(val) === '[object File]';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a Blob
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a Blob, otherwise false
|
|
|
+ */
|
|
|
+ function isBlob(val) {
|
|
|
+ return toString.call(val) === '[object Blob]';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a Function
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a Function, otherwise false
|
|
|
+ */
|
|
|
+ function isFunction(val) {
|
|
|
+ return toString.call(val) === '[object Function]';
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a Stream
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a Stream, otherwise false
|
|
|
+ */
|
|
|
+ function isStream(val) {
|
|
|
+ return isObject(val) && isFunction(val.pipe);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a value is a URLSearchParams object
|
|
|
+ *
|
|
|
+ * @param {Object} val The value to test
|
|
|
+ * @returns {boolean} True if value is a URLSearchParams object, otherwise false
|
|
|
+ */
|
|
|
+ function isURLSearchParams(val) {
|
|
|
+ return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Trim excess whitespace off the beginning and end of a string
|
|
|
+ *
|
|
|
+ * @param {String} str The String to trim
|
|
|
+ * @returns {String} The String freed of excess whitespace
|
|
|
+ */
|
|
|
+ function trim(str) {
|
|
|
+ return str.replace(/^\s*/, '').replace(/\s*$/, '');
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if we're running in a standard browser environment
|
|
|
+ *
|
|
|
+ * This allows axios to run in a web worker, and react-native.
|
|
|
+ * Both environments support XMLHttpRequest, but not fully standard globals.
|
|
|
+ *
|
|
|
+ * web workers:
|
|
|
+ * typeof window -> undefined
|
|
|
+ * typeof document -> undefined
|
|
|
+ *
|
|
|
+ * react-native:
|
|
|
+ * navigator.product -> 'ReactNative'
|
|
|
+ */
|
|
|
+ function isStandardBrowserEnv() {
|
|
|
+ if (typeof navigator !== 'undefined' && navigator.product === 'ReactNative') {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ return (
|
|
|
+ typeof window !== 'undefined' &&
|
|
|
+ typeof document !== 'undefined'
|
|
|
+ );
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Iterate over an Array or an Object invoking a function for each item.
|
|
|
+ *
|
|
|
+ * If `obj` is an Array callback will be called passing
|
|
|
+ * the value, index, and complete array for each item.
|
|
|
+ *
|
|
|
+ * If 'obj' is an Object callback will be called passing
|
|
|
+ * the value, key, and complete object for each property.
|
|
|
+ *
|
|
|
+ * @param {Object|Array} obj The object to iterate
|
|
|
+ * @param {Function} fn The callback to invoke for each item
|
|
|
+ */
|
|
|
+ function forEach(obj, fn) {
|
|
|
+ // Don't bother if no value provided
|
|
|
+ if (obj === null || typeof obj === 'undefined') {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ // Force an array if not already something iterable
|
|
|
+ if (typeof obj !== 'object' && !isArray(obj)) {
|
|
|
+ /*eslint no-param-reassign:0*/
|
|
|
+ obj = [obj];
|
|
|
+ }
|
|
|
+
|
|
|
+ if (isArray(obj)) {
|
|
|
+ // Iterate over array values
|
|
|
+ for (var i = 0, l = obj.length; i < l; i++) {
|
|
|
+ fn.call(null, obj[i], i, obj);
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ // Iterate over object keys
|
|
|
+ for (var key in obj) {
|
|
|
+ if (Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
|
+ fn.call(null, obj[key], key, obj);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Accepts varargs expecting each argument to be an object, then
|
|
|
+ * immutably merges the properties of each object and returns result.
|
|
|
+ *
|
|
|
+ * When multiple objects contain the same key the later object in
|
|
|
+ * the arguments list will take precedence.
|
|
|
+ *
|
|
|
+ * Example:
|
|
|
+ *
|
|
|
+ * ```js
|
|
|
+ * var result = merge({foo: 123}, {foo: 456});
|
|
|
+ * console.log(result.foo); // outputs 456
|
|
|
+ * ```
|
|
|
+ *
|
|
|
+ * @param {Object} obj1 Object to merge
|
|
|
+ * @returns {Object} Result of all merge properties
|
|
|
+ */
|
|
|
+ function merge(/* obj1, obj2, obj3, ... */) {
|
|
|
+ var result = {};
|
|
|
+ function assignValue(val, key) {
|
|
|
+ if (typeof result[key] === 'object' && typeof val === 'object') {
|
|
|
+ result[key] = merge(result[key], val);
|
|
|
+ } else {
|
|
|
+ result[key] = val;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ for (var i = 0, l = arguments.length; i < l; i++) {
|
|
|
+ forEach(arguments[i], assignValue);
|
|
|
+ }
|
|
|
+ return result;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Extends object a by mutably adding to it the properties of object b.
|
|
|
+ *
|
|
|
+ * @param {Object} a The object to be extended
|
|
|
+ * @param {Object} b The object to copy properties from
|
|
|
+ * @param {Object} thisArg The object to bind function to
|
|
|
+ * @return {Object} The resulting value of object a
|
|
|
+ */
|
|
|
+ function extend(a, b, thisArg) {
|
|
|
+ forEach(b, function assignValue(val, key) {
|
|
|
+ if (thisArg && typeof val === 'function') {
|
|
|
+ a[key] = bind(val, thisArg);
|
|
|
+ } else {
|
|
|
+ a[key] = val;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ return a;
|
|
|
+ }
|
|
|
+
|
|
|
+ module.exports = {
|
|
|
+ isArray: isArray,
|
|
|
+ isArrayBuffer: isArrayBuffer,
|
|
|
+ isBuffer: isBuffer,
|
|
|
+ isFormData: isFormData,
|
|
|
+ isArrayBufferView: isArrayBufferView,
|
|
|
+ isString: isString,
|
|
|
+ isNumber: isNumber,
|
|
|
+ isObject: isObject,
|
|
|
+ isUndefined: isUndefined,
|
|
|
+ isDate: isDate,
|
|
|
+ isFile: isFile,
|
|
|
+ isBlob: isBlob,
|
|
|
+ isFunction: isFunction,
|
|
|
+ isStream: isStream,
|
|
|
+ isURLSearchParams: isURLSearchParams,
|
|
|
+ isStandardBrowserEnv: isStandardBrowserEnv,
|
|
|
+ forEach: forEach,
|
|
|
+ merge: merge,
|
|
|
+ extend: extend,
|
|
|
+ trim: trim
|
|
|
+ };
|
|
|
+
|
|
|
+ /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3).Buffer))
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 3 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ /* WEBPACK VAR INJECTION */(function(global) {/*!
|
|
|
+ * The buffer module from node.js, for the browser.
|
|
|
+ *
|
|
|
+ * @author Feross Aboukhadijeh <feross@feross.org> <http://feross.org>
|
|
|
+ * @license MIT
|
|
|
+ */
|
|
|
+ /* eslint-disable no-proto */
|
|
|
+
|
|
|
+ 'use strict'
|
|
|
+
|
|
|
+ var base64 = __webpack_require__(4)
|
|
|
+ var ieee754 = __webpack_require__(5)
|
|
|
+ var isArray = __webpack_require__(6)
|
|
|
+
|
|
|
+ exports.Buffer = Buffer
|
|
|
+ exports.SlowBuffer = SlowBuffer
|
|
|
+ exports.INSPECT_MAX_BYTES = 50
|
|
|
+
|
|
|
+ /**
|
|
|
+ * If `Buffer.TYPED_ARRAY_SUPPORT`:
|
|
|
+ * === true Use Uint8Array implementation (fastest)
|
|
|
+ * === false Use Object implementation (most compatible, even IE6)
|
|
|
+ *
|
|
|
+ * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,
|
|
|
+ * Opera 11.6+, iOS 4.2+.
|
|
|
+ *
|
|
|
+ * Due to various browser bugs, sometimes the Object implementation will be used even
|
|
|
+ * when the browser supports typed arrays.
|
|
|
+ *
|
|
|
+ * Note:
|
|
|
+ *
|
|
|
+ * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,
|
|
|
+ * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.
|
|
|
+ *
|
|
|
+ * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.
|
|
|
+ *
|
|
|
+ * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of
|
|
|
+ * incorrect length in some situations.
|
|
|
+
|
|
|
+ * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they
|
|
|
+ * get the Object implementation, which is slower but behaves correctly.
|
|
|
+ */
|
|
|
+ Buffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined
|
|
|
+ ? global.TYPED_ARRAY_SUPPORT
|
|
|
+ : typedArraySupport()
|
|
|
+
|
|
|
+ /*
|
|
|
+ * Export kMaxLength after typed array support is determined.
|
|
|
+ */
|
|
|
+ exports.kMaxLength = kMaxLength()
|
|
|
+
|
|
|
+ function typedArraySupport () {
|
|
|
+ try {
|
|
|
+ var arr = new Uint8Array(1)
|
|
|
+ arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}
|
|
|
+ return arr.foo() === 42 && // typed array instances can be augmented
|
|
|
+ typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`
|
|
|
+ arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`
|
|
|
+ } catch (e) {
|
|
|
+ return false
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function kMaxLength () {
|
|
|
+ return Buffer.TYPED_ARRAY_SUPPORT
|
|
|
+ ? 0x7fffffff
|
|
|
+ : 0x3fffffff
|
|
|
+ }
|
|
|
+
|
|
|
+ function createBuffer (that, length) {
|
|
|
+ if (kMaxLength() < length) {
|
|
|
+ throw new RangeError('Invalid typed array length')
|
|
|
+ }
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ // Return an augmented `Uint8Array` instance, for best performance
|
|
|
+ that = new Uint8Array(length)
|
|
|
+ that.__proto__ = Buffer.prototype
|
|
|
+ } else {
|
|
|
+ // Fallback: Return an object instance of the Buffer class
|
|
|
+ if (that === null) {
|
|
|
+ that = new Buffer(length)
|
|
|
+ }
|
|
|
+ that.length = length
|
|
|
+ }
|
|
|
+
|
|
|
+ return that
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * The Buffer constructor returns instances of `Uint8Array` that have their
|
|
|
+ * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of
|
|
|
+ * `Uint8Array`, so the returned instances will have all the node `Buffer` methods
|
|
|
+ * and the `Uint8Array` methods. Square bracket notation works as expected -- it
|
|
|
+ * returns a single octet.
|
|
|
+ *
|
|
|
+ * The `Uint8Array` prototype remains unmodified.
|
|
|
+ */
|
|
|
+
|
|
|
+ function Buffer (arg, encodingOrOffset, length) {
|
|
|
+ if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {
|
|
|
+ return new Buffer(arg, encodingOrOffset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ // Common case.
|
|
|
+ if (typeof arg === 'number') {
|
|
|
+ if (typeof encodingOrOffset === 'string') {
|
|
|
+ throw new Error(
|
|
|
+ 'If encoding is specified then the first argument must be a string'
|
|
|
+ )
|
|
|
+ }
|
|
|
+ return allocUnsafe(this, arg)
|
|
|
+ }
|
|
|
+ return from(this, arg, encodingOrOffset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.poolSize = 8192 // not used by this implementation
|
|
|
+
|
|
|
+ // TODO: Legacy, not needed anymore. Remove in next major version.
|
|
|
+ Buffer._augment = function (arr) {
|
|
|
+ arr.__proto__ = Buffer.prototype
|
|
|
+ return arr
|
|
|
+ }
|
|
|
+
|
|
|
+ function from (that, value, encodingOrOffset, length) {
|
|
|
+ if (typeof value === 'number') {
|
|
|
+ throw new TypeError('"value" argument must not be a number')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {
|
|
|
+ return fromArrayBuffer(that, value, encodingOrOffset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ if (typeof value === 'string') {
|
|
|
+ return fromString(that, value, encodingOrOffset)
|
|
|
+ }
|
|
|
+
|
|
|
+ return fromObject(that, value)
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError
|
|
|
+ * if value is a number.
|
|
|
+ * Buffer.from(str[, encoding])
|
|
|
+ * Buffer.from(array)
|
|
|
+ * Buffer.from(buffer)
|
|
|
+ * Buffer.from(arrayBuffer[, byteOffset[, length]])
|
|
|
+ **/
|
|
|
+ Buffer.from = function (value, encodingOrOffset, length) {
|
|
|
+ return from(null, value, encodingOrOffset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ Buffer.prototype.__proto__ = Uint8Array.prototype
|
|
|
+ Buffer.__proto__ = Uint8Array
|
|
|
+ if (typeof Symbol !== 'undefined' && Symbol.species &&
|
|
|
+ Buffer[Symbol.species] === Buffer) {
|
|
|
+ // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97
|
|
|
+ Object.defineProperty(Buffer, Symbol.species, {
|
|
|
+ value: null,
|
|
|
+ configurable: true
|
|
|
+ })
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function assertSize (size) {
|
|
|
+ if (typeof size !== 'number') {
|
|
|
+ throw new TypeError('"size" argument must be a number')
|
|
|
+ } else if (size < 0) {
|
|
|
+ throw new RangeError('"size" argument must not be negative')
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function alloc (that, size, fill, encoding) {
|
|
|
+ assertSize(size)
|
|
|
+ if (size <= 0) {
|
|
|
+ return createBuffer(that, size)
|
|
|
+ }
|
|
|
+ if (fill !== undefined) {
|
|
|
+ // Only pay attention to encoding if it's a string. This
|
|
|
+ // prevents accidentally sending in a number that would
|
|
|
+ // be interpretted as a start offset.
|
|
|
+ return typeof encoding === 'string'
|
|
|
+ ? createBuffer(that, size).fill(fill, encoding)
|
|
|
+ : createBuffer(that, size).fill(fill)
|
|
|
+ }
|
|
|
+ return createBuffer(that, size)
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Creates a new filled Buffer instance.
|
|
|
+ * alloc(size[, fill[, encoding]])
|
|
|
+ **/
|
|
|
+ Buffer.alloc = function (size, fill, encoding) {
|
|
|
+ return alloc(null, size, fill, encoding)
|
|
|
+ }
|
|
|
+
|
|
|
+ function allocUnsafe (that, size) {
|
|
|
+ assertSize(size)
|
|
|
+ that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)
|
|
|
+ if (!Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ for (var i = 0; i < size; ++i) {
|
|
|
+ that[i] = 0
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return that
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.
|
|
|
+ * */
|
|
|
+ Buffer.allocUnsafe = function (size) {
|
|
|
+ return allocUnsafe(null, size)
|
|
|
+ }
|
|
|
+ /**
|
|
|
+ * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.
|
|
|
+ */
|
|
|
+ Buffer.allocUnsafeSlow = function (size) {
|
|
|
+ return allocUnsafe(null, size)
|
|
|
+ }
|
|
|
+
|
|
|
+ function fromString (that, string, encoding) {
|
|
|
+ if (typeof encoding !== 'string' || encoding === '') {
|
|
|
+ encoding = 'utf8'
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!Buffer.isEncoding(encoding)) {
|
|
|
+ throw new TypeError('"encoding" must be a valid string encoding')
|
|
|
+ }
|
|
|
+
|
|
|
+ var length = byteLength(string, encoding) | 0
|
|
|
+ that = createBuffer(that, length)
|
|
|
+
|
|
|
+ var actual = that.write(string, encoding)
|
|
|
+
|
|
|
+ if (actual !== length) {
|
|
|
+ // Writing a hex string, for example, that contains invalid characters will
|
|
|
+ // cause everything after the first invalid character to be ignored. (e.g.
|
|
|
+ // 'abxxcd' will be treated as 'ab')
|
|
|
+ that = that.slice(0, actual)
|
|
|
+ }
|
|
|
+
|
|
|
+ return that
|
|
|
+ }
|
|
|
+
|
|
|
+ function fromArrayLike (that, array) {
|
|
|
+ var length = array.length < 0 ? 0 : checked(array.length) | 0
|
|
|
+ that = createBuffer(that, length)
|
|
|
+ for (var i = 0; i < length; i += 1) {
|
|
|
+ that[i] = array[i] & 255
|
|
|
+ }
|
|
|
+ return that
|
|
|
+ }
|
|
|
+
|
|
|
+ function fromArrayBuffer (that, array, byteOffset, length) {
|
|
|
+ array.byteLength // this throws if `array` is not a valid ArrayBuffer
|
|
|
+
|
|
|
+ if (byteOffset < 0 || array.byteLength < byteOffset) {
|
|
|
+ throw new RangeError('\'offset\' is out of bounds')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (array.byteLength < byteOffset + (length || 0)) {
|
|
|
+ throw new RangeError('\'length\' is out of bounds')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (byteOffset === undefined && length === undefined) {
|
|
|
+ array = new Uint8Array(array)
|
|
|
+ } else if (length === undefined) {
|
|
|
+ array = new Uint8Array(array, byteOffset)
|
|
|
+ } else {
|
|
|
+ array = new Uint8Array(array, byteOffset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ // Return an augmented `Uint8Array` instance, for best performance
|
|
|
+ that = array
|
|
|
+ that.__proto__ = Buffer.prototype
|
|
|
+ } else {
|
|
|
+ // Fallback: Return an object instance of the Buffer class
|
|
|
+ that = fromArrayLike(that, array)
|
|
|
+ }
|
|
|
+ return that
|
|
|
+ }
|
|
|
+
|
|
|
+ function fromObject (that, obj) {
|
|
|
+ if (Buffer.isBuffer(obj)) {
|
|
|
+ var len = checked(obj.length) | 0
|
|
|
+ that = createBuffer(that, len)
|
|
|
+
|
|
|
+ if (that.length === 0) {
|
|
|
+ return that
|
|
|
+ }
|
|
|
+
|
|
|
+ obj.copy(that, 0, 0, len)
|
|
|
+ return that
|
|
|
+ }
|
|
|
+
|
|
|
+ if (obj) {
|
|
|
+ if ((typeof ArrayBuffer !== 'undefined' &&
|
|
|
+ obj.buffer instanceof ArrayBuffer) || 'length' in obj) {
|
|
|
+ if (typeof obj.length !== 'number' || isnan(obj.length)) {
|
|
|
+ return createBuffer(that, 0)
|
|
|
+ }
|
|
|
+ return fromArrayLike(that, obj)
|
|
|
+ }
|
|
|
+
|
|
|
+ if (obj.type === 'Buffer' && isArray(obj.data)) {
|
|
|
+ return fromArrayLike(that, obj.data)
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')
|
|
|
+ }
|
|
|
+
|
|
|
+ function checked (length) {
|
|
|
+ // Note: cannot use `length < kMaxLength()` here because that fails when
|
|
|
+ // length is NaN (which is otherwise coerced to zero.)
|
|
|
+ if (length >= kMaxLength()) {
|
|
|
+ throw new RangeError('Attempt to allocate Buffer larger than maximum ' +
|
|
|
+ 'size: 0x' + kMaxLength().toString(16) + ' bytes')
|
|
|
+ }
|
|
|
+ return length | 0
|
|
|
+ }
|
|
|
+
|
|
|
+ function SlowBuffer (length) {
|
|
|
+ if (+length != length) { // eslint-disable-line eqeqeq
|
|
|
+ length = 0
|
|
|
+ }
|
|
|
+ return Buffer.alloc(+length)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.isBuffer = function isBuffer (b) {
|
|
|
+ return !!(b != null && b._isBuffer)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.compare = function compare (a, b) {
|
|
|
+ if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {
|
|
|
+ throw new TypeError('Arguments must be Buffers')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (a === b) return 0
|
|
|
+
|
|
|
+ var x = a.length
|
|
|
+ var y = b.length
|
|
|
+
|
|
|
+ for (var i = 0, len = Math.min(x, y); i < len; ++i) {
|
|
|
+ if (a[i] !== b[i]) {
|
|
|
+ x = a[i]
|
|
|
+ y = b[i]
|
|
|
+ break
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if (x < y) return -1
|
|
|
+ if (y < x) return 1
|
|
|
+ return 0
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.isEncoding = function isEncoding (encoding) {
|
|
|
+ switch (String(encoding).toLowerCase()) {
|
|
|
+ case 'hex':
|
|
|
+ case 'utf8':
|
|
|
+ case 'utf-8':
|
|
|
+ case 'ascii':
|
|
|
+ case 'latin1':
|
|
|
+ case 'binary':
|
|
|
+ case 'base64':
|
|
|
+ case 'ucs2':
|
|
|
+ case 'ucs-2':
|
|
|
+ case 'utf16le':
|
|
|
+ case 'utf-16le':
|
|
|
+ return true
|
|
|
+ default:
|
|
|
+ return false
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.concat = function concat (list, length) {
|
|
|
+ if (!isArray(list)) {
|
|
|
+ throw new TypeError('"list" argument must be an Array of Buffers')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (list.length === 0) {
|
|
|
+ return Buffer.alloc(0)
|
|
|
+ }
|
|
|
+
|
|
|
+ var i
|
|
|
+ if (length === undefined) {
|
|
|
+ length = 0
|
|
|
+ for (i = 0; i < list.length; ++i) {
|
|
|
+ length += list[i].length
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ var buffer = Buffer.allocUnsafe(length)
|
|
|
+ var pos = 0
|
|
|
+ for (i = 0; i < list.length; ++i) {
|
|
|
+ var buf = list[i]
|
|
|
+ if (!Buffer.isBuffer(buf)) {
|
|
|
+ throw new TypeError('"list" argument must be an Array of Buffers')
|
|
|
+ }
|
|
|
+ buf.copy(buffer, pos)
|
|
|
+ pos += buf.length
|
|
|
+ }
|
|
|
+ return buffer
|
|
|
+ }
|
|
|
+
|
|
|
+ function byteLength (string, encoding) {
|
|
|
+ if (Buffer.isBuffer(string)) {
|
|
|
+ return string.length
|
|
|
+ }
|
|
|
+ if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&
|
|
|
+ (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {
|
|
|
+ return string.byteLength
|
|
|
+ }
|
|
|
+ if (typeof string !== 'string') {
|
|
|
+ string = '' + string
|
|
|
+ }
|
|
|
+
|
|
|
+ var len = string.length
|
|
|
+ if (len === 0) return 0
|
|
|
+
|
|
|
+ // Use a for loop to avoid recursion
|
|
|
+ var loweredCase = false
|
|
|
+ for (;;) {
|
|
|
+ switch (encoding) {
|
|
|
+ case 'ascii':
|
|
|
+ case 'latin1':
|
|
|
+ case 'binary':
|
|
|
+ return len
|
|
|
+ case 'utf8':
|
|
|
+ case 'utf-8':
|
|
|
+ case undefined:
|
|
|
+ return utf8ToBytes(string).length
|
|
|
+ case 'ucs2':
|
|
|
+ case 'ucs-2':
|
|
|
+ case 'utf16le':
|
|
|
+ case 'utf-16le':
|
|
|
+ return len * 2
|
|
|
+ case 'hex':
|
|
|
+ return len >>> 1
|
|
|
+ case 'base64':
|
|
|
+ return base64ToBytes(string).length
|
|
|
+ default:
|
|
|
+ if (loweredCase) return utf8ToBytes(string).length // assume utf8
|
|
|
+ encoding = ('' + encoding).toLowerCase()
|
|
|
+ loweredCase = true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ Buffer.byteLength = byteLength
|
|
|
+
|
|
|
+ function slowToString (encoding, start, end) {
|
|
|
+ var loweredCase = false
|
|
|
+
|
|
|
+ // No need to verify that "this.length <= MAX_UINT32" since it's a read-only
|
|
|
+ // property of a typed array.
|
|
|
+
|
|
|
+ // This behaves neither like String nor Uint8Array in that we set start/end
|
|
|
+ // to their upper/lower bounds if the value passed is out of range.
|
|
|
+ // undefined is handled specially as per ECMA-262 6th Edition,
|
|
|
+ // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.
|
|
|
+ if (start === undefined || start < 0) {
|
|
|
+ start = 0
|
|
|
+ }
|
|
|
+ // Return early if start > this.length. Done here to prevent potential uint32
|
|
|
+ // coercion fail below.
|
|
|
+ if (start > this.length) {
|
|
|
+ return ''
|
|
|
+ }
|
|
|
+
|
|
|
+ if (end === undefined || end > this.length) {
|
|
|
+ end = this.length
|
|
|
+ }
|
|
|
+
|
|
|
+ if (end <= 0) {
|
|
|
+ return ''
|
|
|
+ }
|
|
|
+
|
|
|
+ // Force coersion to uint32. This will also coerce falsey/NaN values to 0.
|
|
|
+ end >>>= 0
|
|
|
+ start >>>= 0
|
|
|
+
|
|
|
+ if (end <= start) {
|
|
|
+ return ''
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!encoding) encoding = 'utf8'
|
|
|
+
|
|
|
+ while (true) {
|
|
|
+ switch (encoding) {
|
|
|
+ case 'hex':
|
|
|
+ return hexSlice(this, start, end)
|
|
|
+
|
|
|
+ case 'utf8':
|
|
|
+ case 'utf-8':
|
|
|
+ return utf8Slice(this, start, end)
|
|
|
+
|
|
|
+ case 'ascii':
|
|
|
+ return asciiSlice(this, start, end)
|
|
|
+
|
|
|
+ case 'latin1':
|
|
|
+ case 'binary':
|
|
|
+ return latin1Slice(this, start, end)
|
|
|
+
|
|
|
+ case 'base64':
|
|
|
+ return base64Slice(this, start, end)
|
|
|
+
|
|
|
+ case 'ucs2':
|
|
|
+ case 'ucs-2':
|
|
|
+ case 'utf16le':
|
|
|
+ case 'utf-16le':
|
|
|
+ return utf16leSlice(this, start, end)
|
|
|
+
|
|
|
+ default:
|
|
|
+ if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)
|
|
|
+ encoding = (encoding + '').toLowerCase()
|
|
|
+ loweredCase = true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ // The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect
|
|
|
+ // Buffer instances.
|
|
|
+ Buffer.prototype._isBuffer = true
|
|
|
+
|
|
|
+ function swap (b, n, m) {
|
|
|
+ var i = b[n]
|
|
|
+ b[n] = b[m]
|
|
|
+ b[m] = i
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.swap16 = function swap16 () {
|
|
|
+ var len = this.length
|
|
|
+ if (len % 2 !== 0) {
|
|
|
+ throw new RangeError('Buffer size must be a multiple of 16-bits')
|
|
|
+ }
|
|
|
+ for (var i = 0; i < len; i += 2) {
|
|
|
+ swap(this, i, i + 1)
|
|
|
+ }
|
|
|
+ return this
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.swap32 = function swap32 () {
|
|
|
+ var len = this.length
|
|
|
+ if (len % 4 !== 0) {
|
|
|
+ throw new RangeError('Buffer size must be a multiple of 32-bits')
|
|
|
+ }
|
|
|
+ for (var i = 0; i < len; i += 4) {
|
|
|
+ swap(this, i, i + 3)
|
|
|
+ swap(this, i + 1, i + 2)
|
|
|
+ }
|
|
|
+ return this
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.swap64 = function swap64 () {
|
|
|
+ var len = this.length
|
|
|
+ if (len % 8 !== 0) {
|
|
|
+ throw new RangeError('Buffer size must be a multiple of 64-bits')
|
|
|
+ }
|
|
|
+ for (var i = 0; i < len; i += 8) {
|
|
|
+ swap(this, i, i + 7)
|
|
|
+ swap(this, i + 1, i + 6)
|
|
|
+ swap(this, i + 2, i + 5)
|
|
|
+ swap(this, i + 3, i + 4)
|
|
|
+ }
|
|
|
+ return this
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.toString = function toString () {
|
|
|
+ var length = this.length | 0
|
|
|
+ if (length === 0) return ''
|
|
|
+ if (arguments.length === 0) return utf8Slice(this, 0, length)
|
|
|
+ return slowToString.apply(this, arguments)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.equals = function equals (b) {
|
|
|
+ if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')
|
|
|
+ if (this === b) return true
|
|
|
+ return Buffer.compare(this, b) === 0
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.inspect = function inspect () {
|
|
|
+ var str = ''
|
|
|
+ var max = exports.INSPECT_MAX_BYTES
|
|
|
+ if (this.length > 0) {
|
|
|
+ str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')
|
|
|
+ if (this.length > max) str += ' ... '
|
|
|
+ }
|
|
|
+ return '<Buffer ' + str + '>'
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {
|
|
|
+ if (!Buffer.isBuffer(target)) {
|
|
|
+ throw new TypeError('Argument must be a Buffer')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (start === undefined) {
|
|
|
+ start = 0
|
|
|
+ }
|
|
|
+ if (end === undefined) {
|
|
|
+ end = target ? target.length : 0
|
|
|
+ }
|
|
|
+ if (thisStart === undefined) {
|
|
|
+ thisStart = 0
|
|
|
+ }
|
|
|
+ if (thisEnd === undefined) {
|
|
|
+ thisEnd = this.length
|
|
|
+ }
|
|
|
+
|
|
|
+ if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {
|
|
|
+ throw new RangeError('out of range index')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (thisStart >= thisEnd && start >= end) {
|
|
|
+ return 0
|
|
|
+ }
|
|
|
+ if (thisStart >= thisEnd) {
|
|
|
+ return -1
|
|
|
+ }
|
|
|
+ if (start >= end) {
|
|
|
+ return 1
|
|
|
+ }
|
|
|
+
|
|
|
+ start >>>= 0
|
|
|
+ end >>>= 0
|
|
|
+ thisStart >>>= 0
|
|
|
+ thisEnd >>>= 0
|
|
|
+
|
|
|
+ if (this === target) return 0
|
|
|
+
|
|
|
+ var x = thisEnd - thisStart
|
|
|
+ var y = end - start
|
|
|
+ var len = Math.min(x, y)
|
|
|
+
|
|
|
+ var thisCopy = this.slice(thisStart, thisEnd)
|
|
|
+ var targetCopy = target.slice(start, end)
|
|
|
+
|
|
|
+ for (var i = 0; i < len; ++i) {
|
|
|
+ if (thisCopy[i] !== targetCopy[i]) {
|
|
|
+ x = thisCopy[i]
|
|
|
+ y = targetCopy[i]
|
|
|
+ break
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if (x < y) return -1
|
|
|
+ if (y < x) return 1
|
|
|
+ return 0
|
|
|
+ }
|
|
|
+
|
|
|
+ // Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,
|
|
|
+ // OR the last index of `val` in `buffer` at offset <= `byteOffset`.
|
|
|
+ //
|
|
|
+ // Arguments:
|
|
|
+ // - buffer - a Buffer to search
|
|
|
+ // - val - a string, Buffer, or number
|
|
|
+ // - byteOffset - an index into `buffer`; will be clamped to an int32
|
|
|
+ // - encoding - an optional encoding, relevant is val is a string
|
|
|
+ // - dir - true for indexOf, false for lastIndexOf
|
|
|
+ function bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {
|
|
|
+ // Empty buffer means no match
|
|
|
+ if (buffer.length === 0) return -1
|
|
|
+
|
|
|
+ // Normalize byteOffset
|
|
|
+ if (typeof byteOffset === 'string') {
|
|
|
+ encoding = byteOffset
|
|
|
+ byteOffset = 0
|
|
|
+ } else if (byteOffset > 0x7fffffff) {
|
|
|
+ byteOffset = 0x7fffffff
|
|
|
+ } else if (byteOffset < -0x80000000) {
|
|
|
+ byteOffset = -0x80000000
|
|
|
+ }
|
|
|
+ byteOffset = +byteOffset // Coerce to Number.
|
|
|
+ if (isNaN(byteOffset)) {
|
|
|
+ // byteOffset: it it's undefined, null, NaN, "foo", etc, search whole buffer
|
|
|
+ byteOffset = dir ? 0 : (buffer.length - 1)
|
|
|
+ }
|
|
|
+
|
|
|
+ // Normalize byteOffset: negative offsets start from the end of the buffer
|
|
|
+ if (byteOffset < 0) byteOffset = buffer.length + byteOffset
|
|
|
+ if (byteOffset >= buffer.length) {
|
|
|
+ if (dir) return -1
|
|
|
+ else byteOffset = buffer.length - 1
|
|
|
+ } else if (byteOffset < 0) {
|
|
|
+ if (dir) byteOffset = 0
|
|
|
+ else return -1
|
|
|
+ }
|
|
|
+
|
|
|
+ // Normalize val
|
|
|
+ if (typeof val === 'string') {
|
|
|
+ val = Buffer.from(val, encoding)
|
|
|
+ }
|
|
|
+
|
|
|
+ // Finally, search either indexOf (if dir is true) or lastIndexOf
|
|
|
+ if (Buffer.isBuffer(val)) {
|
|
|
+ // Special case: looking for empty string/buffer always fails
|
|
|
+ if (val.length === 0) {
|
|
|
+ return -1
|
|
|
+ }
|
|
|
+ return arrayIndexOf(buffer, val, byteOffset, encoding, dir)
|
|
|
+ } else if (typeof val === 'number') {
|
|
|
+ val = val & 0xFF // Search for a byte value [0-255]
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT &&
|
|
|
+ typeof Uint8Array.prototype.indexOf === 'function') {
|
|
|
+ if (dir) {
|
|
|
+ return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)
|
|
|
+ } else {
|
|
|
+ return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)
|
|
|
+ }
|
|
|
+
|
|
|
+ throw new TypeError('val must be string, number or Buffer')
|
|
|
+ }
|
|
|
+
|
|
|
+ function arrayIndexOf (arr, val, byteOffset, encoding, dir) {
|
|
|
+ var indexSize = 1
|
|
|
+ var arrLength = arr.length
|
|
|
+ var valLength = val.length
|
|
|
+
|
|
|
+ if (encoding !== undefined) {
|
|
|
+ encoding = String(encoding).toLowerCase()
|
|
|
+ if (encoding === 'ucs2' || encoding === 'ucs-2' ||
|
|
|
+ encoding === 'utf16le' || encoding === 'utf-16le') {
|
|
|
+ if (arr.length < 2 || val.length < 2) {
|
|
|
+ return -1
|
|
|
+ }
|
|
|
+ indexSize = 2
|
|
|
+ arrLength /= 2
|
|
|
+ valLength /= 2
|
|
|
+ byteOffset /= 2
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function read (buf, i) {
|
|
|
+ if (indexSize === 1) {
|
|
|
+ return buf[i]
|
|
|
+ } else {
|
|
|
+ return buf.readUInt16BE(i * indexSize)
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ var i
|
|
|
+ if (dir) {
|
|
|
+ var foundIndex = -1
|
|
|
+ for (i = byteOffset; i < arrLength; i++) {
|
|
|
+ if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {
|
|
|
+ if (foundIndex === -1) foundIndex = i
|
|
|
+ if (i - foundIndex + 1 === valLength) return foundIndex * indexSize
|
|
|
+ } else {
|
|
|
+ if (foundIndex !== -1) i -= i - foundIndex
|
|
|
+ foundIndex = -1
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength
|
|
|
+ for (i = byteOffset; i >= 0; i--) {
|
|
|
+ var found = true
|
|
|
+ for (var j = 0; j < valLength; j++) {
|
|
|
+ if (read(arr, i + j) !== read(val, j)) {
|
|
|
+ found = false
|
|
|
+ break
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (found) return i
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return -1
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.includes = function includes (val, byteOffset, encoding) {
|
|
|
+ return this.indexOf(val, byteOffset, encoding) !== -1
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {
|
|
|
+ return bidirectionalIndexOf(this, val, byteOffset, encoding, true)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {
|
|
|
+ return bidirectionalIndexOf(this, val, byteOffset, encoding, false)
|
|
|
+ }
|
|
|
+
|
|
|
+ function hexWrite (buf, string, offset, length) {
|
|
|
+ offset = Number(offset) || 0
|
|
|
+ var remaining = buf.length - offset
|
|
|
+ if (!length) {
|
|
|
+ length = remaining
|
|
|
+ } else {
|
|
|
+ length = Number(length)
|
|
|
+ if (length > remaining) {
|
|
|
+ length = remaining
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ // must be an even number of digits
|
|
|
+ var strLen = string.length
|
|
|
+ if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')
|
|
|
+
|
|
|
+ if (length > strLen / 2) {
|
|
|
+ length = strLen / 2
|
|
|
+ }
|
|
|
+ for (var i = 0; i < length; ++i) {
|
|
|
+ var parsed = parseInt(string.substr(i * 2, 2), 16)
|
|
|
+ if (isNaN(parsed)) return i
|
|
|
+ buf[offset + i] = parsed
|
|
|
+ }
|
|
|
+ return i
|
|
|
+ }
|
|
|
+
|
|
|
+ function utf8Write (buf, string, offset, length) {
|
|
|
+ return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ function asciiWrite (buf, string, offset, length) {
|
|
|
+ return blitBuffer(asciiToBytes(string), buf, offset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ function latin1Write (buf, string, offset, length) {
|
|
|
+ return asciiWrite(buf, string, offset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ function base64Write (buf, string, offset, length) {
|
|
|
+ return blitBuffer(base64ToBytes(string), buf, offset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ function ucs2Write (buf, string, offset, length) {
|
|
|
+ return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.write = function write (string, offset, length, encoding) {
|
|
|
+ // Buffer#write(string)
|
|
|
+ if (offset === undefined) {
|
|
|
+ encoding = 'utf8'
|
|
|
+ length = this.length
|
|
|
+ offset = 0
|
|
|
+ // Buffer#write(string, encoding)
|
|
|
+ } else if (length === undefined && typeof offset === 'string') {
|
|
|
+ encoding = offset
|
|
|
+ length = this.length
|
|
|
+ offset = 0
|
|
|
+ // Buffer#write(string, offset[, length][, encoding])
|
|
|
+ } else if (isFinite(offset)) {
|
|
|
+ offset = offset | 0
|
|
|
+ if (isFinite(length)) {
|
|
|
+ length = length | 0
|
|
|
+ if (encoding === undefined) encoding = 'utf8'
|
|
|
+ } else {
|
|
|
+ encoding = length
|
|
|
+ length = undefined
|
|
|
+ }
|
|
|
+ // legacy write(string, encoding, offset, length) - remove in v0.13
|
|
|
+ } else {
|
|
|
+ throw new Error(
|
|
|
+ 'Buffer.write(string, encoding, offset[, length]) is no longer supported'
|
|
|
+ )
|
|
|
+ }
|
|
|
+
|
|
|
+ var remaining = this.length - offset
|
|
|
+ if (length === undefined || length > remaining) length = remaining
|
|
|
+
|
|
|
+ if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {
|
|
|
+ throw new RangeError('Attempt to write outside buffer bounds')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!encoding) encoding = 'utf8'
|
|
|
+
|
|
|
+ var loweredCase = false
|
|
|
+ for (;;) {
|
|
|
+ switch (encoding) {
|
|
|
+ case 'hex':
|
|
|
+ return hexWrite(this, string, offset, length)
|
|
|
+
|
|
|
+ case 'utf8':
|
|
|
+ case 'utf-8':
|
|
|
+ return utf8Write(this, string, offset, length)
|
|
|
+
|
|
|
+ case 'ascii':
|
|
|
+ return asciiWrite(this, string, offset, length)
|
|
|
+
|
|
|
+ case 'latin1':
|
|
|
+ case 'binary':
|
|
|
+ return latin1Write(this, string, offset, length)
|
|
|
+
|
|
|
+ case 'base64':
|
|
|
+ // Warning: maxLength not taken into account in base64Write
|
|
|
+ return base64Write(this, string, offset, length)
|
|
|
+
|
|
|
+ case 'ucs2':
|
|
|
+ case 'ucs-2':
|
|
|
+ case 'utf16le':
|
|
|
+ case 'utf-16le':
|
|
|
+ return ucs2Write(this, string, offset, length)
|
|
|
+
|
|
|
+ default:
|
|
|
+ if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)
|
|
|
+ encoding = ('' + encoding).toLowerCase()
|
|
|
+ loweredCase = true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.toJSON = function toJSON () {
|
|
|
+ return {
|
|
|
+ type: 'Buffer',
|
|
|
+ data: Array.prototype.slice.call(this._arr || this, 0)
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function base64Slice (buf, start, end) {
|
|
|
+ if (start === 0 && end === buf.length) {
|
|
|
+ return base64.fromByteArray(buf)
|
|
|
+ } else {
|
|
|
+ return base64.fromByteArray(buf.slice(start, end))
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function utf8Slice (buf, start, end) {
|
|
|
+ end = Math.min(buf.length, end)
|
|
|
+ var res = []
|
|
|
+
|
|
|
+ var i = start
|
|
|
+ while (i < end) {
|
|
|
+ var firstByte = buf[i]
|
|
|
+ var codePoint = null
|
|
|
+ var bytesPerSequence = (firstByte > 0xEF) ? 4
|
|
|
+ : (firstByte > 0xDF) ? 3
|
|
|
+ : (firstByte > 0xBF) ? 2
|
|
|
+ : 1
|
|
|
+
|
|
|
+ if (i + bytesPerSequence <= end) {
|
|
|
+ var secondByte, thirdByte, fourthByte, tempCodePoint
|
|
|
+
|
|
|
+ switch (bytesPerSequence) {
|
|
|
+ case 1:
|
|
|
+ if (firstByte < 0x80) {
|
|
|
+ codePoint = firstByte
|
|
|
+ }
|
|
|
+ break
|
|
|
+ case 2:
|
|
|
+ secondByte = buf[i + 1]
|
|
|
+ if ((secondByte & 0xC0) === 0x80) {
|
|
|
+ tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)
|
|
|
+ if (tempCodePoint > 0x7F) {
|
|
|
+ codePoint = tempCodePoint
|
|
|
+ }
|
|
|
+ }
|
|
|
+ break
|
|
|
+ case 3:
|
|
|
+ secondByte = buf[i + 1]
|
|
|
+ thirdByte = buf[i + 2]
|
|
|
+ if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {
|
|
|
+ tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)
|
|
|
+ if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {
|
|
|
+ codePoint = tempCodePoint
|
|
|
+ }
|
|
|
+ }
|
|
|
+ break
|
|
|
+ case 4:
|
|
|
+ secondByte = buf[i + 1]
|
|
|
+ thirdByte = buf[i + 2]
|
|
|
+ fourthByte = buf[i + 3]
|
|
|
+ if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {
|
|
|
+ tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)
|
|
|
+ if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {
|
|
|
+ codePoint = tempCodePoint
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if (codePoint === null) {
|
|
|
+ // we did not generate a valid codePoint so insert a
|
|
|
+ // replacement char (U+FFFD) and advance only 1 byte
|
|
|
+ codePoint = 0xFFFD
|
|
|
+ bytesPerSequence = 1
|
|
|
+ } else if (codePoint > 0xFFFF) {
|
|
|
+ // encode to utf16 (surrogate pair dance)
|
|
|
+ codePoint -= 0x10000
|
|
|
+ res.push(codePoint >>> 10 & 0x3FF | 0xD800)
|
|
|
+ codePoint = 0xDC00 | codePoint & 0x3FF
|
|
|
+ }
|
|
|
+
|
|
|
+ res.push(codePoint)
|
|
|
+ i += bytesPerSequence
|
|
|
+ }
|
|
|
+
|
|
|
+ return decodeCodePointsArray(res)
|
|
|
+ }
|
|
|
+
|
|
|
+ // Based on http://stackoverflow.com/a/22747272/680742, the browser with
|
|
|
+ // the lowest limit is Chrome, with 0x10000 args.
|
|
|
+ // We go 1 magnitude less, for safety
|
|
|
+ var MAX_ARGUMENTS_LENGTH = 0x1000
|
|
|
+
|
|
|
+ function decodeCodePointsArray (codePoints) {
|
|
|
+ var len = codePoints.length
|
|
|
+ if (len <= MAX_ARGUMENTS_LENGTH) {
|
|
|
+ return String.fromCharCode.apply(String, codePoints) // avoid extra slice()
|
|
|
+ }
|
|
|
+
|
|
|
+ // Decode in chunks to avoid "call stack size exceeded".
|
|
|
+ var res = ''
|
|
|
+ var i = 0
|
|
|
+ while (i < len) {
|
|
|
+ res += String.fromCharCode.apply(
|
|
|
+ String,
|
|
|
+ codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)
|
|
|
+ )
|
|
|
+ }
|
|
|
+ return res
|
|
|
+ }
|
|
|
+
|
|
|
+ function asciiSlice (buf, start, end) {
|
|
|
+ var ret = ''
|
|
|
+ end = Math.min(buf.length, end)
|
|
|
+
|
|
|
+ for (var i = start; i < end; ++i) {
|
|
|
+ ret += String.fromCharCode(buf[i] & 0x7F)
|
|
|
+ }
|
|
|
+ return ret
|
|
|
+ }
|
|
|
+
|
|
|
+ function latin1Slice (buf, start, end) {
|
|
|
+ var ret = ''
|
|
|
+ end = Math.min(buf.length, end)
|
|
|
+
|
|
|
+ for (var i = start; i < end; ++i) {
|
|
|
+ ret += String.fromCharCode(buf[i])
|
|
|
+ }
|
|
|
+ return ret
|
|
|
+ }
|
|
|
+
|
|
|
+ function hexSlice (buf, start, end) {
|
|
|
+ var len = buf.length
|
|
|
+
|
|
|
+ if (!start || start < 0) start = 0
|
|
|
+ if (!end || end < 0 || end > len) end = len
|
|
|
+
|
|
|
+ var out = ''
|
|
|
+ for (var i = start; i < end; ++i) {
|
|
|
+ out += toHex(buf[i])
|
|
|
+ }
|
|
|
+ return out
|
|
|
+ }
|
|
|
+
|
|
|
+ function utf16leSlice (buf, start, end) {
|
|
|
+ var bytes = buf.slice(start, end)
|
|
|
+ var res = ''
|
|
|
+ for (var i = 0; i < bytes.length; i += 2) {
|
|
|
+ res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)
|
|
|
+ }
|
|
|
+ return res
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.slice = function slice (start, end) {
|
|
|
+ var len = this.length
|
|
|
+ start = ~~start
|
|
|
+ end = end === undefined ? len : ~~end
|
|
|
+
|
|
|
+ if (start < 0) {
|
|
|
+ start += len
|
|
|
+ if (start < 0) start = 0
|
|
|
+ } else if (start > len) {
|
|
|
+ start = len
|
|
|
+ }
|
|
|
+
|
|
|
+ if (end < 0) {
|
|
|
+ end += len
|
|
|
+ if (end < 0) end = 0
|
|
|
+ } else if (end > len) {
|
|
|
+ end = len
|
|
|
+ }
|
|
|
+
|
|
|
+ if (end < start) end = start
|
|
|
+
|
|
|
+ var newBuf
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ newBuf = this.subarray(start, end)
|
|
|
+ newBuf.__proto__ = Buffer.prototype
|
|
|
+ } else {
|
|
|
+ var sliceLen = end - start
|
|
|
+ newBuf = new Buffer(sliceLen, undefined)
|
|
|
+ for (var i = 0; i < sliceLen; ++i) {
|
|
|
+ newBuf[i] = this[i + start]
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return newBuf
|
|
|
+ }
|
|
|
+
|
|
|
+ /*
|
|
|
+ * Need to make sure that buffer isn't trying to write out of bounds.
|
|
|
+ */
|
|
|
+ function checkOffset (offset, ext, length) {
|
|
|
+ if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')
|
|
|
+ if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {
|
|
|
+ offset = offset | 0
|
|
|
+ byteLength = byteLength | 0
|
|
|
+ if (!noAssert) checkOffset(offset, byteLength, this.length)
|
|
|
+
|
|
|
+ var val = this[offset]
|
|
|
+ var mul = 1
|
|
|
+ var i = 0
|
|
|
+ while (++i < byteLength && (mul *= 0x100)) {
|
|
|
+ val += this[offset + i] * mul
|
|
|
+ }
|
|
|
+
|
|
|
+ return val
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {
|
|
|
+ offset = offset | 0
|
|
|
+ byteLength = byteLength | 0
|
|
|
+ if (!noAssert) {
|
|
|
+ checkOffset(offset, byteLength, this.length)
|
|
|
+ }
|
|
|
+
|
|
|
+ var val = this[offset + --byteLength]
|
|
|
+ var mul = 1
|
|
|
+ while (byteLength > 0 && (mul *= 0x100)) {
|
|
|
+ val += this[offset + --byteLength] * mul
|
|
|
+ }
|
|
|
+
|
|
|
+ return val
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 1, this.length)
|
|
|
+ return this[offset]
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 2, this.length)
|
|
|
+ return this[offset] | (this[offset + 1] << 8)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 2, this.length)
|
|
|
+ return (this[offset] << 8) | this[offset + 1]
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 4, this.length)
|
|
|
+
|
|
|
+ return ((this[offset]) |
|
|
|
+ (this[offset + 1] << 8) |
|
|
|
+ (this[offset + 2] << 16)) +
|
|
|
+ (this[offset + 3] * 0x1000000)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 4, this.length)
|
|
|
+
|
|
|
+ return (this[offset] * 0x1000000) +
|
|
|
+ ((this[offset + 1] << 16) |
|
|
|
+ (this[offset + 2] << 8) |
|
|
|
+ this[offset + 3])
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {
|
|
|
+ offset = offset | 0
|
|
|
+ byteLength = byteLength | 0
|
|
|
+ if (!noAssert) checkOffset(offset, byteLength, this.length)
|
|
|
+
|
|
|
+ var val = this[offset]
|
|
|
+ var mul = 1
|
|
|
+ var i = 0
|
|
|
+ while (++i < byteLength && (mul *= 0x100)) {
|
|
|
+ val += this[offset + i] * mul
|
|
|
+ }
|
|
|
+ mul *= 0x80
|
|
|
+
|
|
|
+ if (val >= mul) val -= Math.pow(2, 8 * byteLength)
|
|
|
+
|
|
|
+ return val
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {
|
|
|
+ offset = offset | 0
|
|
|
+ byteLength = byteLength | 0
|
|
|
+ if (!noAssert) checkOffset(offset, byteLength, this.length)
|
|
|
+
|
|
|
+ var i = byteLength
|
|
|
+ var mul = 1
|
|
|
+ var val = this[offset + --i]
|
|
|
+ while (i > 0 && (mul *= 0x100)) {
|
|
|
+ val += this[offset + --i] * mul
|
|
|
+ }
|
|
|
+ mul *= 0x80
|
|
|
+
|
|
|
+ if (val >= mul) val -= Math.pow(2, 8 * byteLength)
|
|
|
+
|
|
|
+ return val
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 1, this.length)
|
|
|
+ if (!(this[offset] & 0x80)) return (this[offset])
|
|
|
+ return ((0xff - this[offset] + 1) * -1)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 2, this.length)
|
|
|
+ var val = this[offset] | (this[offset + 1] << 8)
|
|
|
+ return (val & 0x8000) ? val | 0xFFFF0000 : val
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 2, this.length)
|
|
|
+ var val = this[offset + 1] | (this[offset] << 8)
|
|
|
+ return (val & 0x8000) ? val | 0xFFFF0000 : val
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 4, this.length)
|
|
|
+
|
|
|
+ return (this[offset]) |
|
|
|
+ (this[offset + 1] << 8) |
|
|
|
+ (this[offset + 2] << 16) |
|
|
|
+ (this[offset + 3] << 24)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 4, this.length)
|
|
|
+
|
|
|
+ return (this[offset] << 24) |
|
|
|
+ (this[offset + 1] << 16) |
|
|
|
+ (this[offset + 2] << 8) |
|
|
|
+ (this[offset + 3])
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 4, this.length)
|
|
|
+ return ieee754.read(this, offset, true, 23, 4)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 4, this.length)
|
|
|
+ return ieee754.read(this, offset, false, 23, 4)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 8, this.length)
|
|
|
+ return ieee754.read(this, offset, true, 52, 8)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {
|
|
|
+ if (!noAssert) checkOffset(offset, 8, this.length)
|
|
|
+ return ieee754.read(this, offset, false, 52, 8)
|
|
|
+ }
|
|
|
+
|
|
|
+ function checkInt (buf, value, offset, ext, max, min) {
|
|
|
+ if (!Buffer.isBuffer(buf)) throw new TypeError('"buffer" argument must be a Buffer instance')
|
|
|
+ if (value > max || value < min) throw new RangeError('"value" argument is out of bounds')
|
|
|
+ if (offset + ext > buf.length) throw new RangeError('Index out of range')
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ byteLength = byteLength | 0
|
|
|
+ if (!noAssert) {
|
|
|
+ var maxBytes = Math.pow(2, 8 * byteLength) - 1
|
|
|
+ checkInt(this, value, offset, byteLength, maxBytes, 0)
|
|
|
+ }
|
|
|
+
|
|
|
+ var mul = 1
|
|
|
+ var i = 0
|
|
|
+ this[offset] = value & 0xFF
|
|
|
+ while (++i < byteLength && (mul *= 0x100)) {
|
|
|
+ this[offset + i] = (value / mul) & 0xFF
|
|
|
+ }
|
|
|
+
|
|
|
+ return offset + byteLength
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ byteLength = byteLength | 0
|
|
|
+ if (!noAssert) {
|
|
|
+ var maxBytes = Math.pow(2, 8 * byteLength) - 1
|
|
|
+ checkInt(this, value, offset, byteLength, maxBytes, 0)
|
|
|
+ }
|
|
|
+
|
|
|
+ var i = byteLength - 1
|
|
|
+ var mul = 1
|
|
|
+ this[offset + i] = value & 0xFF
|
|
|
+ while (--i >= 0 && (mul *= 0x100)) {
|
|
|
+ this[offset + i] = (value / mul) & 0xFF
|
|
|
+ }
|
|
|
+
|
|
|
+ return offset + byteLength
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)
|
|
|
+ if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)
|
|
|
+ this[offset] = (value & 0xff)
|
|
|
+ return offset + 1
|
|
|
+ }
|
|
|
+
|
|
|
+ function objectWriteUInt16 (buf, value, offset, littleEndian) {
|
|
|
+ if (value < 0) value = 0xffff + value + 1
|
|
|
+ for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {
|
|
|
+ buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>
|
|
|
+ (littleEndian ? i : 1 - i) * 8
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ this[offset] = (value & 0xff)
|
|
|
+ this[offset + 1] = (value >>> 8)
|
|
|
+ } else {
|
|
|
+ objectWriteUInt16(this, value, offset, true)
|
|
|
+ }
|
|
|
+ return offset + 2
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ this[offset] = (value >>> 8)
|
|
|
+ this[offset + 1] = (value & 0xff)
|
|
|
+ } else {
|
|
|
+ objectWriteUInt16(this, value, offset, false)
|
|
|
+ }
|
|
|
+ return offset + 2
|
|
|
+ }
|
|
|
+
|
|
|
+ function objectWriteUInt32 (buf, value, offset, littleEndian) {
|
|
|
+ if (value < 0) value = 0xffffffff + value + 1
|
|
|
+ for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {
|
|
|
+ buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ this[offset + 3] = (value >>> 24)
|
|
|
+ this[offset + 2] = (value >>> 16)
|
|
|
+ this[offset + 1] = (value >>> 8)
|
|
|
+ this[offset] = (value & 0xff)
|
|
|
+ } else {
|
|
|
+ objectWriteUInt32(this, value, offset, true)
|
|
|
+ }
|
|
|
+ return offset + 4
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ this[offset] = (value >>> 24)
|
|
|
+ this[offset + 1] = (value >>> 16)
|
|
|
+ this[offset + 2] = (value >>> 8)
|
|
|
+ this[offset + 3] = (value & 0xff)
|
|
|
+ } else {
|
|
|
+ objectWriteUInt32(this, value, offset, false)
|
|
|
+ }
|
|
|
+ return offset + 4
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) {
|
|
|
+ var limit = Math.pow(2, 8 * byteLength - 1)
|
|
|
+
|
|
|
+ checkInt(this, value, offset, byteLength, limit - 1, -limit)
|
|
|
+ }
|
|
|
+
|
|
|
+ var i = 0
|
|
|
+ var mul = 1
|
|
|
+ var sub = 0
|
|
|
+ this[offset] = value & 0xFF
|
|
|
+ while (++i < byteLength && (mul *= 0x100)) {
|
|
|
+ if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {
|
|
|
+ sub = 1
|
|
|
+ }
|
|
|
+ this[offset + i] = ((value / mul) >> 0) - sub & 0xFF
|
|
|
+ }
|
|
|
+
|
|
|
+ return offset + byteLength
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) {
|
|
|
+ var limit = Math.pow(2, 8 * byteLength - 1)
|
|
|
+
|
|
|
+ checkInt(this, value, offset, byteLength, limit - 1, -limit)
|
|
|
+ }
|
|
|
+
|
|
|
+ var i = byteLength - 1
|
|
|
+ var mul = 1
|
|
|
+ var sub = 0
|
|
|
+ this[offset + i] = value & 0xFF
|
|
|
+ while (--i >= 0 && (mul *= 0x100)) {
|
|
|
+ if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {
|
|
|
+ sub = 1
|
|
|
+ }
|
|
|
+ this[offset + i] = ((value / mul) >> 0) - sub & 0xFF
|
|
|
+ }
|
|
|
+
|
|
|
+ return offset + byteLength
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)
|
|
|
+ if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)
|
|
|
+ if (value < 0) value = 0xff + value + 1
|
|
|
+ this[offset] = (value & 0xff)
|
|
|
+ return offset + 1
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ this[offset] = (value & 0xff)
|
|
|
+ this[offset + 1] = (value >>> 8)
|
|
|
+ } else {
|
|
|
+ objectWriteUInt16(this, value, offset, true)
|
|
|
+ }
|
|
|
+ return offset + 2
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ this[offset] = (value >>> 8)
|
|
|
+ this[offset + 1] = (value & 0xff)
|
|
|
+ } else {
|
|
|
+ objectWriteUInt16(this, value, offset, false)
|
|
|
+ }
|
|
|
+ return offset + 2
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ this[offset] = (value & 0xff)
|
|
|
+ this[offset + 1] = (value >>> 8)
|
|
|
+ this[offset + 2] = (value >>> 16)
|
|
|
+ this[offset + 3] = (value >>> 24)
|
|
|
+ } else {
|
|
|
+ objectWriteUInt32(this, value, offset, true)
|
|
|
+ }
|
|
|
+ return offset + 4
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {
|
|
|
+ value = +value
|
|
|
+ offset = offset | 0
|
|
|
+ if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)
|
|
|
+ if (value < 0) value = 0xffffffff + value + 1
|
|
|
+ if (Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ this[offset] = (value >>> 24)
|
|
|
+ this[offset + 1] = (value >>> 16)
|
|
|
+ this[offset + 2] = (value >>> 8)
|
|
|
+ this[offset + 3] = (value & 0xff)
|
|
|
+ } else {
|
|
|
+ objectWriteUInt32(this, value, offset, false)
|
|
|
+ }
|
|
|
+ return offset + 4
|
|
|
+ }
|
|
|
+
|
|
|
+ function checkIEEE754 (buf, value, offset, ext, max, min) {
|
|
|
+ if (offset + ext > buf.length) throw new RangeError('Index out of range')
|
|
|
+ if (offset < 0) throw new RangeError('Index out of range')
|
|
|
+ }
|
|
|
+
|
|
|
+ function writeFloat (buf, value, offset, littleEndian, noAssert) {
|
|
|
+ if (!noAssert) {
|
|
|
+ checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)
|
|
|
+ }
|
|
|
+ ieee754.write(buf, value, offset, littleEndian, 23, 4)
|
|
|
+ return offset + 4
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {
|
|
|
+ return writeFloat(this, value, offset, true, noAssert)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {
|
|
|
+ return writeFloat(this, value, offset, false, noAssert)
|
|
|
+ }
|
|
|
+
|
|
|
+ function writeDouble (buf, value, offset, littleEndian, noAssert) {
|
|
|
+ if (!noAssert) {
|
|
|
+ checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)
|
|
|
+ }
|
|
|
+ ieee754.write(buf, value, offset, littleEndian, 52, 8)
|
|
|
+ return offset + 8
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {
|
|
|
+ return writeDouble(this, value, offset, true, noAssert)
|
|
|
+ }
|
|
|
+
|
|
|
+ Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {
|
|
|
+ return writeDouble(this, value, offset, false, noAssert)
|
|
|
+ }
|
|
|
+
|
|
|
+ // copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)
|
|
|
+ Buffer.prototype.copy = function copy (target, targetStart, start, end) {
|
|
|
+ if (!start) start = 0
|
|
|
+ if (!end && end !== 0) end = this.length
|
|
|
+ if (targetStart >= target.length) targetStart = target.length
|
|
|
+ if (!targetStart) targetStart = 0
|
|
|
+ if (end > 0 && end < start) end = start
|
|
|
+
|
|
|
+ // Copy 0 bytes; we're done
|
|
|
+ if (end === start) return 0
|
|
|
+ if (target.length === 0 || this.length === 0) return 0
|
|
|
+
|
|
|
+ // Fatal error conditions
|
|
|
+ if (targetStart < 0) {
|
|
|
+ throw new RangeError('targetStart out of bounds')
|
|
|
+ }
|
|
|
+ if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')
|
|
|
+ if (end < 0) throw new RangeError('sourceEnd out of bounds')
|
|
|
+
|
|
|
+ // Are we oob?
|
|
|
+ if (end > this.length) end = this.length
|
|
|
+ if (target.length - targetStart < end - start) {
|
|
|
+ end = target.length - targetStart + start
|
|
|
+ }
|
|
|
+
|
|
|
+ var len = end - start
|
|
|
+ var i
|
|
|
+
|
|
|
+ if (this === target && start < targetStart && targetStart < end) {
|
|
|
+ // descending copy from end
|
|
|
+ for (i = len - 1; i >= 0; --i) {
|
|
|
+ target[i + targetStart] = this[i + start]
|
|
|
+ }
|
|
|
+ } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {
|
|
|
+ // ascending copy from start
|
|
|
+ for (i = 0; i < len; ++i) {
|
|
|
+ target[i + targetStart] = this[i + start]
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ Uint8Array.prototype.set.call(
|
|
|
+ target,
|
|
|
+ this.subarray(start, start + len),
|
|
|
+ targetStart
|
|
|
+ )
|
|
|
+ }
|
|
|
+
|
|
|
+ return len
|
|
|
+ }
|
|
|
+
|
|
|
+ // Usage:
|
|
|
+ // buffer.fill(number[, offset[, end]])
|
|
|
+ // buffer.fill(buffer[, offset[, end]])
|
|
|
+ // buffer.fill(string[, offset[, end]][, encoding])
|
|
|
+ Buffer.prototype.fill = function fill (val, start, end, encoding) {
|
|
|
+ // Handle string cases:
|
|
|
+ if (typeof val === 'string') {
|
|
|
+ if (typeof start === 'string') {
|
|
|
+ encoding = start
|
|
|
+ start = 0
|
|
|
+ end = this.length
|
|
|
+ } else if (typeof end === 'string') {
|
|
|
+ encoding = end
|
|
|
+ end = this.length
|
|
|
+ }
|
|
|
+ if (val.length === 1) {
|
|
|
+ var code = val.charCodeAt(0)
|
|
|
+ if (code < 256) {
|
|
|
+ val = code
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (encoding !== undefined && typeof encoding !== 'string') {
|
|
|
+ throw new TypeError('encoding must be a string')
|
|
|
+ }
|
|
|
+ if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {
|
|
|
+ throw new TypeError('Unknown encoding: ' + encoding)
|
|
|
+ }
|
|
|
+ } else if (typeof val === 'number') {
|
|
|
+ val = val & 255
|
|
|
+ }
|
|
|
+
|
|
|
+ // Invalid ranges are not set to a default, so can range check early.
|
|
|
+ if (start < 0 || this.length < start || this.length < end) {
|
|
|
+ throw new RangeError('Out of range index')
|
|
|
+ }
|
|
|
+
|
|
|
+ if (end <= start) {
|
|
|
+ return this
|
|
|
+ }
|
|
|
+
|
|
|
+ start = start >>> 0
|
|
|
+ end = end === undefined ? this.length : end >>> 0
|
|
|
+
|
|
|
+ if (!val) val = 0
|
|
|
+
|
|
|
+ var i
|
|
|
+ if (typeof val === 'number') {
|
|
|
+ for (i = start; i < end; ++i) {
|
|
|
+ this[i] = val
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ var bytes = Buffer.isBuffer(val)
|
|
|
+ ? val
|
|
|
+ : utf8ToBytes(new Buffer(val, encoding).toString())
|
|
|
+ var len = bytes.length
|
|
|
+ for (i = 0; i < end - start; ++i) {
|
|
|
+ this[i + start] = bytes[i % len]
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return this
|
|
|
+ }
|
|
|
+
|
|
|
+ // HELPER FUNCTIONS
|
|
|
+ // ================
|
|
|
+
|
|
|
+ var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g
|
|
|
+
|
|
|
+ function base64clean (str) {
|
|
|
+ // Node strips out invalid characters like \n and \t from the string, base64-js does not
|
|
|
+ str = stringtrim(str).replace(INVALID_BASE64_RE, '')
|
|
|
+ // Node converts strings with length < 2 to ''
|
|
|
+ if (str.length < 2) return ''
|
|
|
+ // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not
|
|
|
+ while (str.length % 4 !== 0) {
|
|
|
+ str = str + '='
|
|
|
+ }
|
|
|
+ return str
|
|
|
+ }
|
|
|
+
|
|
|
+ function stringtrim (str) {
|
|
|
+ if (str.trim) return str.trim()
|
|
|
+ return str.replace(/^\s+|\s+$/g, '')
|
|
|
+ }
|
|
|
+
|
|
|
+ function toHex (n) {
|
|
|
+ if (n < 16) return '0' + n.toString(16)
|
|
|
+ return n.toString(16)
|
|
|
+ }
|
|
|
+
|
|
|
+ function utf8ToBytes (string, units) {
|
|
|
+ units = units || Infinity
|
|
|
+ var codePoint
|
|
|
+ var length = string.length
|
|
|
+ var leadSurrogate = null
|
|
|
+ var bytes = []
|
|
|
+
|
|
|
+ for (var i = 0; i < length; ++i) {
|
|
|
+ codePoint = string.charCodeAt(i)
|
|
|
+
|
|
|
+ // is surrogate component
|
|
|
+ if (codePoint > 0xD7FF && codePoint < 0xE000) {
|
|
|
+ // last char was a lead
|
|
|
+ if (!leadSurrogate) {
|
|
|
+ // no lead yet
|
|
|
+ if (codePoint > 0xDBFF) {
|
|
|
+ // unexpected trail
|
|
|
+ if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)
|
|
|
+ continue
|
|
|
+ } else if (i + 1 === length) {
|
|
|
+ // unpaired lead
|
|
|
+ if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)
|
|
|
+ continue
|
|
|
+ }
|
|
|
+
|
|
|
+ // valid lead
|
|
|
+ leadSurrogate = codePoint
|
|
|
+
|
|
|
+ continue
|
|
|
+ }
|
|
|
+
|
|
|
+ // 2 leads in a row
|
|
|
+ if (codePoint < 0xDC00) {
|
|
|
+ if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)
|
|
|
+ leadSurrogate = codePoint
|
|
|
+ continue
|
|
|
+ }
|
|
|
+
|
|
|
+ // valid surrogate pair
|
|
|
+ codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000
|
|
|
+ } else if (leadSurrogate) {
|
|
|
+ // valid bmp char, but last char was a lead
|
|
|
+ if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)
|
|
|
+ }
|
|
|
+
|
|
|
+ leadSurrogate = null
|
|
|
+
|
|
|
+ // encode utf8
|
|
|
+ if (codePoint < 0x80) {
|
|
|
+ if ((units -= 1) < 0) break
|
|
|
+ bytes.push(codePoint)
|
|
|
+ } else if (codePoint < 0x800) {
|
|
|
+ if ((units -= 2) < 0) break
|
|
|
+ bytes.push(
|
|
|
+ codePoint >> 0x6 | 0xC0,
|
|
|
+ codePoint & 0x3F | 0x80
|
|
|
+ )
|
|
|
+ } else if (codePoint < 0x10000) {
|
|
|
+ if ((units -= 3) < 0) break
|
|
|
+ bytes.push(
|
|
|
+ codePoint >> 0xC | 0xE0,
|
|
|
+ codePoint >> 0x6 & 0x3F | 0x80,
|
|
|
+ codePoint & 0x3F | 0x80
|
|
|
+ )
|
|
|
+ } else if (codePoint < 0x110000) {
|
|
|
+ if ((units -= 4) < 0) break
|
|
|
+ bytes.push(
|
|
|
+ codePoint >> 0x12 | 0xF0,
|
|
|
+ codePoint >> 0xC & 0x3F | 0x80,
|
|
|
+ codePoint >> 0x6 & 0x3F | 0x80,
|
|
|
+ codePoint & 0x3F | 0x80
|
|
|
+ )
|
|
|
+ } else {
|
|
|
+ throw new Error('Invalid code point')
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return bytes
|
|
|
+ }
|
|
|
+
|
|
|
+ function asciiToBytes (str) {
|
|
|
+ var byteArray = []
|
|
|
+ for (var i = 0; i < str.length; ++i) {
|
|
|
+ // Node's code seems to be doing this and not & 0x7F..
|
|
|
+ byteArray.push(str.charCodeAt(i) & 0xFF)
|
|
|
+ }
|
|
|
+ return byteArray
|
|
|
+ }
|
|
|
+
|
|
|
+ function utf16leToBytes (str, units) {
|
|
|
+ var c, hi, lo
|
|
|
+ var byteArray = []
|
|
|
+ for (var i = 0; i < str.length; ++i) {
|
|
|
+ if ((units -= 2) < 0) break
|
|
|
+
|
|
|
+ c = str.charCodeAt(i)
|
|
|
+ hi = c >> 8
|
|
|
+ lo = c % 256
|
|
|
+ byteArray.push(lo)
|
|
|
+ byteArray.push(hi)
|
|
|
+ }
|
|
|
+
|
|
|
+ return byteArray
|
|
|
+ }
|
|
|
+
|
|
|
+ function base64ToBytes (str) {
|
|
|
+ return base64.toByteArray(base64clean(str))
|
|
|
+ }
|
|
|
+
|
|
|
+ function blitBuffer (src, dst, offset, length) {
|
|
|
+ for (var i = 0; i < length; ++i) {
|
|
|
+ if ((i + offset >= dst.length) || (i >= src.length)) break
|
|
|
+ dst[i + offset] = src[i]
|
|
|
+ }
|
|
|
+ return i
|
|
|
+ }
|
|
|
+
|
|
|
+ function isnan (val) {
|
|
|
+ return val !== val // eslint-disable-line no-self-compare
|
|
|
+ }
|
|
|
+
|
|
|
+ /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 4 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict'
|
|
|
+
|
|
|
+ exports.byteLength = byteLength
|
|
|
+ exports.toByteArray = toByteArray
|
|
|
+ exports.fromByteArray = fromByteArray
|
|
|
+
|
|
|
+ var lookup = []
|
|
|
+ var revLookup = []
|
|
|
+ var Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array
|
|
|
+
|
|
|
+ var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'
|
|
|
+ for (var i = 0, len = code.length; i < len; ++i) {
|
|
|
+ lookup[i] = code[i]
|
|
|
+ revLookup[code.charCodeAt(i)] = i
|
|
|
+ }
|
|
|
+
|
|
|
+ revLookup['-'.charCodeAt(0)] = 62
|
|
|
+ revLookup['_'.charCodeAt(0)] = 63
|
|
|
+
|
|
|
+ function placeHoldersCount (b64) {
|
|
|
+ var len = b64.length
|
|
|
+ if (len % 4 > 0) {
|
|
|
+ throw new Error('Invalid string. Length must be a multiple of 4')
|
|
|
+ }
|
|
|
+
|
|
|
+ // the number of equal signs (place holders)
|
|
|
+ // if there are two placeholders, than the two characters before it
|
|
|
+ // represent one byte
|
|
|
+ // if there is only one, then the three characters before it represent 2 bytes
|
|
|
+ // this is just a cheap hack to not do indexOf twice
|
|
|
+ return b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0
|
|
|
+ }
|
|
|
+
|
|
|
+ function byteLength (b64) {
|
|
|
+ // base64 is 4/3 + up to two characters of the original data
|
|
|
+ return b64.length * 3 / 4 - placeHoldersCount(b64)
|
|
|
+ }
|
|
|
+
|
|
|
+ function toByteArray (b64) {
|
|
|
+ var i, j, l, tmp, placeHolders, arr
|
|
|
+ var len = b64.length
|
|
|
+ placeHolders = placeHoldersCount(b64)
|
|
|
+
|
|
|
+ arr = new Arr(len * 3 / 4 - placeHolders)
|
|
|
+
|
|
|
+ // if there are placeholders, only get up to the last complete 4 chars
|
|
|
+ l = placeHolders > 0 ? len - 4 : len
|
|
|
+
|
|
|
+ var L = 0
|
|
|
+
|
|
|
+ for (i = 0, j = 0; i < l; i += 4, j += 3) {
|
|
|
+ tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]
|
|
|
+ arr[L++] = (tmp >> 16) & 0xFF
|
|
|
+ arr[L++] = (tmp >> 8) & 0xFF
|
|
|
+ arr[L++] = tmp & 0xFF
|
|
|
+ }
|
|
|
+
|
|
|
+ if (placeHolders === 2) {
|
|
|
+ tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)
|
|
|
+ arr[L++] = tmp & 0xFF
|
|
|
+ } else if (placeHolders === 1) {
|
|
|
+ tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)
|
|
|
+ arr[L++] = (tmp >> 8) & 0xFF
|
|
|
+ arr[L++] = tmp & 0xFF
|
|
|
+ }
|
|
|
+
|
|
|
+ return arr
|
|
|
+ }
|
|
|
+
|
|
|
+ function tripletToBase64 (num) {
|
|
|
+ return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]
|
|
|
+ }
|
|
|
+
|
|
|
+ function encodeChunk (uint8, start, end) {
|
|
|
+ var tmp
|
|
|
+ var output = []
|
|
|
+ for (var i = start; i < end; i += 3) {
|
|
|
+ tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])
|
|
|
+ output.push(tripletToBase64(tmp))
|
|
|
+ }
|
|
|
+ return output.join('')
|
|
|
+ }
|
|
|
+
|
|
|
+ function fromByteArray (uint8) {
|
|
|
+ var tmp
|
|
|
+ var len = uint8.length
|
|
|
+ var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes
|
|
|
+ var output = ''
|
|
|
+ var parts = []
|
|
|
+ var maxChunkLength = 16383 // must be multiple of 3
|
|
|
+
|
|
|
+ // go through the array every three bytes, we'll deal with trailing stuff later
|
|
|
+ for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {
|
|
|
+ parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))
|
|
|
+ }
|
|
|
+
|
|
|
+ // pad the end with zeros, but make sure to not forget the extra bytes
|
|
|
+ if (extraBytes === 1) {
|
|
|
+ tmp = uint8[len - 1]
|
|
|
+ output += lookup[tmp >> 2]
|
|
|
+ output += lookup[(tmp << 4) & 0x3F]
|
|
|
+ output += '=='
|
|
|
+ } else if (extraBytes === 2) {
|
|
|
+ tmp = (uint8[len - 2] << 8) + (uint8[len - 1])
|
|
|
+ output += lookup[tmp >> 10]
|
|
|
+ output += lookup[(tmp >> 4) & 0x3F]
|
|
|
+ output += lookup[(tmp << 2) & 0x3F]
|
|
|
+ output += '='
|
|
|
+ }
|
|
|
+
|
|
|
+ parts.push(output)
|
|
|
+
|
|
|
+ return parts.join('')
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 5 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ exports.read = function (buffer, offset, isLE, mLen, nBytes) {
|
|
|
+ var e, m
|
|
|
+ var eLen = nBytes * 8 - mLen - 1
|
|
|
+ var eMax = (1 << eLen) - 1
|
|
|
+ var eBias = eMax >> 1
|
|
|
+ var nBits = -7
|
|
|
+ var i = isLE ? (nBytes - 1) : 0
|
|
|
+ var d = isLE ? -1 : 1
|
|
|
+ var s = buffer[offset + i]
|
|
|
+
|
|
|
+ i += d
|
|
|
+
|
|
|
+ e = s & ((1 << (-nBits)) - 1)
|
|
|
+ s >>= (-nBits)
|
|
|
+ nBits += eLen
|
|
|
+ for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}
|
|
|
+
|
|
|
+ m = e & ((1 << (-nBits)) - 1)
|
|
|
+ e >>= (-nBits)
|
|
|
+ nBits += mLen
|
|
|
+ for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}
|
|
|
+
|
|
|
+ if (e === 0) {
|
|
|
+ e = 1 - eBias
|
|
|
+ } else if (e === eMax) {
|
|
|
+ return m ? NaN : ((s ? -1 : 1) * Infinity)
|
|
|
+ } else {
|
|
|
+ m = m + Math.pow(2, mLen)
|
|
|
+ e = e - eBias
|
|
|
+ }
|
|
|
+ return (s ? -1 : 1) * m * Math.pow(2, e - mLen)
|
|
|
+ }
|
|
|
+
|
|
|
+ exports.write = function (buffer, value, offset, isLE, mLen, nBytes) {
|
|
|
+ var e, m, c
|
|
|
+ var eLen = nBytes * 8 - mLen - 1
|
|
|
+ var eMax = (1 << eLen) - 1
|
|
|
+ var eBias = eMax >> 1
|
|
|
+ var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)
|
|
|
+ var i = isLE ? 0 : (nBytes - 1)
|
|
|
+ var d = isLE ? 1 : -1
|
|
|
+ var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0
|
|
|
+
|
|
|
+ value = Math.abs(value)
|
|
|
+
|
|
|
+ if (isNaN(value) || value === Infinity) {
|
|
|
+ m = isNaN(value) ? 1 : 0
|
|
|
+ e = eMax
|
|
|
+ } else {
|
|
|
+ e = Math.floor(Math.log(value) / Math.LN2)
|
|
|
+ if (value * (c = Math.pow(2, -e)) < 1) {
|
|
|
+ e--
|
|
|
+ c *= 2
|
|
|
+ }
|
|
|
+ if (e + eBias >= 1) {
|
|
|
+ value += rt / c
|
|
|
+ } else {
|
|
|
+ value += rt * Math.pow(2, 1 - eBias)
|
|
|
+ }
|
|
|
+ if (value * c >= 2) {
|
|
|
+ e++
|
|
|
+ c /= 2
|
|
|
+ }
|
|
|
+
|
|
|
+ if (e + eBias >= eMax) {
|
|
|
+ m = 0
|
|
|
+ e = eMax
|
|
|
+ } else if (e + eBias >= 1) {
|
|
|
+ m = (value * c - 1) * Math.pow(2, mLen)
|
|
|
+ e = e + eBias
|
|
|
+ } else {
|
|
|
+ m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)
|
|
|
+ e = 0
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}
|
|
|
+
|
|
|
+ e = (e << mLen) | m
|
|
|
+ eLen += mLen
|
|
|
+ for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}
|
|
|
+
|
|
|
+ buffer[offset + i - d] |= s * 128
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 6 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ var toString = {}.toString;
|
|
|
+
|
|
|
+ module.exports = Array.isArray || function (arr) {
|
|
|
+ return toString.call(arr) == '[object Array]';
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 7 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ module.exports = function bind(fn, thisArg) {
|
|
|
+ return function wrap() {
|
|
|
+ var args = new Array(arguments.length);
|
|
|
+ for (var i = 0; i < args.length; i++) {
|
|
|
+ args[i] = arguments[i];
|
|
|
+ }
|
|
|
+ return fn.apply(thisArg, args);
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 8 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var defaults = __webpack_require__(9);
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+ var InterceptorManager = __webpack_require__(20);
|
|
|
+ var dispatchRequest = __webpack_require__(21);
|
|
|
+ var isAbsoluteURL = __webpack_require__(24);
|
|
|
+ var combineURLs = __webpack_require__(25);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Create a new instance of Axios
|
|
|
+ *
|
|
|
+ * @param {Object} instanceConfig The default config for the instance
|
|
|
+ */
|
|
|
+ function Axios(instanceConfig) {
|
|
|
+ this.defaults = instanceConfig;
|
|
|
+ this.interceptors = {
|
|
|
+ request: new InterceptorManager(),
|
|
|
+ response: new InterceptorManager()
|
|
|
+ };
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Dispatch a request
|
|
|
+ *
|
|
|
+ * @param {Object} config The config specific for this request (merged with this.defaults)
|
|
|
+ */
|
|
|
+ Axios.prototype.request = function request(config) {
|
|
|
+ /*eslint no-param-reassign:0*/
|
|
|
+ // Allow for axios('example/url'[, config]) a la fetch API
|
|
|
+ if (typeof config === 'string') {
|
|
|
+ config = utils.merge({
|
|
|
+ url: arguments[0]
|
|
|
+ }, arguments[1]);
|
|
|
+ }
|
|
|
+
|
|
|
+ config = utils.merge(defaults, this.defaults, { method: 'get' }, config);
|
|
|
+
|
|
|
+ // Support baseURL config
|
|
|
+ if (config.baseURL && !isAbsoluteURL(config.url)) {
|
|
|
+ config.url = combineURLs(config.baseURL, config.url);
|
|
|
+ }
|
|
|
+
|
|
|
+ // Hook up interceptors middleware
|
|
|
+ var chain = [dispatchRequest, undefined];
|
|
|
+ var promise = Promise.resolve(config);
|
|
|
+
|
|
|
+ this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {
|
|
|
+ chain.unshift(interceptor.fulfilled, interceptor.rejected);
|
|
|
+ });
|
|
|
+
|
|
|
+ this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {
|
|
|
+ chain.push(interceptor.fulfilled, interceptor.rejected);
|
|
|
+ });
|
|
|
+
|
|
|
+ while (chain.length) {
|
|
|
+ promise = promise.then(chain.shift(), chain.shift());
|
|
|
+ }
|
|
|
+
|
|
|
+ return promise;
|
|
|
+ };
|
|
|
+
|
|
|
+ // Provide aliases for supported request methods
|
|
|
+ utils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {
|
|
|
+ /*eslint func-names:0*/
|
|
|
+ Axios.prototype[method] = function(url, config) {
|
|
|
+ return this.request(utils.merge(config || {}, {
|
|
|
+ method: method,
|
|
|
+ url: url
|
|
|
+ }));
|
|
|
+ };
|
|
|
+ });
|
|
|
+
|
|
|
+ utils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {
|
|
|
+ /*eslint func-names:0*/
|
|
|
+ Axios.prototype[method] = function(url, data, config) {
|
|
|
+ return this.request(utils.merge(config || {}, {
|
|
|
+ method: method,
|
|
|
+ url: url,
|
|
|
+ data: data
|
|
|
+ }));
|
|
|
+ };
|
|
|
+ });
|
|
|
+
|
|
|
+ module.exports = Axios;
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 9 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+ var normalizeHeaderName = __webpack_require__(10);
|
|
|
+
|
|
|
+ var DEFAULT_CONTENT_TYPE = {
|
|
|
+ 'Content-Type': 'application/x-www-form-urlencoded'
|
|
|
+ };
|
|
|
+
|
|
|
+ function setContentTypeIfUnset(headers, value) {
|
|
|
+ if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {
|
|
|
+ headers['Content-Type'] = value;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function getDefaultAdapter() {
|
|
|
+ var adapter;
|
|
|
+ if (typeof XMLHttpRequest !== 'undefined') {
|
|
|
+ // For browsers use XHR adapter
|
|
|
+ adapter = __webpack_require__(11);
|
|
|
+ } else if (typeof process !== 'undefined') {
|
|
|
+ // For node use HTTP adapter
|
|
|
+ adapter = __webpack_require__(11);
|
|
|
+ }
|
|
|
+ return adapter;
|
|
|
+ }
|
|
|
+
|
|
|
+ var defaults = {
|
|
|
+ adapter: getDefaultAdapter(),
|
|
|
+
|
|
|
+ transformRequest: [function transformRequest(data, headers) {
|
|
|
+ normalizeHeaderName(headers, 'Content-Type');
|
|
|
+ if (utils.isFormData(data) ||
|
|
|
+ utils.isArrayBuffer(data) ||
|
|
|
+ utils.isBuffer(data) ||
|
|
|
+ utils.isStream(data) ||
|
|
|
+ utils.isFile(data) ||
|
|
|
+ utils.isBlob(data)
|
|
|
+ ) {
|
|
|
+ return data;
|
|
|
+ }
|
|
|
+ if (utils.isArrayBufferView(data)) {
|
|
|
+ return data.buffer;
|
|
|
+ }
|
|
|
+ if (utils.isURLSearchParams(data)) {
|
|
|
+ setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');
|
|
|
+ return data.toString();
|
|
|
+ }
|
|
|
+ if (utils.isObject(data)) {
|
|
|
+ setContentTypeIfUnset(headers, 'application/json;charset=utf-8');
|
|
|
+ return JSON.stringify(data);
|
|
|
+ }
|
|
|
+ return data;
|
|
|
+ }],
|
|
|
+
|
|
|
+ transformResponse: [function transformResponse(data) {
|
|
|
+ /*eslint no-param-reassign:0*/
|
|
|
+ if (typeof data === 'string') {
|
|
|
+ try {
|
|
|
+ data = JSON.parse(data);
|
|
|
+ } catch (e) { /* Ignore */ }
|
|
|
+ }
|
|
|
+ return data;
|
|
|
+ }],
|
|
|
+
|
|
|
+ timeout: 0,
|
|
|
+
|
|
|
+ xsrfCookieName: 'XSRF-TOKEN',
|
|
|
+ xsrfHeaderName: 'X-XSRF-TOKEN',
|
|
|
+
|
|
|
+ maxContentLength: -1,
|
|
|
+
|
|
|
+ validateStatus: function validateStatus(status) {
|
|
|
+ return status >= 200 && status < 300;
|
|
|
+ }
|
|
|
+ };
|
|
|
+
|
|
|
+ defaults.headers = {
|
|
|
+ common: {
|
|
|
+ 'Accept': 'application/json, text/plain, */*'
|
|
|
+ }
|
|
|
+ };
|
|
|
+
|
|
|
+ utils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {
|
|
|
+ defaults.headers[method] = {};
|
|
|
+ });
|
|
|
+
|
|
|
+ utils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {
|
|
|
+ defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);
|
|
|
+ });
|
|
|
+
|
|
|
+ module.exports = defaults;
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 10 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+
|
|
|
+ module.exports = function normalizeHeaderName(headers, normalizedName) {
|
|
|
+ utils.forEach(headers, function processHeader(value, name) {
|
|
|
+ if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {
|
|
|
+ headers[normalizedName] = value;
|
|
|
+ delete headers[name];
|
|
|
+ }
|
|
|
+ });
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 11 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+ var settle = __webpack_require__(12);
|
|
|
+ var buildURL = __webpack_require__(15);
|
|
|
+ var parseHeaders = __webpack_require__(16);
|
|
|
+ var isURLSameOrigin = __webpack_require__(17);
|
|
|
+ var createError = __webpack_require__(13);
|
|
|
+ var btoa = (typeof window !== 'undefined' && window.btoa && window.btoa.bind(window)) || __webpack_require__(18);
|
|
|
+
|
|
|
+ module.exports = function xhrAdapter(config) {
|
|
|
+ return new Promise(function dispatchXhrRequest(resolve, reject) {
|
|
|
+ var requestData = config.data;
|
|
|
+ var requestHeaders = config.headers;
|
|
|
+
|
|
|
+ if (utils.isFormData(requestData)) {
|
|
|
+ delete requestHeaders['Content-Type']; // Let the browser set it
|
|
|
+ }
|
|
|
+
|
|
|
+ var request = new XMLHttpRequest();
|
|
|
+ var loadEvent = 'onreadystatechange';
|
|
|
+ var xDomain = false;
|
|
|
+
|
|
|
+ // For IE 8/9 CORS support
|
|
|
+ // Only supports POST and GET calls and doesn't returns the response headers.
|
|
|
+ // DON'T do this for testing b/c XMLHttpRequest is mocked, not XDomainRequest.
|
|
|
+ if (("production") !== 'test' &&
|
|
|
+ typeof window !== 'undefined' &&
|
|
|
+ window.XDomainRequest && !('withCredentials' in request) &&
|
|
|
+ !isURLSameOrigin(config.url)) {
|
|
|
+ request = new window.XDomainRequest();
|
|
|
+ loadEvent = 'onload';
|
|
|
+ xDomain = true;
|
|
|
+ request.onprogress = function handleProgress() {};
|
|
|
+ request.ontimeout = function handleTimeout() {};
|
|
|
+ }
|
|
|
+
|
|
|
+ // HTTP basic authentication
|
|
|
+ if (config.auth) {
|
|
|
+ var username = config.auth.username || '';
|
|
|
+ var password = config.auth.password || '';
|
|
|
+ requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);
|
|
|
+ }
|
|
|
+
|
|
|
+ request.open(config.method.toUpperCase(), buildURL(config.url, config.params, config.paramsSerializer), true);
|
|
|
+
|
|
|
+ // Set the request timeout in MS
|
|
|
+ request.timeout = config.timeout;
|
|
|
+
|
|
|
+ // Listen for ready state
|
|
|
+ request[loadEvent] = function handleLoad() {
|
|
|
+ if (!request || (request.readyState !== 4 && !xDomain)) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ // The request errored out and we didn't get a response, this will be
|
|
|
+ // handled by onerror instead
|
|
|
+ // With one exception: request that using file: protocol, most browsers
|
|
|
+ // will return status as 0 even though it's a successful request
|
|
|
+ if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ // Prepare the response
|
|
|
+ var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;
|
|
|
+ var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;
|
|
|
+ var response = {
|
|
|
+ data: responseData,
|
|
|
+ // IE sends 1223 instead of 204 (https://github.com/mzabriskie/axios/issues/201)
|
|
|
+ status: request.status === 1223 ? 204 : request.status,
|
|
|
+ statusText: request.status === 1223 ? 'No Content' : request.statusText,
|
|
|
+ headers: responseHeaders,
|
|
|
+ config: config,
|
|
|
+ request: request
|
|
|
+ };
|
|
|
+
|
|
|
+ settle(resolve, reject, response);
|
|
|
+
|
|
|
+ // Clean up request
|
|
|
+ request = null;
|
|
|
+ };
|
|
|
+
|
|
|
+ // Handle low level network errors
|
|
|
+ request.onerror = function handleError() {
|
|
|
+ // Real errors are hidden from us by the browser
|
|
|
+ // onerror should only fire if it's a network error
|
|
|
+ reject(createError('Network Error', config));
|
|
|
+
|
|
|
+ // Clean up request
|
|
|
+ request = null;
|
|
|
+ };
|
|
|
+
|
|
|
+ // Handle timeout
|
|
|
+ request.ontimeout = function handleTimeout() {
|
|
|
+ reject(createError('timeout of ' + config.timeout + 'ms exceeded', config, 'ECONNABORTED'));
|
|
|
+
|
|
|
+ // Clean up request
|
|
|
+ request = null;
|
|
|
+ };
|
|
|
+
|
|
|
+ // Add xsrf header
|
|
|
+ // This is only done if running in a standard browser environment.
|
|
|
+ // Specifically not if we're in a web worker, or react-native.
|
|
|
+ if (utils.isStandardBrowserEnv()) {
|
|
|
+ var cookies = __webpack_require__(19);
|
|
|
+
|
|
|
+ // Add xsrf header
|
|
|
+ var xsrfValue = (config.withCredentials || isURLSameOrigin(config.url)) && config.xsrfCookieName ?
|
|
|
+ cookies.read(config.xsrfCookieName) :
|
|
|
+ undefined;
|
|
|
+
|
|
|
+ if (xsrfValue) {
|
|
|
+ requestHeaders[config.xsrfHeaderName] = xsrfValue;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ // Add headers to the request
|
|
|
+ if ('setRequestHeader' in request) {
|
|
|
+ utils.forEach(requestHeaders, function setRequestHeader(val, key) {
|
|
|
+ if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {
|
|
|
+ // Remove Content-Type if data is undefined
|
|
|
+ delete requestHeaders[key];
|
|
|
+ } else {
|
|
|
+ // Otherwise add header to the request
|
|
|
+ request.setRequestHeader(key, val);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ // Add withCredentials to request if needed
|
|
|
+ if (config.withCredentials) {
|
|
|
+ request.withCredentials = true;
|
|
|
+ }
|
|
|
+
|
|
|
+ // Add responseType to request if needed
|
|
|
+ if (config.responseType) {
|
|
|
+ try {
|
|
|
+ request.responseType = config.responseType;
|
|
|
+ } catch (e) {
|
|
|
+ // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.
|
|
|
+ // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.
|
|
|
+ if (config.responseType !== 'json') {
|
|
|
+ throw e;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ // Handle progress if needed
|
|
|
+ if (typeof config.onDownloadProgress === 'function') {
|
|
|
+ request.addEventListener('progress', config.onDownloadProgress);
|
|
|
+ }
|
|
|
+
|
|
|
+ // Not all browsers support upload events
|
|
|
+ if (typeof config.onUploadProgress === 'function' && request.upload) {
|
|
|
+ request.upload.addEventListener('progress', config.onUploadProgress);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (config.cancelToken) {
|
|
|
+ // Handle cancellation
|
|
|
+ config.cancelToken.promise.then(function onCanceled(cancel) {
|
|
|
+ if (!request) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ request.abort();
|
|
|
+ reject(cancel);
|
|
|
+ // Clean up request
|
|
|
+ request = null;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ if (requestData === undefined) {
|
|
|
+ requestData = null;
|
|
|
+ }
|
|
|
+
|
|
|
+ // Send the request
|
|
|
+ request.send(requestData);
|
|
|
+ });
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 12 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var createError = __webpack_require__(13);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Resolve or reject a Promise based on response status.
|
|
|
+ *
|
|
|
+ * @param {Function} resolve A function that resolves the promise.
|
|
|
+ * @param {Function} reject A function that rejects the promise.
|
|
|
+ * @param {object} response The response.
|
|
|
+ */
|
|
|
+ module.exports = function settle(resolve, reject, response) {
|
|
|
+ var validateStatus = response.config.validateStatus;
|
|
|
+ // Note: status is not exposed by XDomainRequest
|
|
|
+ if (!response.status || !validateStatus || validateStatus(response.status)) {
|
|
|
+ resolve(response);
|
|
|
+ } else {
|
|
|
+ reject(createError(
|
|
|
+ 'Request failed with status code ' + response.status,
|
|
|
+ response.config,
|
|
|
+ null,
|
|
|
+ response
|
|
|
+ ));
|
|
|
+ }
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 13 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var enhanceError = __webpack_require__(14);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Create an Error with the specified message, config, error code, and response.
|
|
|
+ *
|
|
|
+ * @param {string} message The error message.
|
|
|
+ * @param {Object} config The config.
|
|
|
+ * @param {string} [code] The error code (for example, 'ECONNABORTED').
|
|
|
+ @ @param {Object} [response] The response.
|
|
|
+ * @returns {Error} The created error.
|
|
|
+ */
|
|
|
+ module.exports = function createError(message, config, code, response) {
|
|
|
+ var error = new Error(message);
|
|
|
+ return enhanceError(error, config, code, response);
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 14 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Update an Error with the specified config, error code, and response.
|
|
|
+ *
|
|
|
+ * @param {Error} error The error to update.
|
|
|
+ * @param {Object} config The config.
|
|
|
+ * @param {string} [code] The error code (for example, 'ECONNABORTED').
|
|
|
+ @ @param {Object} [response] The response.
|
|
|
+ * @returns {Error} The error.
|
|
|
+ */
|
|
|
+ module.exports = function enhanceError(error, config, code, response) {
|
|
|
+ error.config = config;
|
|
|
+ if (code) {
|
|
|
+ error.code = code;
|
|
|
+ }
|
|
|
+ error.response = response;
|
|
|
+ return error;
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 15 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+
|
|
|
+ function encode(val) {
|
|
|
+ return encodeURIComponent(val).
|
|
|
+ replace(/%40/gi, '@').
|
|
|
+ replace(/%3A/gi, ':').
|
|
|
+ replace(/%24/g, '$').
|
|
|
+ replace(/%2C/gi, ',').
|
|
|
+ replace(/%20/g, '+').
|
|
|
+ replace(/%5B/gi, '[').
|
|
|
+ replace(/%5D/gi, ']');
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Build a URL by appending params to the end
|
|
|
+ *
|
|
|
+ * @param {string} url The base of the url (e.g., http://www.google.com)
|
|
|
+ * @param {object} [params] The params to be appended
|
|
|
+ * @returns {string} The formatted url
|
|
|
+ */
|
|
|
+ module.exports = function buildURL(url, params, paramsSerializer) {
|
|
|
+ /*eslint no-param-reassign:0*/
|
|
|
+ if (!params) {
|
|
|
+ return url;
|
|
|
+ }
|
|
|
+
|
|
|
+ var serializedParams;
|
|
|
+ if (paramsSerializer) {
|
|
|
+ serializedParams = paramsSerializer(params);
|
|
|
+ } else if (utils.isURLSearchParams(params)) {
|
|
|
+ serializedParams = params.toString();
|
|
|
+ } else {
|
|
|
+ var parts = [];
|
|
|
+
|
|
|
+ utils.forEach(params, function serialize(val, key) {
|
|
|
+ if (val === null || typeof val === 'undefined') {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (utils.isArray(val)) {
|
|
|
+ key = key + '[]';
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!utils.isArray(val)) {
|
|
|
+ val = [val];
|
|
|
+ }
|
|
|
+
|
|
|
+ utils.forEach(val, function parseValue(v) {
|
|
|
+ if (utils.isDate(v)) {
|
|
|
+ v = v.toISOString();
|
|
|
+ } else if (utils.isObject(v)) {
|
|
|
+ v = JSON.stringify(v);
|
|
|
+ }
|
|
|
+ parts.push(encode(key) + '=' + encode(v));
|
|
|
+ });
|
|
|
+ });
|
|
|
+
|
|
|
+ serializedParams = parts.join('&');
|
|
|
+ }
|
|
|
+
|
|
|
+ if (serializedParams) {
|
|
|
+ url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;
|
|
|
+ }
|
|
|
+
|
|
|
+ return url;
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 16 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Parse headers into an object
|
|
|
+ *
|
|
|
+ * ```
|
|
|
+ * Date: Wed, 27 Aug 2014 08:58:49 GMT
|
|
|
+ * Content-Type: application/json
|
|
|
+ * Connection: keep-alive
|
|
|
+ * Transfer-Encoding: chunked
|
|
|
+ * ```
|
|
|
+ *
|
|
|
+ * @param {String} headers Headers needing to be parsed
|
|
|
+ * @returns {Object} Headers parsed into an object
|
|
|
+ */
|
|
|
+ module.exports = function parseHeaders(headers) {
|
|
|
+ var parsed = {};
|
|
|
+ var key;
|
|
|
+ var val;
|
|
|
+ var i;
|
|
|
+
|
|
|
+ if (!headers) { return parsed; }
|
|
|
+
|
|
|
+ utils.forEach(headers.split('\n'), function parser(line) {
|
|
|
+ i = line.indexOf(':');
|
|
|
+ key = utils.trim(line.substr(0, i)).toLowerCase();
|
|
|
+ val = utils.trim(line.substr(i + 1));
|
|
|
+
|
|
|
+ if (key) {
|
|
|
+ parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;
|
|
|
+ }
|
|
|
+ });
|
|
|
+
|
|
|
+ return parsed;
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 17 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+
|
|
|
+ module.exports = (
|
|
|
+ utils.isStandardBrowserEnv() ?
|
|
|
+
|
|
|
+ // Standard browser envs have full support of the APIs needed to test
|
|
|
+ // whether the request URL is of the same origin as current location.
|
|
|
+ (function standardBrowserEnv() {
|
|
|
+ var msie = /(msie|trident)/i.test(navigator.userAgent);
|
|
|
+ var urlParsingNode = document.createElement('a');
|
|
|
+ var originURL;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Parse a URL to discover it's components
|
|
|
+ *
|
|
|
+ * @param {String} url The URL to be parsed
|
|
|
+ * @returns {Object}
|
|
|
+ */
|
|
|
+ function resolveURL(url) {
|
|
|
+ var href = url;
|
|
|
+
|
|
|
+ if (msie) {
|
|
|
+ // IE needs attribute set twice to normalize properties
|
|
|
+ urlParsingNode.setAttribute('href', href);
|
|
|
+ href = urlParsingNode.href;
|
|
|
+ }
|
|
|
+
|
|
|
+ urlParsingNode.setAttribute('href', href);
|
|
|
+
|
|
|
+ // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils
|
|
|
+ return {
|
|
|
+ href: urlParsingNode.href,
|
|
|
+ protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',
|
|
|
+ host: urlParsingNode.host,
|
|
|
+ search: urlParsingNode.search ? urlParsingNode.search.replace(/^\?/, '') : '',
|
|
|
+ hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',
|
|
|
+ hostname: urlParsingNode.hostname,
|
|
|
+ port: urlParsingNode.port,
|
|
|
+ pathname: (urlParsingNode.pathname.charAt(0) === '/') ?
|
|
|
+ urlParsingNode.pathname :
|
|
|
+ '/' + urlParsingNode.pathname
|
|
|
+ };
|
|
|
+ }
|
|
|
+
|
|
|
+ originURL = resolveURL(window.location.href);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determine if a URL shares the same origin as the current location
|
|
|
+ *
|
|
|
+ * @param {String} requestURL The URL to test
|
|
|
+ * @returns {boolean} True if URL shares the same origin, otherwise false
|
|
|
+ */
|
|
|
+ return function isURLSameOrigin(requestURL) {
|
|
|
+ var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;
|
|
|
+ return (parsed.protocol === originURL.protocol &&
|
|
|
+ parsed.host === originURL.host);
|
|
|
+ };
|
|
|
+ })() :
|
|
|
+
|
|
|
+ // Non standard browser envs (web workers, react-native) lack needed support.
|
|
|
+ (function nonStandardBrowserEnv() {
|
|
|
+ return function isURLSameOrigin() {
|
|
|
+ return true;
|
|
|
+ };
|
|
|
+ })()
|
|
|
+ );
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 18 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ // btoa polyfill for IE<10 courtesy https://github.com/davidchambers/Base64.js
|
|
|
+
|
|
|
+ var chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';
|
|
|
+
|
|
|
+ function E() {
|
|
|
+ this.message = 'String contains an invalid character';
|
|
|
+ }
|
|
|
+ E.prototype = new Error;
|
|
|
+ E.prototype.code = 5;
|
|
|
+ E.prototype.name = 'InvalidCharacterError';
|
|
|
+
|
|
|
+ function btoa(input) {
|
|
|
+ var str = String(input);
|
|
|
+ var output = '';
|
|
|
+ for (
|
|
|
+ // initialize result and counter
|
|
|
+ var block, charCode, idx = 0, map = chars;
|
|
|
+ // if the next str index does not exist:
|
|
|
+ // change the mapping table to "="
|
|
|
+ // check if d has no fractional digits
|
|
|
+ str.charAt(idx | 0) || (map = '=', idx % 1);
|
|
|
+ // "8 - idx % 1 * 8" generates the sequence 2, 4, 6, 8
|
|
|
+ output += map.charAt(63 & block >> 8 - idx % 1 * 8)
|
|
|
+ ) {
|
|
|
+ charCode = str.charCodeAt(idx += 3 / 4);
|
|
|
+ if (charCode > 0xFF) {
|
|
|
+ throw new E();
|
|
|
+ }
|
|
|
+ block = block << 8 | charCode;
|
|
|
+ }
|
|
|
+ return output;
|
|
|
+ }
|
|
|
+
|
|
|
+ module.exports = btoa;
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 19 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+
|
|
|
+ module.exports = (
|
|
|
+ utils.isStandardBrowserEnv() ?
|
|
|
+
|
|
|
+ // Standard browser envs support document.cookie
|
|
|
+ (function standardBrowserEnv() {
|
|
|
+ return {
|
|
|
+ write: function write(name, value, expires, path, domain, secure) {
|
|
|
+ var cookie = [];
|
|
|
+ cookie.push(name + '=' + encodeURIComponent(value));
|
|
|
+
|
|
|
+ if (utils.isNumber(expires)) {
|
|
|
+ cookie.push('expires=' + new Date(expires).toGMTString());
|
|
|
+ }
|
|
|
+
|
|
|
+ if (utils.isString(path)) {
|
|
|
+ cookie.push('path=' + path);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (utils.isString(domain)) {
|
|
|
+ cookie.push('domain=' + domain);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (secure === true) {
|
|
|
+ cookie.push('secure');
|
|
|
+ }
|
|
|
+
|
|
|
+ document.cookie = cookie.join('; ');
|
|
|
+ },
|
|
|
+
|
|
|
+ read: function read(name) {
|
|
|
+ var match = document.cookie.match(new RegExp('(^|;\\s*)(' + name + ')=([^;]*)'));
|
|
|
+ return (match ? decodeURIComponent(match[3]) : null);
|
|
|
+ },
|
|
|
+
|
|
|
+ remove: function remove(name) {
|
|
|
+ this.write(name, '', Date.now() - 86400000);
|
|
|
+ }
|
|
|
+ };
|
|
|
+ })() :
|
|
|
+
|
|
|
+ // Non standard browser env (web workers, react-native) lack needed support.
|
|
|
+ (function nonStandardBrowserEnv() {
|
|
|
+ return {
|
|
|
+ write: function write() {},
|
|
|
+ read: function read() { return null; },
|
|
|
+ remove: function remove() {}
|
|
|
+ };
|
|
|
+ })()
|
|
|
+ );
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 20 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+
|
|
|
+ function InterceptorManager() {
|
|
|
+ this.handlers = [];
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Add a new interceptor to the stack
|
|
|
+ *
|
|
|
+ * @param {Function} fulfilled The function to handle `then` for a `Promise`
|
|
|
+ * @param {Function} rejected The function to handle `reject` for a `Promise`
|
|
|
+ *
|
|
|
+ * @return {Number} An ID used to remove interceptor later
|
|
|
+ */
|
|
|
+ InterceptorManager.prototype.use = function use(fulfilled, rejected) {
|
|
|
+ this.handlers.push({
|
|
|
+ fulfilled: fulfilled,
|
|
|
+ rejected: rejected
|
|
|
+ });
|
|
|
+ return this.handlers.length - 1;
|
|
|
+ };
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Remove an interceptor from the stack
|
|
|
+ *
|
|
|
+ * @param {Number} id The ID that was returned by `use`
|
|
|
+ */
|
|
|
+ InterceptorManager.prototype.eject = function eject(id) {
|
|
|
+ if (this.handlers[id]) {
|
|
|
+ this.handlers[id] = null;
|
|
|
+ }
|
|
|
+ };
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Iterate over all the registered interceptors
|
|
|
+ *
|
|
|
+ * This method is particularly useful for skipping over any
|
|
|
+ * interceptors that may have become `null` calling `eject`.
|
|
|
+ *
|
|
|
+ * @param {Function} fn The function to call for each interceptor
|
|
|
+ */
|
|
|
+ InterceptorManager.prototype.forEach = function forEach(fn) {
|
|
|
+ utils.forEach(this.handlers, function forEachHandler(h) {
|
|
|
+ if (h !== null) {
|
|
|
+ fn(h);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ };
|
|
|
+
|
|
|
+ module.exports = InterceptorManager;
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 21 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+ var transformData = __webpack_require__(22);
|
|
|
+ var isCancel = __webpack_require__(23);
|
|
|
+ var defaults = __webpack_require__(9);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Throws a `Cancel` if cancellation has been requested.
|
|
|
+ */
|
|
|
+ function throwIfCancellationRequested(config) {
|
|
|
+ if (config.cancelToken) {
|
|
|
+ config.cancelToken.throwIfRequested();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Dispatch a request to the server using the configured adapter.
|
|
|
+ *
|
|
|
+ * @param {object} config The config that is to be used for the request
|
|
|
+ * @returns {Promise} The Promise to be fulfilled
|
|
|
+ */
|
|
|
+ module.exports = function dispatchRequest(config) {
|
|
|
+ throwIfCancellationRequested(config);
|
|
|
+
|
|
|
+ // Ensure headers exist
|
|
|
+ config.headers = config.headers || {};
|
|
|
+
|
|
|
+ // Transform request data
|
|
|
+ config.data = transformData(
|
|
|
+ config.data,
|
|
|
+ config.headers,
|
|
|
+ config.transformRequest
|
|
|
+ );
|
|
|
+
|
|
|
+ // Flatten headers
|
|
|
+ config.headers = utils.merge(
|
|
|
+ config.headers.common || {},
|
|
|
+ config.headers[config.method] || {},
|
|
|
+ config.headers || {}
|
|
|
+ );
|
|
|
+
|
|
|
+ utils.forEach(
|
|
|
+ ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],
|
|
|
+ function cleanHeaderConfig(method) {
|
|
|
+ delete config.headers[method];
|
|
|
+ }
|
|
|
+ );
|
|
|
+
|
|
|
+ var adapter = config.adapter || defaults.adapter;
|
|
|
+
|
|
|
+ return adapter(config).then(function onAdapterResolution(response) {
|
|
|
+ throwIfCancellationRequested(config);
|
|
|
+
|
|
|
+ // Transform response data
|
|
|
+ response.data = transformData(
|
|
|
+ response.data,
|
|
|
+ response.headers,
|
|
|
+ config.transformResponse
|
|
|
+ );
|
|
|
+
|
|
|
+ return response;
|
|
|
+ }, function onAdapterRejection(reason) {
|
|
|
+ if (!isCancel(reason)) {
|
|
|
+ throwIfCancellationRequested(config);
|
|
|
+
|
|
|
+ // Transform response data
|
|
|
+ if (reason && reason.response) {
|
|
|
+ reason.response.data = transformData(
|
|
|
+ reason.response.data,
|
|
|
+ reason.response.headers,
|
|
|
+ config.transformResponse
|
|
|
+ );
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return Promise.reject(reason);
|
|
|
+ });
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 22 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var utils = __webpack_require__(2);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Transform the data for a request or a response
|
|
|
+ *
|
|
|
+ * @param {Object|String} data The data to be transformed
|
|
|
+ * @param {Array} headers The headers for the request or response
|
|
|
+ * @param {Array|Function} fns A single function or Array of functions
|
|
|
+ * @returns {*} The resulting transformed data
|
|
|
+ */
|
|
|
+ module.exports = function transformData(data, headers, fns) {
|
|
|
+ /*eslint no-param-reassign:0*/
|
|
|
+ utils.forEach(fns, function transform(fn) {
|
|
|
+ data = fn(data, headers);
|
|
|
+ });
|
|
|
+
|
|
|
+ return data;
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 23 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ module.exports = function isCancel(value) {
|
|
|
+ return !!(value && value.__CANCEL__);
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 24 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Determines whether the specified URL is absolute
|
|
|
+ *
|
|
|
+ * @param {string} url The URL to test
|
|
|
+ * @returns {boolean} True if the specified URL is absolute, otherwise false
|
|
|
+ */
|
|
|
+ module.exports = function isAbsoluteURL(url) {
|
|
|
+ // A URL is considered absolute if it begins with "<scheme>://" or "//" (protocol-relative URL).
|
|
|
+ // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed
|
|
|
+ // by any combination of letters, digits, plus, period, or hyphen.
|
|
|
+ return /^([a-z][a-z\d\+\-\.]*:)?\/\//i.test(url);
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 25 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Creates a new URL by combining the specified URLs
|
|
|
+ *
|
|
|
+ * @param {string} baseURL The base URL
|
|
|
+ * @param {string} relativeURL The relative URL
|
|
|
+ * @returns {string} The combined URL
|
|
|
+ */
|
|
|
+ module.exports = function combineURLs(baseURL, relativeURL) {
|
|
|
+ return relativeURL
|
|
|
+ ? baseURL.replace(/\/+$/, '') + '/' + relativeURL.replace(/^\/+/, '')
|
|
|
+ : baseURL;
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 26 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ /**
|
|
|
+ * A `Cancel` is an object that is thrown when an operation is canceled.
|
|
|
+ *
|
|
|
+ * @class
|
|
|
+ * @param {string=} message The message.
|
|
|
+ */
|
|
|
+ function Cancel(message) {
|
|
|
+ this.message = message;
|
|
|
+ }
|
|
|
+
|
|
|
+ Cancel.prototype.toString = function toString() {
|
|
|
+ return 'Cancel' + (this.message ? ': ' + this.message : '');
|
|
|
+ };
|
|
|
+
|
|
|
+ Cancel.prototype.__CANCEL__ = true;
|
|
|
+
|
|
|
+ module.exports = Cancel;
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 27 */
|
|
|
+/***/ function(module, exports, __webpack_require__) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ var Cancel = __webpack_require__(26);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * A `CancelToken` is an object that can be used to request cancellation of an operation.
|
|
|
+ *
|
|
|
+ * @class
|
|
|
+ * @param {Function} executor The executor function.
|
|
|
+ */
|
|
|
+ function CancelToken(executor) {
|
|
|
+ if (typeof executor !== 'function') {
|
|
|
+ throw new TypeError('executor must be a function.');
|
|
|
+ }
|
|
|
+
|
|
|
+ var resolvePromise;
|
|
|
+ this.promise = new Promise(function promiseExecutor(resolve) {
|
|
|
+ resolvePromise = resolve;
|
|
|
+ });
|
|
|
+
|
|
|
+ var token = this;
|
|
|
+ executor(function cancel(message) {
|
|
|
+ if (token.reason) {
|
|
|
+ // Cancellation has already been requested
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ token.reason = new Cancel(message);
|
|
|
+ resolvePromise(token.reason);
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Throws a `Cancel` if cancellation has been requested.
|
|
|
+ */
|
|
|
+ CancelToken.prototype.throwIfRequested = function throwIfRequested() {
|
|
|
+ if (this.reason) {
|
|
|
+ throw this.reason;
|
|
|
+ }
|
|
|
+ };
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Returns an object that contains a new `CancelToken` and a function that, when called,
|
|
|
+ * cancels the `CancelToken`.
|
|
|
+ */
|
|
|
+ CancelToken.source = function source() {
|
|
|
+ var cancel;
|
|
|
+ var token = new CancelToken(function executor(c) {
|
|
|
+ cancel = c;
|
|
|
+ });
|
|
|
+ return {
|
|
|
+ token: token,
|
|
|
+ cancel: cancel
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ module.exports = CancelToken;
|
|
|
+
|
|
|
+
|
|
|
+/***/ },
|
|
|
+/* 28 */
|
|
|
+/***/ function(module, exports) {
|
|
|
+
|
|
|
+ 'use strict';
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Syntactic sugar for invoking a function and expanding an array for arguments.
|
|
|
+ *
|
|
|
+ * Common use case would be to use `Function.prototype.apply`.
|
|
|
+ *
|
|
|
+ * ```js
|
|
|
+ * function f(x, y, z) {}
|
|
|
+ * var args = [1, 2, 3];
|
|
|
+ * f.apply(null, args);
|
|
|
+ * ```
|
|
|
+ *
|
|
|
+ * With `spread` this example can be re-written.
|
|
|
+ *
|
|
|
+ * ```js
|
|
|
+ * spread(function(x, y, z) {})([1, 2, 3]);
|
|
|
+ * ```
|
|
|
+ *
|
|
|
+ * @param {Function} callback
|
|
|
+ * @returns {Function}
|
|
|
+ */
|
|
|
+ module.exports = function spread(callback) {
|
|
|
+ return function wrap(arr) {
|
|
|
+ return callback.apply(null, arr);
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+
|
|
|
+/***/ }
|
|
|
+/******/ ])
|
|
|
+});
|
|
|
+;
|
|
|
+//# sourceMappingURL=axios.map
|