UNPKG

@atlaskit/util-service-support

Version:

A library of support classes for integrating React components with REST HTTP services

127 lines (125 loc) 5.87 kB
import _defineProperty from "@babel/runtime/helpers/defineProperty"; import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator"; import _regeneratorRuntime from "@babel/runtime/regenerator"; function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } import { meros } from 'meros/browser'; import { buildCredentials } from './types'; import { buildHeaders, buildUrl, defaultRequestServiceOptions } from './shared'; import { fg } from '@atlaskit/platform-feature-flags'; import { addFeatureFlagAccessed } from '@atlaskit/react-ufo/feature-flags-accessed'; import { getActiveTraceHttpRequestHeaders } from '@atlaskit/react-ufo/experience-trace-id-context'; /** Copied from meros types, as there are difficulties with resolving the type in CI */ /** * Make a request that **may** result in an HTTP multipart response from the server. * @returns an object with a parsed JSON body OR an object with the parts from * the HTTP multipart response. * * PartsType type parameter specifies the type of the response when the server response * is multipart. * * BodyType specifies the type of the response when the server response is not multipart */ var _requestServiceMultipart = /*#__PURE__*/function () { var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(serviceConfig) { var options, url, securityProvider, refreshedSecurityProvider, path, queryParams, requestInit, secOptions, requestUrl, headers, credentials, TRACING_HEADER_FOR_SERVICE_UTIL, tracingHeaderEnabled, tracingHeaders, requestOptions, fetchResponse, parts, _args = arguments; return _regeneratorRuntime.wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: options = _args.length > 1 && _args[1] !== undefined ? _args[1] : defaultRequestServiceOptions; url = serviceConfig.url, securityProvider = serviceConfig.securityProvider, refreshedSecurityProvider = serviceConfig.refreshedSecurityProvider; path = options.path, queryParams = options.queryParams, requestInit = options.requestInit; secOptions = securityProvider && securityProvider(); requestUrl = buildUrl(url, path, queryParams, secOptions); headers = buildHeaders(secOptions, requestInit && requestInit.headers); credentials = buildCredentials(secOptions); // Get tracing headers from UFO TRACING_HEADER_FOR_SERVICE_UTIL = 'platform_collab_provider_tracingheaders'; tracingHeaderEnabled = fg('platform_collab_provider_tracingheaders'); addFeatureFlagAccessed(TRACING_HEADER_FOR_SERVICE_UTIL, tracingHeaderEnabled); tracingHeaders = {}; if (tracingHeaderEnabled) { tracingHeaders = getActiveTraceHttpRequestHeaders(url); } requestOptions = _objectSpread(_objectSpread({}, requestInit), {}, { // populate headers mainly for the collab provider however // other components which uses this util can get the header as well. // Those tracing headers shall not incur any issues as long as backends handle them properly headers: _objectSpread(_objectSpread({}, headers), tracingHeaders), credentials: credentials }); _context.next = 15; return fetch(requestUrl, requestOptions); case 15: fetchResponse = _context.sent; _context.next = 18; return meros(fetchResponse); case 18: parts = _context.sent; if (!(fetchResponse.ok && fetchResponse.status !== 204)) { _context.next = 28; break; } if (!(parts[Symbol.asyncIterator] < 'u')) { _context.next = 22; break; } return _context.abrupt("return", { isMultipart: true, parts: parts }); case 22: _context.next = 24; return parts.json(); case 24: _context.t0 = _context.sent; return _context.abrupt("return", { isMultipart: false, body: _context.t0 }); case 28: if (!(fetchResponse.status === 401 && refreshedSecurityProvider)) { _context.next = 30; break; } return _context.abrupt("return", refreshedSecurityProvider().then(function (newSecOptions) { var retryServiceConfig = { url: url, securityProvider: function securityProvider() { return newSecOptions; } }; return _requestServiceMultipart(retryServiceConfig, options); })); case 30: return _context.abrupt("return", Promise.reject({ code: fetchResponse.status, reason: fetchResponse.statusText })); case 31: case "end": return _context.stop(); } }, _callee); })); return function requestServiceMultipart(_x) { return _ref.apply(this, arguments); }; }(); export { _requestServiceMultipart as requestServiceMultipart };