[ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 (function (global, factory) { 2 typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : 3 typeof define === 'function' && define.amd ? define(['exports'], factory) : 4 (factory((global.WHATWGFetch = {}))); 5 }(this, (function (exports) { 'use strict'; 6 7 /* eslint-disable no-prototype-builtins */ 8 var g = 9 (typeof globalThis !== 'undefined' && globalThis) || 10 (typeof self !== 'undefined' && self) || 11 // eslint-disable-next-line no-undef 12 (typeof global !== 'undefined' && global) || 13 {}; 14 15 var support = { 16 searchParams: 'URLSearchParams' in g, 17 iterable: 'Symbol' in g && 'iterator' in Symbol, 18 blob: 19 'FileReader' in g && 20 'Blob' in g && 21 (function() { 22 try { 23 new Blob(); 24 return true 25 } catch (e) { 26 return false 27 } 28 })(), 29 formData: 'FormData' in g, 30 arrayBuffer: 'ArrayBuffer' in g 31 }; 32 33 function isDataView(obj) { 34 return obj && DataView.prototype.isPrototypeOf(obj) 35 } 36 37 if (support.arrayBuffer) { 38 var viewClasses = [ 39 '[object Int8Array]', 40 '[object Uint8Array]', 41 '[object Uint8ClampedArray]', 42 '[object Int16Array]', 43 '[object Uint16Array]', 44 '[object Int32Array]', 45 '[object Uint32Array]', 46 '[object Float32Array]', 47 '[object Float64Array]' 48 ]; 49 50 var isArrayBufferView = 51 ArrayBuffer.isView || 52 function(obj) { 53 return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1 54 }; 55 } 56 57 function normalizeName(name) { 58 if (typeof name !== 'string') { 59 name = String(name); 60 } 61 if (/[^a-z0-9\-#$%&'*+.^_`|~!]/i.test(name) || name === '') { 62 throw new TypeError('Invalid character in header field name: "' + name + '"') 63 } 64 return name.toLowerCase() 65 } 66 67 function normalizeValue(value) { 68 if (typeof value !== 'string') { 69 value = String(value); 70 } 71 return value 72 } 73 74 // Build a destructive iterator for the value list 75 function iteratorFor(items) { 76 var iterator = { 77 next: function() { 78 var value = items.shift(); 79 return {done: value === undefined, value: value} 80 } 81 }; 82 83 if (support.iterable) { 84 iterator[Symbol.iterator] = function() { 85 return iterator 86 }; 87 } 88 89 return iterator 90 } 91 92 function Headers(headers) { 93 this.map = {}; 94 95 if (headers instanceof Headers) { 96 headers.forEach(function(value, name) { 97 this.append(name, value); 98 }, this); 99 } else if (Array.isArray(headers)) { 100 headers.forEach(function(header) { 101 if (header.length != 2) { 102 throw new TypeError('Headers constructor: expected name/value pair to be length 2, found' + header.length) 103 } 104 this.append(header[0], header[1]); 105 }, this); 106 } else if (headers) { 107 Object.getOwnPropertyNames(headers).forEach(function(name) { 108 this.append(name, headers[name]); 109 }, this); 110 } 111 } 112 113 Headers.prototype.append = function(name, value) { 114 name = normalizeName(name); 115 value = normalizeValue(value); 116 var oldValue = this.map[name]; 117 this.map[name] = oldValue ? oldValue + ', ' + value : value; 118 }; 119 120 Headers.prototype['delete'] = function(name) { 121 delete this.map[normalizeName(name)]; 122 }; 123 124 Headers.prototype.get = function(name) { 125 name = normalizeName(name); 126 return this.has(name) ? this.map[name] : null 127 }; 128 129 Headers.prototype.has = function(name) { 130 return this.map.hasOwnProperty(normalizeName(name)) 131 }; 132 133 Headers.prototype.set = function(name, value) { 134 this.map[normalizeName(name)] = normalizeValue(value); 135 }; 136 137 Headers.prototype.forEach = function(callback, thisArg) { 138 for (var name in this.map) { 139 if (this.map.hasOwnProperty(name)) { 140 callback.call(thisArg, this.map[name], name, this); 141 } 142 } 143 }; 144 145 Headers.prototype.keys = function() { 146 var items = []; 147 this.forEach(function(value, name) { 148 items.push(name); 149 }); 150 return iteratorFor(items) 151 }; 152 153 Headers.prototype.values = function() { 154 var items = []; 155 this.forEach(function(value) { 156 items.push(value); 157 }); 158 return iteratorFor(items) 159 }; 160 161 Headers.prototype.entries = function() { 162 var items = []; 163 this.forEach(function(value, name) { 164 items.push([name, value]); 165 }); 166 return iteratorFor(items) 167 }; 168 169 if (support.iterable) { 170 Headers.prototype[Symbol.iterator] = Headers.prototype.entries; 171 } 172 173 function consumed(body) { 174 if (body._noBody) return 175 if (body.bodyUsed) { 176 return Promise.reject(new TypeError('Already read')) 177 } 178 body.bodyUsed = true; 179 } 180 181 function fileReaderReady(reader) { 182 return new Promise(function(resolve, reject) { 183 reader.onload = function() { 184 resolve(reader.result); 185 }; 186 reader.onerror = function() { 187 reject(reader.error); 188 }; 189 }) 190 } 191 192 function readBlobAsArrayBuffer(blob) { 193 var reader = new FileReader(); 194 var promise = fileReaderReady(reader); 195 reader.readAsArrayBuffer(blob); 196 return promise 197 } 198 199 function readBlobAsText(blob) { 200 var reader = new FileReader(); 201 var promise = fileReaderReady(reader); 202 var match = /charset=([A-Za-z0-9_-]+)/.exec(blob.type); 203 var encoding = match ? match[1] : 'utf-8'; 204 reader.readAsText(blob, encoding); 205 return promise 206 } 207 208 function readArrayBufferAsText(buf) { 209 var view = new Uint8Array(buf); 210 var chars = new Array(view.length); 211 212 for (var i = 0; i < view.length; i++) { 213 chars[i] = String.fromCharCode(view[i]); 214 } 215 return chars.join('') 216 } 217 218 function bufferClone(buf) { 219 if (buf.slice) { 220 return buf.slice(0) 221 } else { 222 var view = new Uint8Array(buf.byteLength); 223 view.set(new Uint8Array(buf)); 224 return view.buffer 225 } 226 } 227 228 function Body() { 229 this.bodyUsed = false; 230 231 this._initBody = function(body) { 232 /* 233 fetch-mock wraps the Response object in an ES6 Proxy to 234 provide useful test harness features such as flush. However, on 235 ES5 browsers without fetch or Proxy support pollyfills must be used; 236 the proxy-pollyfill is unable to proxy an attribute unless it exists 237 on the object before the Proxy is created. This change ensures 238 Response.bodyUsed exists on the instance, while maintaining the 239 semantic of setting Request.bodyUsed in the constructor before 240 _initBody is called. 241 */ 242 // eslint-disable-next-line no-self-assign 243 this.bodyUsed = this.bodyUsed; 244 this._bodyInit = body; 245 if (!body) { 246 this._noBody = true; 247 this._bodyText = ''; 248 } else if (typeof body === 'string') { 249 this._bodyText = body; 250 } else if (support.blob && Blob.prototype.isPrototypeOf(body)) { 251 this._bodyBlob = body; 252 } else if (support.formData && FormData.prototype.isPrototypeOf(body)) { 253 this._bodyFormData = body; 254 } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) { 255 this._bodyText = body.toString(); 256 } else if (support.arrayBuffer && support.blob && isDataView(body)) { 257 this._bodyArrayBuffer = bufferClone(body.buffer); 258 // IE 10-11 can't handle a DataView body. 259 this._bodyInit = new Blob([this._bodyArrayBuffer]); 260 } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) { 261 this._bodyArrayBuffer = bufferClone(body); 262 } else { 263 this._bodyText = body = Object.prototype.toString.call(body); 264 } 265 266 if (!this.headers.get('content-type')) { 267 if (typeof body === 'string') { 268 this.headers.set('content-type', 'text/plain;charset=UTF-8'); 269 } else if (this._bodyBlob && this._bodyBlob.type) { 270 this.headers.set('content-type', this._bodyBlob.type); 271 } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) { 272 this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8'); 273 } 274 } 275 }; 276 277 if (support.blob) { 278 this.blob = function() { 279 var rejected = consumed(this); 280 if (rejected) { 281 return rejected 282 } 283 284 if (this._bodyBlob) { 285 return Promise.resolve(this._bodyBlob) 286 } else if (this._bodyArrayBuffer) { 287 return Promise.resolve(new Blob([this._bodyArrayBuffer])) 288 } else if (this._bodyFormData) { 289 throw new Error('could not read FormData body as blob') 290 } else { 291 return Promise.resolve(new Blob([this._bodyText])) 292 } 293 }; 294 } 295 296 this.arrayBuffer = function() { 297 if (this._bodyArrayBuffer) { 298 var isConsumed = consumed(this); 299 if (isConsumed) { 300 return isConsumed 301 } else if (ArrayBuffer.isView(this._bodyArrayBuffer)) { 302 return Promise.resolve( 303 this._bodyArrayBuffer.buffer.slice( 304 this._bodyArrayBuffer.byteOffset, 305 this._bodyArrayBuffer.byteOffset + this._bodyArrayBuffer.byteLength 306 ) 307 ) 308 } else { 309 return Promise.resolve(this._bodyArrayBuffer) 310 } 311 } else if (support.blob) { 312 return this.blob().then(readBlobAsArrayBuffer) 313 } else { 314 throw new Error('could not read as ArrayBuffer') 315 } 316 }; 317 318 this.text = function() { 319 var rejected = consumed(this); 320 if (rejected) { 321 return rejected 322 } 323 324 if (this._bodyBlob) { 325 return readBlobAsText(this._bodyBlob) 326 } else if (this._bodyArrayBuffer) { 327 return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer)) 328 } else if (this._bodyFormData) { 329 throw new Error('could not read FormData body as text') 330 } else { 331 return Promise.resolve(this._bodyText) 332 } 333 }; 334 335 if (support.formData) { 336 this.formData = function() { 337 return this.text().then(decode) 338 }; 339 } 340 341 this.json = function() { 342 return this.text().then(JSON.parse) 343 }; 344 345 return this 346 } 347 348 // HTTP methods whose capitalization should be normalized 349 var methods = ['CONNECT', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT', 'TRACE']; 350 351 function normalizeMethod(method) { 352 var upcased = method.toUpperCase(); 353 return methods.indexOf(upcased) > -1 ? upcased : method 354 } 355 356 function Request(input, options) { 357 if (!(this instanceof Request)) { 358 throw new TypeError('Please use the "new" operator, this DOM object constructor cannot be called as a function.') 359 } 360 361 options = options || {}; 362 var body = options.body; 363 364 if (input instanceof Request) { 365 if (input.bodyUsed) { 366 throw new TypeError('Already read') 367 } 368 this.url = input.url; 369 this.credentials = input.credentials; 370 if (!options.headers) { 371 this.headers = new Headers(input.headers); 372 } 373 this.method = input.method; 374 this.mode = input.mode; 375 this.signal = input.signal; 376 if (!body && input._bodyInit != null) { 377 body = input._bodyInit; 378 input.bodyUsed = true; 379 } 380 } else { 381 this.url = String(input); 382 } 383 384 this.credentials = options.credentials || this.credentials || 'same-origin'; 385 if (options.headers || !this.headers) { 386 this.headers = new Headers(options.headers); 387 } 388 this.method = normalizeMethod(options.method || this.method || 'GET'); 389 this.mode = options.mode || this.mode || null; 390 this.signal = options.signal || this.signal || (function () { 391 if ('AbortController' in g) { 392 var ctrl = new AbortController(); 393 return ctrl.signal; 394 } 395 }()); 396 this.referrer = null; 397 398 if ((this.method === 'GET' || this.method === 'HEAD') && body) { 399 throw new TypeError('Body not allowed for GET or HEAD requests') 400 } 401 this._initBody(body); 402 403 if (this.method === 'GET' || this.method === 'HEAD') { 404 if (options.cache === 'no-store' || options.cache === 'no-cache') { 405 // Search for a '_' parameter in the query string 406 var reParamSearch = /([?&])_=[^&]*/; 407 if (reParamSearch.test(this.url)) { 408 // If it already exists then set the value with the current time 409 this.url = this.url.replace(reParamSearch, '$1_=' + new Date().getTime()); 410 } else { 411 // Otherwise add a new '_' parameter to the end with the current time 412 var reQueryString = /\?/; 413 this.url += (reQueryString.test(this.url) ? '&' : '?') + '_=' + new Date().getTime(); 414 } 415 } 416 } 417 } 418 419 Request.prototype.clone = function() { 420 return new Request(this, {body: this._bodyInit}) 421 }; 422 423 function decode(body) { 424 var form = new FormData(); 425 body 426 .trim() 427 .split('&') 428 .forEach(function(bytes) { 429 if (bytes) { 430 var split = bytes.split('='); 431 var name = split.shift().replace(/\+/g, ' '); 432 var value = split.join('=').replace(/\+/g, ' '); 433 form.append(decodeURIComponent(name), decodeURIComponent(value)); 434 } 435 }); 436 return form 437 } 438 439 function parseHeaders(rawHeaders) { 440 var headers = new Headers(); 441 // Replace instances of \r\n and \n followed by at least one space or horizontal tab with a space 442 // https://tools.ietf.org/html/rfc7230#section-3.2 443 var preProcessedHeaders = rawHeaders.replace(/\r?\n[\t ]+/g, ' '); 444 // Avoiding split via regex to work around a common IE11 bug with the core-js 3.6.0 regex polyfill 445 // https://github.com/github/fetch/issues/748 446 // https://github.com/zloirock/core-js/issues/751 447 preProcessedHeaders 448 .split('\r') 449 .map(function(header) { 450 return header.indexOf('\n') === 0 ? header.substr(1, header.length) : header 451 }) 452 .forEach(function(line) { 453 var parts = line.split(':'); 454 var key = parts.shift().trim(); 455 if (key) { 456 var value = parts.join(':').trim(); 457 try { 458 headers.append(key, value); 459 } catch (error) { 460 console.warn('Response ' + error.message); 461 } 462 } 463 }); 464 return headers 465 } 466 467 Body.call(Request.prototype); 468 469 function Response(bodyInit, options) { 470 if (!(this instanceof Response)) { 471 throw new TypeError('Please use the "new" operator, this DOM object constructor cannot be called as a function.') 472 } 473 if (!options) { 474 options = {}; 475 } 476 477 this.type = 'default'; 478 this.status = options.status === undefined ? 200 : options.status; 479 if (this.status < 200 || this.status > 599) { 480 throw new RangeError("Failed to construct 'Response': The status provided (0) is outside the range [200, 599].") 481 } 482 this.ok = this.status >= 200 && this.status < 300; 483 this.statusText = options.statusText === undefined ? '' : '' + options.statusText; 484 this.headers = new Headers(options.headers); 485 this.url = options.url || ''; 486 this._initBody(bodyInit); 487 } 488 489 Body.call(Response.prototype); 490 491 Response.prototype.clone = function() { 492 return new Response(this._bodyInit, { 493 status: this.status, 494 statusText: this.statusText, 495 headers: new Headers(this.headers), 496 url: this.url 497 }) 498 }; 499 500 Response.error = function() { 501 var response = new Response(null, {status: 200, statusText: ''}); 502 response.ok = false; 503 response.status = 0; 504 response.type = 'error'; 505 return response 506 }; 507 508 var redirectStatuses = [301, 302, 303, 307, 308]; 509 510 Response.redirect = function(url, status) { 511 if (redirectStatuses.indexOf(status) === -1) { 512 throw new RangeError('Invalid status code') 513 } 514 515 return new Response(null, {status: status, headers: {location: url}}) 516 }; 517 518 exports.DOMException = g.DOMException; 519 try { 520 new exports.DOMException(); 521 } catch (err) { 522 exports.DOMException = function(message, name) { 523 this.message = message; 524 this.name = name; 525 var error = Error(message); 526 this.stack = error.stack; 527 }; 528 exports.DOMException.prototype = Object.create(Error.prototype); 529 exports.DOMException.prototype.constructor = exports.DOMException; 530 } 531 532 function fetch(input, init) { 533 return new Promise(function(resolve, reject) { 534 var request = new Request(input, init); 535 536 if (request.signal && request.signal.aborted) { 537 return reject(new exports.DOMException('Aborted', 'AbortError')) 538 } 539 540 var xhr = new XMLHttpRequest(); 541 542 function abortXhr() { 543 xhr.abort(); 544 } 545 546 xhr.onload = function() { 547 var options = { 548 statusText: xhr.statusText, 549 headers: parseHeaders(xhr.getAllResponseHeaders() || '') 550 }; 551 // This check if specifically for when a user fetches a file locally from the file system 552 // Only if the status is out of a normal range 553 if (request.url.indexOf('file://') === 0 && (xhr.status < 200 || xhr.status > 599)) { 554 options.status = 200; 555 } else { 556 options.status = xhr.status; 557 } 558 options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL'); 559 var body = 'response' in xhr ? xhr.response : xhr.responseText; 560 setTimeout(function() { 561 resolve(new Response(body, options)); 562 }, 0); 563 }; 564 565 xhr.onerror = function() { 566 setTimeout(function() { 567 reject(new TypeError('Network request failed')); 568 }, 0); 569 }; 570 571 xhr.ontimeout = function() { 572 setTimeout(function() { 573 reject(new TypeError('Network request timed out')); 574 }, 0); 575 }; 576 577 xhr.onabort = function() { 578 setTimeout(function() { 579 reject(new exports.DOMException('Aborted', 'AbortError')); 580 }, 0); 581 }; 582 583 function fixUrl(url) { 584 try { 585 return url === '' && g.location.href ? g.location.href : url 586 } catch (e) { 587 return url 588 } 589 } 590 591 xhr.open(request.method, fixUrl(request.url), true); 592 593 if (request.credentials === 'include') { 594 xhr.withCredentials = true; 595 } else if (request.credentials === 'omit') { 596 xhr.withCredentials = false; 597 } 598 599 if ('responseType' in xhr) { 600 if (support.blob) { 601 xhr.responseType = 'blob'; 602 } else if ( 603 support.arrayBuffer 604 ) { 605 xhr.responseType = 'arraybuffer'; 606 } 607 } 608 609 if (init && typeof init.headers === 'object' && !(init.headers instanceof Headers || (g.Headers && init.headers instanceof g.Headers))) { 610 var names = []; 611 Object.getOwnPropertyNames(init.headers).forEach(function(name) { 612 names.push(normalizeName(name)); 613 xhr.setRequestHeader(name, normalizeValue(init.headers[name])); 614 }); 615 request.headers.forEach(function(value, name) { 616 if (names.indexOf(name) === -1) { 617 xhr.setRequestHeader(name, value); 618 } 619 }); 620 } else { 621 request.headers.forEach(function(value, name) { 622 xhr.setRequestHeader(name, value); 623 }); 624 } 625 626 if (request.signal) { 627 request.signal.addEventListener('abort', abortXhr); 628 629 xhr.onreadystatechange = function() { 630 // DONE (success or failure) 631 if (xhr.readyState === 4) { 632 request.signal.removeEventListener('abort', abortXhr); 633 } 634 }; 635 } 636 637 xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit); 638 }) 639 } 640 641 fetch.polyfill = true; 642 643 if (!g.fetch) { 644 g.fetch = fetch; 645 g.Headers = Headers; 646 g.Request = Request; 647 g.Response = Response; 648 } 649 650 exports.Headers = Headers; 651 exports.Request = Request; 652 exports.Response = Response; 653 exports.fetch = fetch; 654 655 Object.defineProperty(exports, '__esModule', { value: true }); 656 657 })));
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated : Tue Jan 21 08:20:01 2025 | Cross-referenced by PHPXref |