openstack-uicore-foundation 5.0.3 → 5.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/lib/components/attendance-tracker.js.map +1 -1
  2. package/lib/components/clock.js.map +1 -1
  3. package/lib/components/extra-questions.js.map +1 -1
  4. package/lib/components/forms/simple-form.js.map +1 -1
  5. package/lib/components/free-text-search.js.map +1 -1
  6. package/lib/components/google-map.js.map +1 -1
  7. package/lib/components/index.js +1 -1
  8. package/lib/components/index.js.map +1 -1
  9. package/lib/components/inputs/access-levels-input.js.map +1 -1
  10. package/lib/components/inputs/attendee-input.js.map +1 -1
  11. package/lib/components/inputs/company-input-v2.js.map +1 -1
  12. package/lib/components/inputs/company-input.js.map +1 -1
  13. package/lib/components/inputs/country-dropdown.js.map +1 -1
  14. package/lib/components/inputs/country-input.js.map +1 -1
  15. package/lib/components/inputs/event-input.js.map +1 -1
  16. package/lib/components/inputs/group-input.js.map +1 -1
  17. package/lib/components/inputs/language-input.js.map +1 -1
  18. package/lib/components/inputs/member-input.js.map +1 -1
  19. package/lib/components/inputs/organization-input.js.map +1 -1
  20. package/lib/components/inputs/promocode-input.js.map +1 -1
  21. package/lib/components/inputs/registration-company-input.js.map +1 -1
  22. package/lib/components/inputs/speaker-input.js.map +1 -1
  23. package/lib/components/inputs/sponsor-input.js.map +1 -1
  24. package/lib/components/inputs/summit-input.js.map +1 -1
  25. package/lib/components/inputs/tag-input.js.map +1 -1
  26. package/lib/components/inputs/ticket-types-input.js.map +1 -1
  27. package/lib/components/inputs/upload-input-v2.js.map +1 -1
  28. package/lib/components/inputs/upload-input-v3.js.map +1 -1
  29. package/lib/components/mui/dropdown-checkbox.js +1 -1
  30. package/lib/components/mui/dropdown-checkbox.js.map +1 -1
  31. package/lib/components/mui/editable-table.js +1 -1
  32. package/lib/components/mui/editable-table.js.map +1 -1
  33. package/lib/components/mui/formik-inputs/additional-input-list.js +1 -1
  34. package/lib/components/mui/formik-inputs/additional-input-list.js.map +1 -1
  35. package/lib/components/mui/formik-inputs/additional-input.js +1 -1
  36. package/lib/components/mui/formik-inputs/additional-input.js.map +1 -1
  37. package/lib/components/mui/formik-inputs/company-input.js.map +1 -1
  38. package/lib/components/mui/formik-inputs/item-price-tiers.js.map +1 -1
  39. package/lib/components/mui/formik-inputs/sponsor-input.js.map +1 -1
  40. package/lib/components/mui/formik-inputs/sponsorship-input.js.map +1 -1
  41. package/lib/components/mui/formik-inputs/sponsorship-summit-select.js.map +1 -1
  42. package/lib/components/mui/formik-inputs/summit-addon-select.js.map +1 -1
  43. package/lib/components/mui/formik-inputs/upload.js.map +1 -1
  44. package/lib/components/mui/show-confirm-dialog.js +1 -1
  45. package/lib/components/mui/show-confirm-dialog.js.map +1 -1
  46. package/lib/components/mui/snackbar-notification.js +1 -1
  47. package/lib/components/mui/snackbar-notification.js.map +1 -1
  48. package/lib/components/mui/sortable-table.js +1 -1
  49. package/lib/components/mui/sortable-table.js.map +1 -1
  50. package/lib/components/mui/sponsor-addon-select.js.map +1 -1
  51. package/lib/components/mui/summit-addon-select.js.map +1 -1
  52. package/lib/components/mui/summits-dropdown.js.map +1 -1
  53. package/lib/components/mui/table.js +1 -1
  54. package/lib/components/mui/table.js.map +1 -1
  55. package/lib/components/schedule-builder-view.js.map +1 -1
  56. package/lib/components/sponsored-project-input.js.map +1 -1
  57. package/lib/components/summit-dropdown.js +1 -1
  58. package/lib/components/summit-dropdown.js.map +1 -1
  59. package/lib/components/table-editable.js.map +1 -1
  60. package/lib/i18n.js.map +1 -1
  61. package/lib/security/abstract-auth-callback-route-v2.js.map +1 -1
  62. package/lib/security/abstract-auth-callback-route.js.map +1 -1
  63. package/lib/security/actions.js.map +1 -1
  64. package/lib/security/methods.js.map +1 -1
  65. package/lib/security/reducers.js.map +1 -1
  66. package/lib/security/session-checker.js.map +1 -1
  67. package/lib/utils/actions.js.map +1 -1
  68. package/lib/utils/methods.js +1 -1
  69. package/lib/utils/methods.js.map +1 -1
  70. package/lib/utils/query-actions.js.map +1 -1
  71. package/lib/utils/questions-set.js.map +1 -1
  72. package/package.json +2 -3
@@ -1 +1 @@
1
- {"version":3,"file":"components/inputs/group-input.js","mappings":"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","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/./src/components/security/constants.js","webpack://openstack-uicore-foundation/external commonjs \"browser-tabs-lock\"","webpack://openstack-uicore-foundation/external commonjs \"js-cookie\"","webpack://openstack-uicore-foundation/./src/components/security/methods.js","webpack://openstack-uicore-foundation/./src/utils/actions.js","webpack://openstack-uicore-foundation/./src/utils/constants.js","webpack://openstack-uicore-foundation/external commonjs \"spark-md5\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/sha256\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/enc-base64url\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/enc-hex\"","webpack://openstack-uicore-foundation/./src/utils/crypto.js","webpack://openstack-uicore-foundation/./src/utils/methods.js","webpack://openstack-uicore-foundation/./src/utils/query-actions.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/defineProperty\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/extends\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/objectWithoutProperties\"","webpack://openstack-uicore-foundation/external commonjs \"i18n-react/dist/i18n-react\"","webpack://openstack-uicore-foundation/external commonjs \"idtoken-verifier\"","webpack://openstack-uicore-foundation/external commonjs \"lodash\"","webpack://openstack-uicore-foundation/external commonjs \"moment-timezone\"","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/external commonjs \"react-select/lib/Async\"","webpack://openstack-uicore-foundation/external commonjs \"superagent/lib/client\"","webpack://openstack-uicore-foundation/external commonjs \"sweetalert2\"","webpack://openstack-uicore-foundation/external commonjs \"urijs\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/./src/components/inputs/group-input.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","export const AUTH_ERROR_MISSING_AUTH_INFO = 'AUTH_ERROR_MISSING_AUTH_INFO';\nexport const AUTH_ERROR_MISSING_REFRESH_TOKEN = 'AUTH_ERROR_MISSING_REFRESH_TOKEN';\nexport const AUTH_ERROR_ACCESS_TOKEN_EXPIRED = 'AUTH_ERROR_ACCESS_TOKEN_EXPIRED';\nexport const AUTH_ERROR_LOCK_ACQUIRE_ERROR = 'AUTH_ERROR_LOCK_ACQUIRE_ERROR'\nexport const AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR = 'AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR';\nexport const AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR = 'AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR';\nexport const AUTH_ERROR_ID_TOKEN_INVALID = 'AUTH_ERROR_ID_TOKEN_INVALID';\nexport const AUTH_ERROR_MISSING_OTP_PARAM = 'AUTH_ERROR_MISSING_OTP_PARAM';\nexport const AUTH_ERROR_MISSING_PKCE_PARAM = 'AUTH_ERROR_MISSING_PKCE_PARAM';\nexport const AUTH_ERROR_MISSING_NONCE_PARAM = 'AUTH_ERROR_MISSING_NONCE_PARAM';\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"browser-tabs-lock\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"js-cookie\");","import {\n base64URLEncode,\n getAuthCallback,\n getCurrentLocation,\n getFromLocalStorage,\n removeFromLocalStorage,\n getOrigin,\n putOnLocalStorage,\n retryPromise,\n setSessionClearingState,\n} from \"../../utils/methods\";\nimport moment from \"moment-timezone\";\nimport request from 'superagent/lib/client';\nimport SuperTokensLock from 'browser-tabs-lock';\nimport Cookies from 'js-cookie'\nlet http = request;\nimport URI from \"urijs\";\nimport IdTokenVerifier from \"idtoken-verifier\";\nimport {SET_LOGGED_USER} from \"./actions\";\nimport {getRandomBytes, getSHA256} from \"../../utils/crypto\";\n\nimport {\n AUTH_ERROR_ACCESS_TOKEN_EXPIRED,\n AUTH_ERROR_MISSING_AUTH_INFO,\n AUTH_ERROR_MISSING_REFRESH_TOKEN,\n AUTH_ERROR_LOCK_ACQUIRE_ERROR,\n AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR,\n AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR,\n AUTH_ERROR_ID_TOKEN_INVALID,\n AUTH_ERROR_MISSING_OTP_PARAM,\n AUTH_ERROR_MISSING_PKCE_PARAM,\n AUTH_ERROR_MISSING_NONCE_PARAM,\n} from \"./constants\";\n\n/**\n * @ignore\n */\nconst Lock = new SuperTokensLock();\n/**\n * @ignore\n */\nconst GET_TOKEN_SILENTLY_LOCK_KEY = 'openstackuicore.lock.getTokenSilently';\nconst GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT = 6000;\nconst NONCE_LEN = 16;\nexport const ACCESS_TOKEN_SKEW_TIME = 60;\nexport const RESPONSE_TYPE_IMPLICIT = \"token id_token\";\nexport const RESPONSE_TYPE_CODE = 'code';\nconst AUTH_INFO = 'authInfo';\nconst NONCE = 'nonce';\nconst PKCE = 'pkce';\nconst ID_TOKEN = 'idToken';\nconst BACK_ULR_PARAM_NAME = 'BackUrl';\n\n\n/**\n *\n * @param backUrl\n * @param prompt\n * @param tokenIdHint\n * @param provider\n * @param loginHint\n * @param otpLoginHint\n * @param tenant\n * @param backUrlParamName\n * @returns {*}\n */\nexport const getAuthUrl = (\n backUrl = null,\n prompt = null,\n tokenIdHint = null,\n provider = null,\n loginHint = null,\n otpLoginHint = null,\n tenant = null,\n backUrlParamName = BACK_ULR_PARAM_NAME\n ) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let redirectUri = getAuthCallback();\n let baseUrl = getOAuth2IDPBaseUrl();\n let scopes = getOAuth2Scopes();\n let flow = getOAuth2Flow();\n\n if (backUrl != null)\n redirectUri += `?${backUrlParamName}=${encodeURIComponent(backUrl)}`;\n\n let nonce = createNonce(NONCE_LEN);\n\n // store nonce to check it later\n putOnLocalStorage(NONCE, nonce);\n let url = URI(`${baseUrl}/oauth2/auth`);\n\n let query = {\n \"response_type\": encodeURI(flow),\n \"scope\": encodeURI(scopes),\n \"nonce\": nonce,\n \"response_mode\": 'fragment',\n \"client_id\": encodeURI(oauth2ClientId),\n \"redirect_uri\": encodeURI(redirectUri)\n };\n\n if (flow === RESPONSE_TYPE_CODE) {\n const pkce = createPKCECodes()\n putOnLocalStorage(PKCE, JSON.stringify(pkce));\n query['code_challenge'] = pkce.codeChallenge;\n query['code_challenge_method'] = 'S256';\n query['approval_prompt'] = 'force';\n }\n\n if (prompt) {\n query['prompt'] = prompt;\n }\n\n if (scopes && scopes.includes('offline_access')) {\n // then we need to force prompt=consent bc we are requesting an offline access\n // and we need to let the user know\n query['prompt'] = 'consent';\n }\n\n if (tokenIdHint) {\n query['id_token_hint'] = tokenIdHint;\n }\n\n if (provider) {\n query['provider'] = provider;\n }\n\n if (otpLoginHint) {\n query['otp_login_hint'] = otpLoginHint;\n }\n\n if (loginHint) {\n query['login_hint'] = encodeURI(loginHint);\n }\n\n if (tenant) {\n query['tenant'] = tenant;\n }\n\n url = url.query(query);\n //console.log(`getAuthUrl ${url.toString()}`);\n return url;\n}\n\n/**\n * @param idToken\n * @returns {*}\n */\nexport const getLogoutUrl = (idToken = null) => {\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n let url = URI(`${baseUrl}/oauth2/end-session`);\n let state = createNonce(NONCE_LEN);\n let postLogOutUri = `${getOrigin()}/auth/logout`;\n // store nonce to check it later\n putOnLocalStorage('post_logout_state', state);\n /**\n * post_logout_redirect_uri should be listed on oauth2 client settings\n * on IDP\n * \"Security Settings\" Tab -> Logout Options -> Post Logout Uris\n */\n const queryParams = {\n \"post_logout_redirect_uri\": encodeURI(postLogOutUri),\n \"client_id\": encodeURI(oauth2ClientId),\n \"state\": state,\n }\n\n if (idToken)\n queryParams.id_token_hint = idToken;\n\n return url.query(queryParams);\n}\n\nconst createNonce = (len) => {\n let possible = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\";\n let nonce = '';\n for (let i = 0; i < len; i++) {\n nonce += possible.charAt(Math.floor(Math.random() * possible.length));\n }\n return nonce;\n}\n\n/**\n *\n * @param backUrl\n * @param provider\n * @param prompt\n * @param loginHint\n * @param otpLoginHint\n * @param tenant\n */\nexport const doLogin = (\n backUrl = null,\n provider = null,\n prompt = null,\n loginHint = null,\n otpLoginHint = null,\n tenant = null\n) => {\n let url = getAuthUrl(backUrl, prompt, null, provider, loginHint, otpLoginHint, tenant);\n let location = getCurrentLocation()\n location.replace(url.toString());\n}\n\n/**\n *\n * @param backUrl\n * @param loginHint\n * @param otpLoginHint\n */\nexport const doLoginBasicLogin = (backUrl = null, loginHint = null, otpLoginHint = null) => {\n doLogin(backUrl, null, null, loginHint, otpLoginHint);\n}\n\nconst createPKCECodes = () => {\n const codeVerifier = base64URLEncode(getRandomBytes(64))\n const codeChallenge = getSHA256(codeVerifier, 'Base64url')\n const createdAt = new Date()\n const codePair = {\n codeVerifier,\n codeChallenge,\n createdAt\n }\n return codePair\n}\n\n/**\n\n * @param code\n * @param backUrl\n * @param backUrlParamName\n * @returns {Promise<{access_token: *, refresh_token: *, id_token: *, expires_in: *, error: *, error_description: *}>}\n */\nexport const emitAccessToken = async (code, backUrl = null, backUrlParamName = BACK_ULR_PARAM_NAME) => {\n\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n let redirectUri = getAuthCallback();\n let pkce = JSON.parse(getFromLocalStorage(PKCE, true));\n\n if (!pkce)\n throw Error(AUTH_ERROR_MISSING_PKCE_PARAM);\n\n if (backUrl != null)\n redirectUri += `?${backUrlParamName}=${encodeURIComponent(backUrl)}`;\n\n const payload = {\n 'code': code,\n 'grant_type': 'authorization_code',\n 'code_verifier': pkce.codeVerifier,\n \"client_id\": encodeURI(oauth2ClientId),\n \"redirect_uri\": encodeURI(redirectUri)\n };\n\n try {\n //const response = await http.post(`${baseUrl}/oauth2/token`, payload);\n //const {body: {access_token, refresh_token, id_token, expires_in}} = response;\n const response = await fetch(`${baseUrl}/oauth2/token`, {\n method: 'POST',\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(payload)\n }).catch(function (error) {\n console.log('Request failed:', error.message);\n });\n const json = await response.json();\n let {access_token, refresh_token, id_token, expires_in, error, error_description} = json;\n return {access_token, refresh_token, id_token, expires_in, error, error_description}\n } catch (err) {\n console.log(err);\n }\n};\n\nexport const MAX_RETRIES = 5;\nexport const BACKOFF_BASE_MS = 1000;\nexport const REFRESH_TOKEN_FETCH_TIMEOUT_MS = 10000;\n\nexport const retryWithBackoff = async (fn, maxRetries = MAX_RETRIES, baseDelayMs = BACKOFF_BASE_MS) => {\n for (let attempt = 0; attempt < maxRetries; attempt++) {\n try {\n return await fn();\n } catch (err) {\n // only retry transient network/server errors — everything else fails fast\n const isRetryable = err.message && err.message.startsWith(AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR);\n if (!isRetryable || attempt === maxRetries - 1) {\n throw err;\n }\n const delay = baseDelayMs * Math.pow(2, attempt);\n console.log(`retryWithBackoff retry ${attempt + 1}/${maxRetries} in ${delay}ms`);\n await new Promise(resolve => setTimeout(resolve, delay));\n }\n }\n};\n\nconst processRefreshToken = async (flow, refreshToken) => {\n\n if (flow === RESPONSE_TYPE_CODE && useOAuth2RefreshToken()) {\n if (!refreshToken) {\n clearAuthInfo();\n throw Error(AUTH_ERROR_MISSING_REFRESH_TOKEN);\n }\n\n let response = await retryWithBackoff(() => refreshAccessToken(refreshToken));\n let {access_token, expires_in, refresh_token, id_token} = response;\n if (typeof refresh_token === 'undefined') {\n refresh_token = null; // not using rotate policy\n }\n storeAuthInfo(access_token, expires_in, refresh_token, id_token);\n return access_token;\n }\n clearAuthInfo();\n throw Error(AUTH_ERROR_ACCESS_TOKEN_EXPIRED);\n}\n\n/**\n * @returns {Promise<*>}\n * @private\n */\nconst _getAccessToken = async () => {\n console.log(`openstack-uicore-foundation::Security::methods::_getAccessToken`);\n let authInfo = getAuthInfo();\n\n if (!authInfo) {\n console.log(`openstack-uicore-foundation::Security::methods::_getAccessToken AUTH_ERROR_MISSING_AUTH_INFO`);\n throw Error(AUTH_ERROR_MISSING_AUTH_INFO);\n }\n\n let {accessToken, expiresIn, accessTokenUpdatedAt, refreshToken} = authInfo;\n let flow = getOAuth2Flow();\n // check lifetime\n const now = moment().unix();\n let timeElapsedSecs = (now - accessTokenUpdatedAt);\n\n expiresIn = (expiresIn - ACCESS_TOKEN_SKEW_TIME);\n console.log(`openstack-uicore-foundation::Security::methods::_getAccessToken now ${now} accessTokenUpdatedAt ${accessTokenUpdatedAt} expiresIn ${expiresIn} timeElapsedSecs ${timeElapsedSecs}`)\n if (timeElapsedSecs >= expiresIn || accessToken == null) {\n console.log(`openstack-uicore-foundation::Security::methods::_getAccessToken access token expired, refreshing it ...`);\n accessToken = await processRefreshToken(flow, refreshToken);\n }\n return accessToken;\n}\n\n/**\n * @returns {Promise<*|undefined>}\n */\nexport const getAccessToken = async () => {\n if (typeof navigator !== 'undefined' && navigator.locks) {\n return await navigator.locks.request(GET_TOKEN_SILENTLY_LOCK_KEY, async lock => {\n console.log(`openstack-uicore-foundation::Security::methods::getAccessToken web lock api`, lock);\n return await _getAccessToken();\n });\n } else {\n if (\n await retryPromise(\n () => Lock.acquireLock(GET_TOKEN_SILENTLY_LOCK_KEY, GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT),\n 10\n )\n ) {\n try {\n return await _getAccessToken();\n } finally {\n await Lock.releaseLock(GET_TOKEN_SILENTLY_LOCK_KEY);\n }\n } else {\n // error on locking\n throw Error(AUTH_ERROR_LOCK_ACQUIRE_ERROR);\n }\n }\n}\n\n/**\n * @private\n */\nconst _clearAccessToken = () => {\n console.log(`openstack-uicore-foundation::Security::methods::_clearAccessToken`);\n\n let authInfo = getAuthInfo();\n\n if (!authInfo) {\n console.log(`openstack-uicore-foundation::Security::methods::_clearAccessToken AUTH_ERROR_MISSING_AUTH_INFO`);\n throw Error(AUTH_ERROR_MISSING_AUTH_INFO);\n }\n\n let {accessToken, expiresIn, accessTokenUpdatedAt, refreshToken} = authInfo;\n\n storeAuthInfo(null, 0, refreshToken)\n}\n\nexport const clearAccessToken = async () => {\n // see https://developer.mozilla.org/en-US/docs/Web/API/Web_Locks_API\n if (typeof navigator !== 'undefined' && navigator.locks) {\n await navigator.locks.request(GET_TOKEN_SILENTLY_LOCK_KEY, async lock => {\n console.log(`openstack-uicore-foundation::Security::methods::clearAccessToken web lock api`, lock);\n _clearAccessToken();\n });\n } else {\n if (\n await retryPromise(\n () => Lock.acquireLock(GET_TOKEN_SILENTLY_LOCK_KEY, GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT),\n 10\n )\n ) {\n try {\n _clearAccessToken();\n } finally {\n await Lock.releaseLock(GET_TOKEN_SILENTLY_LOCK_KEY);\n }\n } else {\n // error on locking\n throw Error(AUTH_ERROR_LOCK_ACQUIRE_ERROR);\n }\n }\n}\n\n\nexport const refreshAccessToken = async (refresh_token) => {\n\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n\n const payload = {\n 'grant_type': 'refresh_token',\n \"client_id\": encodeURI(oauth2ClientId),\n \"refresh_token\": refresh_token\n };\n\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), REFRESH_TOKEN_FETCH_TIMEOUT_MS);\n\n let response;\n try {\n response = await fetch(`${baseUrl}/oauth2/token`, {\n method: 'POST',\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(payload),\n signal: controller.signal\n });\n } catch (networkError) {\n // fetch rejects on network failures (DNS, timeout, no connectivity, abort)\n console.log('refreshAccessToken network error:', networkError.message);\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR}: ${networkError.message}`);\n } finally {\n clearTimeout(timeoutId);\n }\n\n if (!response.ok) {\n console.log(`refreshAccessToken server error: ${response.status} - ${response.statusText}`);\n if (response.status >= 500 || response.status === 408 || response.status === 429) {\n // transient error (server error, request timeout, rate limit) — should be retried\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR}: ${response.status} - ${response.statusText}`);\n }\n // token is genuinely revoked — this is a real auth error\n setSessionClearingState(true);\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR}: ${response.status} - ${response.statusText}`);\n }\n\n let json;\n try {\n json = await response.json();\n } catch (parseError) {\n // IDP returned non-JSON (HTML error page, empty body, etc.) — treat as transient\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR}: invalid JSON response from IDP`);\n }\n let {access_token, refresh_token: new_refresh_token, expires_in, id_token} = json;\n // Defensively ensure we never propagate an undefined access token.\n if (!access_token) {\n setSessionClearingState(true);\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR}: missing access_token in refresh response`);\n }\n return {access_token, refresh_token: new_refresh_token, expires_in, id_token}\n}\n\nexport const storeAuthInfo = (accessToken, expiresIn, refreshToken = null, idToken = null) => {\n\n let formerAuthInfo = getAuthInfo();\n\n let authInfo = {\n accessToken: accessToken,\n expiresIn: expiresIn,\n accessTokenUpdatedAt: Math.floor(Date.now() / 1000),\n };\n\n if (refreshToken == null && formerAuthInfo) {\n refreshToken = formerAuthInfo.refreshToken;\n }\n\n if (idToken == null && formerAuthInfo) {\n idToken = formerAuthInfo.idToken;\n }\n\n if (refreshToken) {\n authInfo['refreshToken'] = refreshToken;\n }\n\n if (idToken) {\n authInfo[ID_TOKEN] = idToken;\n Cookies.set(ID_TOKEN, idToken, {secure: true, sameSite: 'Lax'});\n } else {\n Cookies.remove(ID_TOKEN);\n }\n\n putOnLocalStorage(AUTH_INFO, JSON.stringify(authInfo));\n}\n\nexport const getAuthInfo = () => {\n try {\n let res = getFromLocalStorage(AUTH_INFO, false)\n if (!res) return null;\n return JSON.parse(res);\n } catch (err) {\n return null;\n }\n}\n\nexport const clearAuthInfo = () => {\n if (typeof window !== 'undefined') {\n removeFromLocalStorage(AUTH_INFO);\n Cookies.remove(ID_TOKEN);\n }\n};\n\nexport const getIdToken = () => {\n if (typeof window !== 'undefined') {\n const authInfo = getAuthInfo();\n if (authInfo) {\n return authInfo.idToken;\n }\n return null;\n }\n return null;\n};\n\nexport const getOAuth2ClientId = () => {\n if (typeof window !== 'undefined') {\n return window.OAUTH2_CLIENT_ID;\n }\n return null;\n};\n\nexport const getOAuth2Flow = () => {\n if (typeof window !== 'undefined') {\n return window.OAUTH2_FLOW || \"token id_token\";\n }\n return \"token id_token\";\n}\n\nexport const useOAuth2RefreshToken = () => {\n if (typeof window !== 'undefined') {\n return new Boolean(window.OAUTH2_USE_REFRESH_TOKEN || true);\n }\n return true;\n}\n\nexport const getOAuth2IDPBaseUrl = () => {\n if (typeof window !== 'undefined') {\n return window.IDP_BASE_URL;\n }\n return null;\n};\n\nexport const getOAuth2Scopes = () => {\n if (typeof window !== 'undefined') {\n return window.SCOPES;\n }\n return null;\n};\n\nexport const initLogOut = () => {\n let location = getCurrentLocation();\n location.replace(getLogoutUrl(getIdToken()).toString());\n}\n\nexport const validateIdToken = (idToken, issuer, audience) => {\n\n let verifier = new IdTokenVerifier({\n issuer: issuer,\n audience: audience\n });\n\n let storedNonce = getFromLocalStorage(NONCE, true);\n if (!storedNonce)\n throw Error(AUTH_ERROR_MISSING_NONCE_PARAM);\n\n let jwt = verifier.decode(idToken);\n let alg = jwt.header.alg;\n let kid = jwt.header.kid;\n let aud = jwt.payload.aud;\n let iss = jwt.payload.iss;\n let exp = jwt.payload.exp;\n let nbf = jwt.payload.nbf;\n let tnonce = jwt.payload.nonce || null;\n\n return tnonce == storedNonce && aud == audience && iss == issuer;\n}\n\nexport const passwordlessStart = (params) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let scopes = getOAuth2Scopes();\n let nonce = createNonce(NONCE_LEN);\n // store nonce to check it later\n putOnLocalStorage(NONCE, nonce);\n let baseUrl = getOAuth2IDPBaseUrl();\n let url = URI(`${baseUrl}/oauth2/auth`);\n\n let payload = {\n \"response_type\": \"otp\",\n \"scope\": encodeURI(scopes),\n \"nonce\": nonce,\n \"client_id\": encodeURI(oauth2ClientId),\n \"connection\": params.connection || \"email\",\n \"send\": params.send || \"code\",\n };\n\n if (params.hasOwnProperty('email')) {\n payload[\"email\"] = encodeURIComponent(params.email);\n }\n\n if (params.hasOwnProperty('phone_number')) {\n payload[\"phone_number\"] = encodeURIComponent(params.phone_number);\n }\n\n if (params.hasOwnProperty('redirect_uri')) {\n payload[\"redirect_uri\"] = encodeURIComponent(params.redirect_uri);\n }\n\n let req = http.post(url.toString());\n\n return req.send(payload).then((res) => {\n let json = res.body;\n return Promise.resolve({response: json});\n }).catch((err) => {\n return Promise.reject(err);\n });\n\n}\n\nexport const passwordlessLogin = (params) => (dispatch) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let scopes = getOAuth2Scopes();\n let baseUrl = getOAuth2IDPBaseUrl();\n let url = URI(`${baseUrl}/oauth2/token`);\n\n if (!params.hasOwnProperty(\"otp\")) {\n throw Error(AUTH_ERROR_MISSING_OTP_PARAM);\n }\n\n let payload = {\n \"grant_type\": \"passwordless\",\n \"connection\": params.connection || \"email\",\n \"scope\": encodeURI(scopes),\n \"client_id\": encodeURI(oauth2ClientId),\n \"otp\": params.otp\n };\n\n if (params.hasOwnProperty('email')) {\n payload[\"email\"] = encodeURIComponent(params.email);\n }\n\n if (params.hasOwnProperty('phone_number')) {\n payload[\"phone_number\"] = encodeURIComponent(params.phone_number);\n }\n\n let req = http.post(url.toString());\n\n return req.send(payload).then((res) => {\n try {\n // now we got token\n let json = res.body;\n let {access_token, expires_in, refresh_token, id_token} = json;\n\n if (typeof refresh_token === 'undefined') {\n refresh_token = null; // not using rotate policy\n }\n\n if (typeof id_token === 'undefined') {\n id_token = null; // not using rotate policy\n }\n\n // verify id token\n\n if (id_token) {\n if (!validateIdToken(id_token, baseUrl, oauth2ClientId)) {\n throw Error(AUTH_ERROR_ID_TOKEN_INVALID);\n }\n }\n\n storeAuthInfo(access_token, expires_in, refresh_token, id_token);\n\n if (dispatch) {\n dispatch({\n type: SET_LOGGED_USER,\n payload: {sessionState: null}\n });\n }\n\n return Promise.resolve({response: json});\n } catch (e) {\n console.log(e);\n return Promise.reject(e);\n }\n }).catch((err) => {\n return Promise.reject(err);\n });\n}\n\nexport const isIdTokenAlive = (nowEpoch = null) => () => {\n\n if (!nowEpoch) {\n nowEpoch = Math.floor(Date.now() / 1000);\n }\n\n const idToken = getIdToken();\n if (!idToken)\n throw Error('Id Token not set.');\n\n const issuer = getOAuth2IDPBaseUrl();\n const audience = getOAuth2ClientId();\n\n let verifier = new IdTokenVerifier({\n issuer: issuer,\n audience: audience\n });\n\n const jwt = verifier.decode(idToken);\n const exp = jwt.payload.exp;\n\n // check life time\n return exp - (nowEpoch + ACCESS_TOKEN_SKEW_TIME) > 0;\n}\n","/**\n * Copyright 2017 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific flanguage governing permissions and\n * limitations under the License.\n **/\n\nimport request from 'superagent/lib/client';\nimport URI from \"urijs\";\nURI.escapeQuerySpace = false;\n\nlet http = request;\nimport Swal from 'sweetalert2';\nimport T from \"i18n-react/dist/i18n-react\";\nimport { isClearingSessionState, setSessionClearingState, getCurrentPathName } from './methods';\nimport { CLEAR_SESSION_STATE } from '../components/security/actions';\nimport { doLogin, initLogOut } from '../components/security/methods';\nimport {CODE_200} from \"./constants\";\n\nexport const GENERIC_ERROR = \"Yikes. Something seems to be broken. Our web team has been notified, and we apologize for the inconvenience.\";\nexport const RESET_LOADING = 'RESET_LOADING';\nexport const START_LOADING = 'START_LOADING';\nexport const STOP_LOADING = 'STOP_LOADING';\nexport const VALIDATE = 'VALIDATE';\nexport const CLEAR_MESSAGE = 'CLEAR_MESSAGE';\nexport const SHOW_MESSAGE = 'SHOW_MESSAGE';\nexport const SET_SNACKBAR_MESSAGE = \"SET_SNACKBAR_MESSAGE\";\nexport const CLEAR_SNACKBAR_MESSAGE = \"CLEAR_SNACKBAR_MESSAGE\";\n\nexport const createAction = type => payload => ({\n type,\n payload\n});\n\nexport const resetLoading = createAction(RESET_LOADING);\nexport const startLoading = createAction(START_LOADING);\nexport const stopLoading = createAction(STOP_LOADING);\n\nexport const clearSnackbarMessage = () => (dispatch) => {\n dispatch(createAction(CLEAR_SNACKBAR_MESSAGE)({}));\n};\n\nexport const setSnackbarMessage = (message) => (dispatch) => {\n dispatch(createAction(SET_SNACKBAR_MESSAGE)(message));\n};\n\nexport const snackbarErrorHandler = (err, res) => (dispatch, state) => {\n authErrorHandler(err, res, setSnackbarMessage)(dispatch, state);\n};\n\nexport const snackbarSuccessHandler = (message) => (dispatch, state) =>\n setSnackbarMessage({ ...message, type: \"success\", code: CODE_200 })(\n dispatch,\n state\n );\n\nconst xhrs = {};\nconst etagCache = {};\n\nconst cancel = (key) => {\n if(xhrs[key]) {\n xhrs[key].abort();\n console.log(`aborted request ${key}`);\n delete xhrs[key];\n }\n}\n\nconst schedule = (key, req) => {\n // console.log(`scheduling ${key}`);\n xhrs[key] = req;\n};\n\nconst isObjectEmpty = (obj) => {\n return Object.keys(obj).length === 0 && obj.constructor === Object ;\n}\n\nconst buildNotifyHandlerPayload = (httpCode, title, content, type) => ({ httpCode, title, html: content, type });\nconst buildNotifyHandlerErrorPayload = (httpCode, title, content) => buildNotifyHandlerPayload(httpCode, title, content, \"error\");\nconst buildNotifyHandlerWarningPayload = (httpCode, title, content) => buildNotifyHandlerPayload(httpCode, title, content, \"warning\");\n\nconst initLogin = () => (dispatch) => {\n const currentLocation = getCurrentPathName();\n const clearingSessionState = isClearingSessionState();\n dispatch({\n type: CLEAR_SESSION_STATE,\n payload: {}\n });\n if (!clearingSessionState) {\n setSessionClearingState(true);\n console.log(\"authErrorHandler 401 - re login\");\n doLogin(currentLocation);\n }\n};\n\nconst normalizeFormDataPayload = (req, formData) => {\n if(!isObjectEmpty(formData)) {\n Object.keys(formData).forEach(function (key) {\n let value = formData[key];\n if (Array.isArray(value)) {\n value.forEach(item => {\n req.field(`${key}[]`, item);\n });\n } else {\n req.field(key, value);\n }\n });\n }\n};\n\nexport const authErrorHandler = (\n err,\n res,\n notifyErrorHandler = showMessage\n) => (dispatch) => {\n\n const code = err.status;\n let msg = \"\";\n let payload, callback;\n\n dispatch(stopLoading());\n\n switch (code) {\n case 401:\n if (notifyErrorHandler !== showMessage) {\n payload = buildNotifyHandlerErrorPayload(code, \"ERROR\", T.translate(\"errors.user_not_auth\"));\n callback = () => dispatch(initLogin());\n } else {\n dispatch(initLogin());\n }\n break;\n case 403:\n payload = buildNotifyHandlerErrorPayload(code, \"ERROR\", T.translate(\"errors.user_not_authz\"));\n callback = initLogOut;\n break;\n case 404:\n msg = err.response.body?.message || err.response.error?.message || err.message;\n if (err.response.body?.errors?.length) {\n msg += `<br>${err.response.body.errors.join(\"<br>\")}`;\n }\n payload = buildNotifyHandlerWarningPayload(code, \"Not Found\", msg);\n break;\n case 412:\n for (const [key, value] of Object.entries(err.response.body.errors)) {\n msg += isNaN(key) ? `${key}: ` : \"\";\n msg += `${value}<br>`;\n }\n dispatch({\n type: VALIDATE,\n payload: { errors: err.response.body.errors }\n });\n payload = buildNotifyHandlerWarningPayload(code, \"Validation error\", msg);\n break;\n default:\n payload = buildNotifyHandlerErrorPayload(code, \"ERROR\", T.translate(\"errors.server_error\"));\n }\n\n if (payload)\n dispatch(notifyErrorHandler(payload, callback));\n}\n\nexport const getRequest =(\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {},\n useEtag = false\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n let key = url.toString();\n\n if(!isObjectEmpty(params)) {\n // remove the access token\n const { access_token: _, ...newParams} = params;\n // and generate new key\n key = url.query(newParams).toString();\n url = url.query(params);\n }\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n cancel(key);\n\n return new Promise((resolve, reject) => {\n let req = http.get(url.toString());\n if(useEtag && etagCache.hasOwnProperty(key)){\n const { etag } = etagCache[key];\n if(etag){\n req.set('If-None-Match', etag)\n }\n }\n\n req.timeout({\n response: 60000,\n deadline: 60000,\n })\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject, key, useEtag))\n\n schedule(key, req);\n });\n};\n\nexport const putRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => ( dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n if(payload == null)\n payload = {};\n http.put(url.toString())\n .send(payload)\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject))\n });\n};\n\nexport const deleteRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params) => (dispatch, state) => {\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n if(payload == null)\n payload = {};\n\n http.delete(url)\n .send(payload)\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const postRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n let request = http.post(url);\n\n if(payload != null)\n request.send(payload);\n else // to be a simple CORS request\n request.set('Content-Type', 'text/plain');\n\n request.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const postFile = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n file,\n fileMetadata = {},\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n const req = http.post(url)\n .attach('file', file);\n\n normalizeFormDataPayload(req, fileMetadata);\n\n req.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const putFile = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n file = null,\n fileMetadata = {},\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n const req = http.put(url);\n\n if(file != null){\n req.attach('file', file);\n }\n\n normalizeFormDataPayload(req, fileMetadata)\n\n req.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const defaultErrorHandler = (err, res) => (dispatch) => {\n let body = res.body;\n let text = '';\n if(body instanceof Object){\n if(body.hasOwnProperty('message'))\n text = body.message;\n }\n Swal.fire(res.statusText, text, \"error\");\n}\n\nconst byLowerCase = toFind => value => toLowerCase(value) === toFind;\nconst toLowerCase = value => value.toLowerCase();\nconst getKeys = headers => Object.keys(headers);\n\nexport const getHeaderCaseInsensitive = (headerName, headers = {}) => {\n const key = getKeys(headers).find(byLowerCase(headerName));\n return key ? headers[key] : undefined;\n};\n\nexport const responseHandler = ( dispatch, state, receiveActionCreator, errorHandler, resolve, reject, key = null, useEtag= false ) =>\n\n (err, res) => {\n\n if (err || !res.ok) {\n let code = err.status;\n\n if(code === 304 && etagCache.hasOwnProperty(key) && useEtag){\n const { body } = etagCache[key];\n\n if(typeof receiveActionCreator === 'function') {\n dispatch(receiveActionCreator({response: body}));\n return resolve({response: body});\n }\n\n dispatch(receiveActionCreator);\n return resolve({response: body});\n }\n if(errorHandler) {\n errorHandler(err, res)(dispatch, state);\n }\n return reject({ err, res, dispatch, state })\n }\n\n let json = res.body;\n\n if(useEtag) {\n const responseETAG = getHeaderCaseInsensitive('etag', res.headers);\n if (responseETAG) {\n etagCache[key] = { etag: responseETAG, body: json};\n }\n }\n\n if(typeof receiveActionCreator === 'function') {\n dispatch(receiveActionCreator({response: json}));\n return resolve({response: json});\n }\n dispatch(receiveActionCreator);\n return resolve({response: json});\n}\n\n\nexport const fetchErrorHandler = (response) => {\n let code = response.status;\n let msg = response.statusText;\n\n switch (code) {\n case 403:\n Swal.fire(\"ERROR\", T.translate(\"errors.user_not_authz\"), \"warning\");\n break;\n case 401:\n Swal.fire(\"ERROR\", T.translate(\"errors.session_expired\"), \"error\");\n break;\n case 412:\n Swal.fire(\"ERROR\", msg, \"warning\");\n case 500:\n Swal.fire(\"ERROR\", T.translate(\"errors.server_error\"), \"error\");\n }\n}\n\nexport const fetchResponseHandler = (response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.json();\n }\n}\n\nexport const showMessage = (settings, callback = null) => (dispatch) => {\n dispatch(stopLoading());\n Swal.fire(settings).then((result) => {\n if (result.value && typeof callback === 'function') {\n callback();\n }\n });\n}\n\nexport const showSuccessMessage = (html) => (dispatch) => {\n dispatch(stopLoading());\n Swal.fire({\n title: T.translate(\"general.done\"),\n html: html,\n type: 'success'\n });\n}\n\nexport const downloadFileByContent = (filename, content, mime) => {\n let link = document.createElement('a');\n link.textContent = 'download';\n link.download = filename;\n link.href = `data:${mime},${encodeURIComponent(content)}`\n document.body.appendChild(link); // Required for FF\n link.click();\n document.body.removeChild(link);\n}\n\nexport const getCSV = (endpoint, params, filename, header = null) => (dispatch) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n dispatch(startLoading());\n\n return fetch(url.toString())\n .then((response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.text();\n }\n })\n .then((csv) => {\n dispatch(stopLoading());\n\n if (header) {\n csv = header + '\\r\\r' + csv;\n }\n downloadFileByContent(filename, csv, 'text/csv;charset=utf-8');\n })\n .catch(fetchErrorHandler);\n};\n\nexport const getRawCSV = (endpoint, params, header = null) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n return fetch(url.toString())\n .then((response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.text();\n }\n })\n .then((csv) => {\n if (header) {\n csv = header + '\\r\\r' + csv;\n }\n\n return csv;\n })\n .catch(fetchErrorHandler);\n};\n\nexport const escapeFilterValue = (value) => {\n value = String(value);\n // escape backslash first so you don't accidentally break your own escapes\n value = value.replace(/\\\\/g, \"\\\\\\\\\");\n value = value.replace(/,/g, \"\\\\,\");\n value = value.replace(/;/g, \"\\\\;\");\n // especial case for literal +\n value = value.replace(/\\+/g, \"%2B\");\n return value;\n};\n","export const CENTS_FACTOR = 100n;\nexport const TWO_DECIMAL_PLACES = 2;\nexport const THREE_DECIMAL_PLACES = 3;\nexport const ONE_CENT = 1n;\nexport const ZERO_INT = 0;\n\nexport const CODE_200 = 200;\n\nexport const DEBOUNCE_WAIT_250 = 250;\nexport const DEBOUNCE_WAIT = 500;\n\nexport const NOTIFICATION_TIMEOUT = 2000;\nexport const DEFAULT_PER_PAGE = 10;\nexport const TWENTY_PER_PAGE = 20;\nexport const FIFTY_PER_PAGE = 50;\nexport const MAX_PER_PAGE = 100;\n\nexport const INT_BASE = 10;\n\nexport const ONE_HUNDRED = 100;\nexport const MILLISECONDS_IN_SECOND = 1000;\n\nexport const MILLISECONDS_TO_SECONDS = 1000;\n\nexport const BYTES_PER_MB = 1_048_576; // 1024 * 1024\n\nexport const MAX_INVENTORY_IMAGE_UPLOAD_SIZE = 512000;\nexport const MAX_INVENTORY_IMAGES_UPLOAD_QTY = 5;\nexport const ALLOWED_INVENTORY_IMAGE_FORMATS = [\"jpg\", \"jpeg\", \"png\"];\n\nexport const METAFIELD_TYPES_WITH_OPTIONS = [\n \"CheckBoxList\",\n \"ComboBox\",\n \"RadioButtonList\"\n];\n\nexport const METAFIELD_TYPES = [\n \"CheckBox\",\n ...METAFIELD_TYPES_WITH_OPTIONS,\n \"Text\",\n \"TextArea\",\n \"Quantity\",\n \"DateTime\",\n \"Time\"\n];\n\nexport const DISCOUNT_TYPES = {\n AMOUNT: \"Amount\",\n RATE: \"Rate\"\n};\n\nexport const RATE_FIELDS = {\n EARLY_BIRD: \"early_bird_rate\",\n STANDARD: \"standard_rate\",\n ONSITE: \"onsite_rate\"\n};\n\nexport const DECIMAL_DIGITS = 2;\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"spark-md5\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/sha256\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/enc-base64url\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/enc-hex\");","import SparkMD5 from \"spark-md5\";\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nconst MAX_BYTES = 65536\n// Node supports requesting up to this number of bytes\n// https://github.com/nodejs/node/blob/master/lib/internal/crypto/random.js#L48\nconst MAX_UINT32 = 4294967295\nconst crypto = typeof window !== 'undefined' ? (window.crypto || window.msCrypto) : null;\nimport sha256 from 'crypto-js/sha256';\nimport Base64url from 'crypto-js/enc-base64url'\nimport Hex from 'crypto-js/enc-hex'\nexport const getRandomBytes = (size) => {\n // phantomjs needs to throw\n if (size > MAX_UINT32) throw new RangeError('requested too many random bytes')\n const bytes = Buffer.allocUnsafe(size)\n if(!crypto) return a;\n if (size > 0) { // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) { // this is the max bytes crypto.getRandomValues\n // can do at once see https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n for (let generated = 0; generated < size; generated += MAX_BYTES) {\n // buffer.slice automatically checks if the end is past the end of\n // the buffer so we don't have to here\n crypto.getRandomValues(bytes.slice(generated, generated + MAX_BYTES))\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n return bytes\n}\n\nexport const getSHA256 = (message, format = 'hex') => {\n\n let f = Hex;\n if(format === 'Base64url')\n f = Base64url;\n\n return sha256(message).toString(f);\n}\n\nexport const getMD5 = (file) => {\n return new Promise((resolve, reject) => {\n const chunkSize = 2 * 1024 * 1024; // 2 MB by chunk\n const spark = new SparkMD5.ArrayBuffer();\n const fileReader = new FileReader();\n let cursor = 0;\n\n fileReader.onload = e => {\n spark.append(e.target.result); \n cursor += chunkSize;\n\n if (cursor < file.size) {\n readNextChunk();\n } else {\n resolve(spark.end()); // final MD5\n }\n };\n\n fileReader.onerror = () => reject(\"Error reading the file\");\n\n function readNextChunk() {\n const slice = file.slice(cursor, cursor + chunkSize);\n fileReader.readAsArrayBuffer(slice);\n }\n\n readNextChunk();\n });\n}","/**\n * Copyright 2018 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport moment from 'moment-timezone';\nimport URI from \"urijs\";\n\nexport const findElementPos = (obj) => {\n var curtop = -70;\n if (obj.offsetParent) {\n do {\n curtop += obj.offsetTop;\n } while (obj = obj.offsetParent);\n return [curtop];\n }\n};\n\nexport const epochToMoment = (atime) => {\n if(!atime) return atime;\n atime = atime * 1000;\n return moment(atime);\n};\n\nexport const epochToMomentTimeZone = (atime, time_zone) => {\n if(!atime) return atime;\n atime = atime * 1000;\n return moment(atime).tz(time_zone);\n};\n\nexport const formatEpoch = (atime, format = 'M/D/YYYY h:mm a') => {\n if(!atime) return atime;\n return epochToMoment(atime).format(format);\n};\n\nexport const parseLocationHour = (hour) => {\n let parsedHour = hour.toString();\n if(parsedHour.length < 4) parsedHour = `0${parsedHour}`;\n parsedHour = parsedHour.match(/.{2}/g);\n parsedHour = parsedHour.join(':');\n return parsedHour;\n}\n\nexport const objectToQueryString = (obj) => {\n var str = \"\";\n for (var key in obj) {\n if (str != \"\") {\n str += \"&\";\n }\n str += key + \"=\" + encodeURIComponent(obj[key]);\n }\n\n return str;\n};\n\nexport const getBackURL = () => {\n let url = URI(window.location.href);\n let query = url.search(true);\n let fragment = url.fragment();\n let backUrl = query.hasOwnProperty('BackUrl') ? query['BackUrl'] : null;\n if(backUrl != null && fragment != null && fragment != ''){\n backUrl += `#${fragment}`;\n }\n return backUrl;\n};\n\nexport const toSlug = (text) =>{\n text = text.toLowerCase();\n return text.replace(/[^a-zA-Z0-9]+/g,'_');\n}\n\nexport const getAuthCallback = () => {\n if(typeof window !== 'undefined') {\n return `${window.location.origin}/auth/callback`;\n }\n return null;\n};\n\nexport const getCurrentLocation = () => {\n let location = '';\n if(typeof window !== 'undefined') {\n location = window.location;\n // check if we are on iframe\n if (window.top)\n location = window.top.location;\n }\n return location;\n};\n\nexport const getOrigin = () => {\n if(typeof window !== 'undefined') {\n return window.location.origin;\n }\n return null;\n};\n\nexport const getCurrentPathName = () => {\n if(typeof window !== 'undefined') {\n return window.location.pathname;\n }\n return null;\n};\n\nexport const getCurrentHref = () => {\n if(typeof window !== 'undefined') {\n return window.location.href;\n }\n return null;\n};\n\nexport const getAllowedUserGroups = () => {\n if(typeof window !== 'undefined') {\n return window.ALLOWED_USER_GROUPS || '';\n }\n return null;\n};\n\nexport const buildAPIBaseUrl = (relativeUrl) => {\n if(typeof window !== 'undefined'){\n return `${window.API_BASE_URL}${relativeUrl}`;\n }\n return null``;\n};\n\nexport const putOnLocalStorage = (key, value) => {\n if(typeof window !== 'undefined') {\n window.localStorage.setItem(key, value);\n }\n};\n\nexport const getFromLocalStorage = (key, removeIt) => {\n if(typeof window !== 'undefined') {\n let val = window.localStorage.getItem(key);\n if(removeIt){\n console.log(`getFromLocalStorage removing key ${key}`);\n removeFromLocalStorage(key);\n }\n return val;\n }\n return null;\n};\n\nexport const removeFromLocalStorage = (key) => {\n if(typeof window !== 'undefined') {\n window.localStorage.removeItem(key);\n }\n}\n\nexport const isClearingSessionState = () => {\n if(typeof window !== 'undefined') {\n return window.clearing_session_state;\n }\n return false;\n};\n\nexport const setSessionClearingState = (val) => {\n if(typeof window !== 'undefined') {\n window.clearing_session_state = val;\n }\n};\n\nexport const getCurrentUserLanguage = () => {\n let language = 'en';\n if(typeof navigator !== 'undefined') {\n language = (navigator.languages && navigator.languages[0]) || navigator.language || navigator.userLanguage;\n }\n return language;\n};\n\nexport const scrollToError = (errors) => {\n if(Object.keys(errors).length > 0) {\n const firstError = Object.keys(errors)[0];\n const firstNode = document.getElementById(firstError);\n if (firstNode) window.scrollTo(0, findElementPos(firstNode));\n }\n};\n\nexport const hasErrors = (field, errors) => {\n if(field in errors) {\n return errors[field];\n }\n return '';\n};\n\nexport const shallowEqual = (object1, object2) => {\n const keys1 = Object.keys(object1);\n const keys2 = Object.keys(object2);\n\n if (keys1.length !== keys2.length) {\n return false;\n }\n\n for (let key of keys1) {\n if (object1[key] !== object2[key]) {\n return false;\n }\n }\n\n return true;\n};\n\nexport const arraysEqual = (a1, a2) =>\n a1.length === a2.length && a1.every((o, idx) => shallowEqual(o, a2[idx]));\n\nexport const isEmpty = (obj) => {\n return Object.keys(obj).length === 0;\n};\n\n\nexport const base64URLEncode = (str) => {\n return str\n .toString('base64')\n .replace(/\\+/g, '-')\n .replace(/\\//g, '_')\n .replace(/=/g, '')\n}\n\nexport const retryPromise = async (\n cb,\n maxNumberOfRetries = 3\n) => {\n for (let i = 0; i < maxNumberOfRetries; i++) {\n if (await cb()) {\n return true;\n }\n }\n\n return false;\n}\n\nexport const getTimeServiceUrl = () => {\n if(typeof window !== 'undefined') {\n return window.TIMEINTERVALSINCE1970_API_URL || process.env.TIMEINTERVALSINCE1970_API_URL;\n }\n return null;\n};\n\nexport const getEventLocation = (event, summitVenueCount, summitShowLocDate = null, nowUtc = null) => {\n const shouldShowVenues = (summitShowLocDate && nowUtc) ? summitShowLocDate * 1000 < nowUtc : true;\n const locationName = [];\n const { location } = event;\n\n if (!shouldShowVenues) return 'TBA';\n\n if (!location) return 'TBA';\n\n if (summitVenueCount > 1 && location.venue?.name) locationName.push(location.venue.name);\n if (location.floor?.name) locationName.push(location.floor.name);\n if (location.name) locationName.push(location.name);\n\n return locationName.length > 0 ? locationName.join(' - ') : 'TBA';\n};\n\nexport const getEventHosts = (event) => {\n let hosts = [];\n if (event.speakers?.length > 0) {\n hosts = [...event.speakers];\n }\n if (event.moderator) hosts.push(event.moderator);\n\n return hosts;\n};\n\nconst loadImage = async url => {\n const img = document.createElement('img')\n img.src = url\n img.crossOrigin = 'anonymous'\n\n return new Promise((resolve, reject) => {\n img.onload = () => resolve(img)\n img.onerror = reject\n })\n}\n\nexport const convertSVGtoImg = async (svgUrl) => {\n const img = await loadImage(svgUrl)\n const newWidth = 100\n const newHeight = Math.floor(img.naturalHeight * 100 / img.naturalWidth)\n\n const canvas = document.createElement('canvas')\n canvas.width = newWidth\n canvas.height = newHeight\n canvas.getContext('2d').drawImage(img, 0, 0, newWidth, newHeight)\n\n const url = await canvas.toDataURL(`image/png`, 1.0)\n console.log(url, newWidth, newHeight);\n return {url, width: newWidth, height: newHeight}\n}\n\nexport const isRateEnabled = (value) =>\n value !== null && value !== undefined && value !== \"\";\n","/**\n * Copyright 2018 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport { fetchErrorHandler, fetchResponseHandler, escapeFilterValue } from \"./actions\";\nimport { getAccessToken } from '../components/security/methods';\nimport { buildAPIBaseUrl } from \"./methods\";\nimport _ from 'lodash';\nimport moment from 'moment-timezone'\n\nexport const RECEIVE_COUNTRIES = 'RECEIVE_COUNTRIES';\nimport URI from \"urijs\";\nimport {DEBOUNCE_WAIT, DEFAULT_PER_PAGE, MAX_PER_PAGE} from \"./constants\";\n\nURI.escapeQuerySpace = false;\n\nconst _fetchPublic = async (endpoint, callback, options = {}) => {\n return fetch(buildAPIBaseUrl(endpoint.toString()), options)\n .then(fetchResponseHandler)\n .then((json) => {\n if(typeof callback === 'function')\n callback(json.data);\n })\n .catch(response => {\n const code = response.status;\n if (code === 404) callback([]);\n return response;\n })\n .catch(fetchErrorHandler);\n}\n\nconst _fetchPromise = async (endpoint, options = {}) => {\n let accessToken;\n\n try {\n accessToken = await getAccessToken();\n } catch (e) {\n return Promise.reject(e);\n }\n\n endpoint.addQuery('access_token', accessToken);\n\n return fetch(buildAPIBaseUrl(endpoint.toString()), options)\n .then(fetchResponseHandler)\n .catch(fetchErrorHandler);\n}\n\n/**\n * @param endpoint\n * @param callback\n * @param options\n * @returns {Promise<Response | void>}\n * @private\n */\nconst _fetch = async (endpoint, callback, options = {}) => {\n\n let accessToken;\n\n try {\n accessToken = await getAccessToken();\n } catch (e) {\n if(typeof callback === 'function')\n callback(e);\n return Promise.reject();\n }\n\n endpoint.addQuery('access_token', accessToken);\n\n return _fetchPublic(endpoint, callback, options);\n}\n\n/**\n *\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryMembers = _.debounce(async (input, callback, per_page= DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/members`);\n\n endpoint.addQuery('expand', `tickets,rsvp,schedule_summit_events,all_affiliations`);\n endpoint.addQuery('order','first_name,last_name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `full_name@@${input},first_name@@${input},last_name@@${input},email@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n *\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryAttendees = _.debounce(async (summitId, input, callback, per_page= DEFAULT_PER_PAGE) => {\n \n let endpoint = URI(`/api/v1/summits/${summitId}/attendees`);\n \n endpoint.addQuery('order','first_name,last_name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n \n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `full_name=@${input},email=@${input}`);\n }\n \n _fetch(endpoint, callback);\n \n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const querySummits = _.debounce(async (input, callback, per_page= DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/all`);\n\n endpoint.addQuery('expand', `tickets,rsvp,schedule_summit_events,all_affiliations`);\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n\nexport const fetchAllSummits = async (onlyActive) => {\n\n let endpoint = URI(`/api/v2/summits/all`);\n\n endpoint.addQuery('fields', 'id,name,start_date,end_date');\n endpoint.addQuery('expand', 'none');\n endpoint.addQuery('relations', 'none');\n endpoint.addQuery('order','-start_date');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', MAX_PER_PAGE);\n\n if (onlyActive) {\n const now = moment().tz(\"UTC\").unix();\n endpoint.addQuery('filter[]', `end_date>=${now}`);\n }\n\n return _fetchPromise(endpoint)\n .then((json) => json.data);\n};\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const querySpeakers = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE ) => {\n\n\n let endpoint = URI(`/api/v1/${summitId ? `summits/${summitId}/speakers`:`speakers`}`);\n\n endpoint.addQuery('expand', `member,registration_request`);\n endpoint.addQuery('order','first_name,last_name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `full_name@@${input},first_name@@${input},last_name@@${input},email@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryTags = _.debounce(async (summitId, input, callback, per_page = 50) => {\n\n let endpoint = URI(`/api/v1/${summitId ? `summits/${summitId}/track-tag-groups/all/allowed-tags`:`tags`}`);\n\n if(summitId)\n endpoint.addQuery('expand', `tag,track_tag_group`);\n\n endpoint.addQuery('order','tag');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `tag@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryTracks = _.debounce(async (summitId, input, callback, excludedIds = [], per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/tracks`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if (excludedIds?.length > 0) {\n endpoint.addQuery('filter[]', `not_id==${excludedIds.join(\"||\")}`);\n }\n\n if (input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryTrackGroups = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/track-groups`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=, *): Promise<void>)|*>}\n */\nexport const queryEvents = _.debounce(async (summitId, input, onlyPublished = false, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/events` + (onlyPublished ? '/published' : ''));\n\n endpoint.addQuery('order','title');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `title@@${input}`);\n }\n\n _fetch(endpoint, callback);\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=, *=): Promise<void>)|*>}\n */\nexport const queryEventTypes = _.debounce(async (summitId, input, callback, eventTypeClassName = null, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/event-types`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n if (eventTypeClassName) {\n eventTypeClassName = escapeFilterValue(eventTypeClassName);\n endpoint.addQuery('filter[]', `class_name==${eventTypeClassName}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryGroups = _.debounce(async (input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/groups`);\n\n endpoint.addQuery('order','title,code');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `title@@${input},code@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryCompanies = _.debounce(async (input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/companies`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryRegistrationCompanies = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/registration-companies`);\n\n endpoint.addQuery('order','name')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const querySponsors = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/sponsors`);\n\n endpoint.addQuery('expand','company,sponsorship,sponsorship.type')\n endpoint.addQuery('order','id')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `company_name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\nexport const querySponsorsV2 = _.debounce(async (input, summitId, callback) => {\n const endpoint = URI(\n `/api/v2/summits/${summitId}/sponsors`\n );\n const escapedInput = escapeFilterValue(input);\n endpoint.addQuery(\"fields\", \"id,company.name,company.id\");\n endpoint.addQuery(\"relations\", \"company\");\n endpoint.addQuery(\"expand\", \"company\");\n if (escapedInput) {\n endpoint.addQuery(\"filter\", `company_name=@${escapedInput}`);\n }\n _fetchPromise(endpoint)\n .then((json) => {\n const options = [...json.data].map((sp) => ({\n id: sp.id,\n name: sp.company.name\n }));\n callback(options);\n })\n .catch(fetchErrorHandler);\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const querySponsorsWithBadgeScans = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/sponsors`);\n\n endpoint.addQuery('expand','company,sponsorship,sponsorship.type');\n endpoint.addQuery('fields','id,company.name,sponsorship.type.name');\n endpoint.addQuery('relations','none,company.none,sponsorship.type.none');\n endpoint.addQuery('filter[]','badge_scans_count>0');\n endpoint.addQuery('order','+company_name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `company_name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryAccessLevels = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/access-level-types`);\n\n endpoint.addQuery('order','name')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryOrganizations = _.debounce(async (input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/organizations`);\n\n endpoint.addQuery('order','name')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\nexport const getLanguageList = (callback, signal) => {\n return _fetchPublic(new URI(`/api/public/v1/languages`), callback, { signal });\n};\n\nexport const getCountryList = (callback, signal) => {\n return _fetchPublic(new URI(`/api/public/v1/countries`), callback, { signal });\n};\n\nlet geocoder;\n\nexport const geoCodeAddress = (address) => {\n\n if (!geocoder) geocoder = new google.maps.Geocoder();\n\n // return a Promise\n return new Promise(function(resolve,reject) {\n geocoder.geocode( { 'address': address}, function(results, status) {\n if (status == google.maps.GeocoderStatus.OK) {\n // resolve results upon a successful status\n resolve(results);\n } else {\n // reject status upon un-successful status\n reject(status);\n }\n });\n });\n};\n\nexport const geoCodeLatLng = (lat, lng) => {\n\n if (!geocoder) geocoder = new google.maps.Geocoder();\n\n let latlng = {lat: parseFloat(lat), lng: parseFloat(lng)};\n // return a Promise\n return new Promise(function(resolve,reject) {\n geocoder.geocode( { 'location': latlng}, function(results, status) {\n if (status == google.maps.GeocoderStatus.OK) {\n // resolve results upon a successful status\n resolve(results);\n } else {\n // reject status upon un-successful status\n reject(status);\n }\n });\n });\n};\n\n/**\n * @type {DebouncedFunc<(function(*, *=, *, *=, *=): Promise<void>)|*>}\n */\nexport const queryTicketTypes = _.debounce(async (summitId, filters = {}, callback, version = 'v1', per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/${version}/summits/${summitId}/ticket-types`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(filters.hasOwnProperty('name')) {\n const name = escapeFilterValue(filters.name);\n if(name && name != '')\n endpoint.addQuery('filter[]', `name@@${name}`);\n }\n\n if(filters.hasOwnProperty('audience')){\n const audience = escapeFilterValue(filters.audience);\n if(audience && audience != '')\n endpoint.addQuery('filter[]', `audience==${audience}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const querySponsoredProjects = _.debounce(async (input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n\n const endpoint = URI(`/api/v1/sponsored-projects`);\n\n endpoint.addQuery('order','name')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryPromocodes = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE, extraFilters = []) => {\n\n\n let endpoint = URI(`/api/v1/summits/${summitId}/promo-codes`);\n\n endpoint.addQuery('order','code')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `code@@${input}`);\n }\n\n //eg: filter = 'class_name==SummitRegistrationPromoCode'\n for (const filter of extraFilters) {\n endpoint.addQuery('filter[]', filter);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n\nexport const querySponsorAddons = async (\n summitId,\n sponsorId,\n sponsorshipIds,\n callback\n) => {\n try {\n const promises = sponsorshipIds.map((sponsorshipId) => {\n const endpoint = URI(\n `/api/v1/summits/${summitId}/sponsors/${sponsorId}/sponsorships/${sponsorshipId}/add-ons`\n );\n endpoint.addQuery(\n \"fields\",\n \"id,name,sponsorship.type,sponsorship.type.id,sponsorship.type.type.name\"\n );\n endpoint.addQuery(\n \"expand\",\n \"sponsorship,sponsorship.type,sponsorship.type.type\"\n );\n endpoint.addQuery(\"relations\", \"sponsorship.none\");\n return _fetchPromise(endpoint)\n .then(fetchResponseHandler)\n .then((json) => json.data)\n .catch((error) => {\n fetchErrorHandler(error);\n return [];\n });\n });\n const results = await Promise.all(promises);\n const allAddons = results.flat();\n callback(allAddons);\n } catch (error) {\n fetchErrorHandler(error);\n }\n};\n\n\nexport const querySummitAddons = async (\n summitId,\n callback\n) => {\n const endpoint = URI(\n `/api/v1/summits/${summitId}/add-ons/metadata`\n );\n endpoint.addQuery(\"page\", 1);\n endpoint.addQuery(\"per_page\", MAX_PER_PAGE);\n\n _fetch(endpoint, callback);\n};\n\n\nexport const querySponsorships = _.debounce(async (input, callback) => {\n const endpoint = URI(`/api/v1/sponsorship-types`);\n input = escapeFilterValue(input);\n if (input) {\n endpoint.addQuery(\"filter\", `name=@${input}`);\n }\n _fetch(endpoint, callback);\n}, DEBOUNCE_WAIT);\n\n\nexport const querySponsorshipsBySummit = _.debounce(\n async (input, summitId, callback) => {\n const endpoint = URI(\n `/api/v1/summits/${summitId}/sponsorships-types`\n );\n input = escapeFilterValue(input);\n endpoint.addQuery(\"page\", 1);\n endpoint.addQuery(\"per_page\", MAX_PER_PAGE);\n endpoint.addQuery(\"expand\", \"type\");\n endpoint.addQuery(\"order\", \"+name\");\n if (input) {\n endpoint.addQuery(\"filter\", `name=@${input}`);\n }\n _fetch(endpoint, callback);\n },\n DEBOUNCE_WAIT\n);\n","module.exports = require(\"@babel/runtime/helpers/defineProperty\");","module.exports = require(\"@babel/runtime/helpers/extends\");","module.exports = require(\"@babel/runtime/helpers/objectWithoutProperties\");","module.exports = require(\"i18n-react/dist/i18n-react\");","module.exports = require(\"idtoken-verifier\");","module.exports = require(\"lodash\");","module.exports = require(\"moment-timezone\");","module.exports = require(\"react\");","module.exports = require(\"react-select/lib/Async\");","module.exports = require(\"superagent/lib/client\");","module.exports = require(\"sweetalert2\");","module.exports = require(\"urijs\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","/**\n * Copyright 2017 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport React from 'react';\nimport AsyncSelect from 'react-select/lib/Async';\nimport {queryGroups} from '../../utils/query-actions';\n\nexport default class GroupInput extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.handleChange = this.handleChange.bind(this);\n this.getGroups = this.getGroups.bind(this);\n }\n\n handleChange(value) {\n\n let ev = {target: {\n id: this.props.id,\n value: value,\n type: 'groupinput'\n }};\n\n this.props.onChange(ev);\n }\n\n getGroups (input, callback) {\n if (!input) {\n return Promise.resolve({ options: [] });\n }\n\n queryGroups(input, callback);\n }\n\n render() {\n let {value, onChange, id, multi, ...rest} = this.props;\n let isMulti = (this.props.hasOwnProperty('multi'));\n\n return (\n <AsyncSelect\n value={value}\n onChange={this.handleChange}\n loadOptions={this.getGroups}\n getOptionValue={option => option.id}\n getOptionLabel={option => option.title}\n isMulti={isMulti}\n {...rest}\n />\n );\n\n }\n}\n\n"],"names":["root","factory","exports","module","define","amd","this","AUTH_ERROR_MISSING_AUTH_INFO","AUTH_ERROR_MISSING_REFRESH_TOKEN","AUTH_ERROR_ACCESS_TOKEN_EXPIRED","AUTH_ERROR_LOCK_ACQUIRE_ERROR","AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR","AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR","require","Lock","SuperTokensLock","GET_TOKEN_SILENTLY_LOCK_KEY","RESPONSE_TYPE_CODE","AUTH_INFO","ID_TOKEN","processRefreshToken","async","flow","refreshToken","useOAuth2RefreshToken","clearAuthInfo","Error","response","fn","maxRetries","baseDelayMs","attempt","err","message","startsWith","delay","Math","pow","console","log","Promise","resolve","setTimeout","retryWithBackoff","refreshAccessToken","access_token","expires_in","refresh_token","id_token","storeAuthInfo","_getAccessToken","authInfo","getAuthInfo","accessToken","expiresIn","accessTokenUpdatedAt","getOAuth2Flow","now","moment","unix","timeElapsedSecs","getAccessToken","navigator","locks","request","lock","retryPromise","acquireLock","releaseLock","baseUrl","getOAuth2IDPBaseUrl","oauth2ClientId","getOAuth2ClientId","payload","encodeURI","controller","AbortController","timeoutId","abort","json","fetch","method","headers","body","JSON","stringify","signal","networkError","clearTimeout","ok","status","statusText","setSessionClearingState","parseError","new_refresh_token","idToken","formerAuthInfo","floor","Date","Cookies","secure","sameSite","putOnLocalStorage","res","getFromLocalStorage","parse","window","removeFromLocalStorage","OAUTH2_CLIENT_ID","OAUTH2_FLOW","Boolean","OAUTH2_USE_REFRESH_TOKEN","IDP_BASE_URL","URI","createAction","type","fetchErrorHandler","code","msg","Swal","T","fetchResponseHandler","escapeFilterValue","value","String","replace","DEBOUNCE_WAIT","DEFAULT_PER_PAGE","MAX_PER_PAGE","crypto","msCrypto","buildAPIBaseUrl","relativeUrl","API_BASE_URL","key","localStorage","setItem","removeIt","val","getItem","removeItem","clearing_session_state","cb","maxNumberOfRetries","i","_fetchPublic","endpoint","callback","options","toString","then","data","catch","_fetchPromise","e","reject","addQuery","_fetch","queryGroups","_","input","per_page","summitId","excludedIds","length","join","onlyPublished","eventTypeClassName","escapedInput","map","sp","id","name","company","filters","version","hasOwnProperty","audience","extraFilters","filter","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","o","Object","defineProperty","enumerable","get","obj","prop","prototype","call","r","Symbol","toStringTag","GroupInput","React","constructor","props","super","handleChange","bind","getGroups","ev","target","onChange","render","multi","rest","isMulti","loadOptions","getOptionValue","option","getOptionLabel","title"],"sourceRoot":""}
1
+ {"version":3,"file":"components/inputs/group-input.js","mappings":"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","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/./src/components/security/constants.js","webpack://openstack-uicore-foundation/external commonjs \"browser-tabs-lock\"","webpack://openstack-uicore-foundation/external commonjs \"js-cookie\"","webpack://openstack-uicore-foundation/./src/components/security/methods.js","webpack://openstack-uicore-foundation/./src/utils/actions.js","webpack://openstack-uicore-foundation/./src/utils/constants.js","webpack://openstack-uicore-foundation/external commonjs \"spark-md5\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/sha256\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/enc-base64url\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/enc-hex\"","webpack://openstack-uicore-foundation/./src/utils/crypto.js","webpack://openstack-uicore-foundation/./src/utils/methods.js","webpack://openstack-uicore-foundation/./src/utils/query-actions.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/defineProperty\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/extends\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/objectWithoutProperties\"","webpack://openstack-uicore-foundation/external commonjs \"i18n-react/dist/i18n-react\"","webpack://openstack-uicore-foundation/external commonjs \"idtoken-verifier\"","webpack://openstack-uicore-foundation/external commonjs \"lodash\"","webpack://openstack-uicore-foundation/external commonjs \"moment-timezone\"","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/external commonjs \"react-select/lib/Async\"","webpack://openstack-uicore-foundation/external commonjs \"superagent/lib/client\"","webpack://openstack-uicore-foundation/external commonjs \"sweetalert2\"","webpack://openstack-uicore-foundation/external commonjs \"urijs\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/./src/components/inputs/group-input.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","export const AUTH_ERROR_MISSING_AUTH_INFO = 'AUTH_ERROR_MISSING_AUTH_INFO';\nexport const AUTH_ERROR_MISSING_REFRESH_TOKEN = 'AUTH_ERROR_MISSING_REFRESH_TOKEN';\nexport const AUTH_ERROR_ACCESS_TOKEN_EXPIRED = 'AUTH_ERROR_ACCESS_TOKEN_EXPIRED';\nexport const AUTH_ERROR_LOCK_ACQUIRE_ERROR = 'AUTH_ERROR_LOCK_ACQUIRE_ERROR'\nexport const AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR = 'AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR';\nexport const AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR = 'AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR';\nexport const AUTH_ERROR_ID_TOKEN_INVALID = 'AUTH_ERROR_ID_TOKEN_INVALID';\nexport const AUTH_ERROR_MISSING_OTP_PARAM = 'AUTH_ERROR_MISSING_OTP_PARAM';\nexport const AUTH_ERROR_MISSING_PKCE_PARAM = 'AUTH_ERROR_MISSING_PKCE_PARAM';\nexport const AUTH_ERROR_MISSING_NONCE_PARAM = 'AUTH_ERROR_MISSING_NONCE_PARAM';\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"browser-tabs-lock\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"js-cookie\");","import {\n base64URLEncode,\n getAuthCallback,\n getCurrentLocation,\n getFromLocalStorage,\n removeFromLocalStorage,\n getOrigin,\n putOnLocalStorage,\n retryPromise,\n setSessionClearingState,\n} from \"../../utils/methods\";\nimport moment from \"moment-timezone\";\nimport request from 'superagent/lib/client';\nimport SuperTokensLock from 'browser-tabs-lock';\nimport Cookies from 'js-cookie'\nlet http = request;\nimport URI from \"urijs\";\nimport IdTokenVerifier from \"idtoken-verifier\";\nimport {SET_LOGGED_USER} from \"./actions\";\nimport {getRandomBytes, getSHA256} from \"../../utils/crypto\";\n\nimport {\n AUTH_ERROR_ACCESS_TOKEN_EXPIRED,\n AUTH_ERROR_MISSING_AUTH_INFO,\n AUTH_ERROR_MISSING_REFRESH_TOKEN,\n AUTH_ERROR_LOCK_ACQUIRE_ERROR,\n AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR,\n AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR,\n AUTH_ERROR_ID_TOKEN_INVALID,\n AUTH_ERROR_MISSING_OTP_PARAM,\n AUTH_ERROR_MISSING_PKCE_PARAM,\n AUTH_ERROR_MISSING_NONCE_PARAM,\n} from \"./constants\";\n\n/**\n * @ignore\n */\nconst Lock = new SuperTokensLock();\n/**\n * @ignore\n */\nconst GET_TOKEN_SILENTLY_LOCK_KEY = 'openstackuicore.lock.getTokenSilently';\nconst GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT = 6000;\nconst NONCE_LEN = 16;\nexport const ACCESS_TOKEN_SKEW_TIME = 60;\nexport const RESPONSE_TYPE_IMPLICIT = \"token id_token\";\nexport const RESPONSE_TYPE_CODE = 'code';\nconst AUTH_INFO = 'authInfo';\nconst NONCE = 'nonce';\nconst PKCE = 'pkce';\nconst ID_TOKEN = 'idToken';\nconst BACK_ULR_PARAM_NAME = 'BackUrl';\n\n\n/**\n *\n * @param backUrl\n * @param prompt\n * @param tokenIdHint\n * @param provider\n * @param loginHint\n * @param otpLoginHint\n * @param tenant\n * @param backUrlParamName\n * @returns {*}\n */\nexport const getAuthUrl = (\n backUrl = null,\n prompt = null,\n tokenIdHint = null,\n provider = null,\n loginHint = null,\n otpLoginHint = null,\n tenant = null,\n backUrlParamName = BACK_ULR_PARAM_NAME\n ) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let redirectUri = getAuthCallback();\n let baseUrl = getOAuth2IDPBaseUrl();\n let scopes = getOAuth2Scopes();\n let flow = getOAuth2Flow();\n\n if (backUrl != null)\n redirectUri += `?${backUrlParamName}=${encodeURIComponent(backUrl)}`;\n\n let nonce = createNonce(NONCE_LEN);\n\n // store nonce to check it later\n putOnLocalStorage(NONCE, nonce);\n let url = URI(`${baseUrl}/oauth2/auth`);\n\n let query = {\n \"response_type\": encodeURI(flow),\n \"scope\": encodeURI(scopes),\n \"nonce\": nonce,\n \"response_mode\": 'fragment',\n \"client_id\": encodeURI(oauth2ClientId),\n \"redirect_uri\": encodeURI(redirectUri)\n };\n\n if (flow === RESPONSE_TYPE_CODE) {\n const pkce = createPKCECodes()\n putOnLocalStorage(PKCE, JSON.stringify(pkce));\n query['code_challenge'] = pkce.codeChallenge;\n query['code_challenge_method'] = 'S256';\n query['approval_prompt'] = 'force';\n }\n\n if (prompt) {\n query['prompt'] = prompt;\n }\n\n if (scopes && scopes.includes('offline_access')) {\n // then we need to force prompt=consent bc we are requesting an offline access\n // and we need to let the user know\n query['prompt'] = 'consent';\n }\n\n if (tokenIdHint) {\n query['id_token_hint'] = tokenIdHint;\n }\n\n if (provider) {\n query['provider'] = provider;\n }\n\n if (otpLoginHint) {\n query['otp_login_hint'] = otpLoginHint;\n }\n\n if (loginHint) {\n query['login_hint'] = encodeURI(loginHint);\n }\n\n if (tenant) {\n query['tenant'] = tenant;\n }\n\n url = url.query(query);\n //console.log(`getAuthUrl ${url.toString()}`);\n return url;\n}\n\n/**\n * @param idToken\n * @returns {*}\n */\nexport const getLogoutUrl = (idToken = null) => {\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n let url = URI(`${baseUrl}/oauth2/end-session`);\n let state = createNonce(NONCE_LEN);\n let postLogOutUri = `${getOrigin()}/auth/logout`;\n // store nonce to check it later\n putOnLocalStorage('post_logout_state', state);\n /**\n * post_logout_redirect_uri should be listed on oauth2 client settings\n * on IDP\n * \"Security Settings\" Tab -> Logout Options -> Post Logout Uris\n */\n const queryParams = {\n \"post_logout_redirect_uri\": encodeURI(postLogOutUri),\n \"client_id\": encodeURI(oauth2ClientId),\n \"state\": state,\n }\n\n if (idToken)\n queryParams.id_token_hint = idToken;\n\n return url.query(queryParams);\n}\n\nconst createNonce = (len) => {\n let possible = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\";\n let nonce = '';\n for (let i = 0; i < len; i++) {\n nonce += possible.charAt(Math.floor(Math.random() * possible.length));\n }\n return nonce;\n}\n\n/**\n *\n * @param backUrl\n * @param provider\n * @param prompt\n * @param loginHint\n * @param otpLoginHint\n * @param tenant\n */\nexport const doLogin = (\n backUrl = null,\n provider = null,\n prompt = null,\n loginHint = null,\n otpLoginHint = null,\n tenant = null\n) => {\n let url = getAuthUrl(backUrl, prompt, null, provider, loginHint, otpLoginHint, tenant);\n let location = getCurrentLocation()\n location.replace(url.toString());\n}\n\n/**\n *\n * @param backUrl\n * @param loginHint\n * @param otpLoginHint\n */\nexport const doLoginBasicLogin = (backUrl = null, loginHint = null, otpLoginHint = null) => {\n doLogin(backUrl, null, null, loginHint, otpLoginHint);\n}\n\nconst createPKCECodes = () => {\n const codeVerifier = base64URLEncode(getRandomBytes(64))\n const codeChallenge = getSHA256(codeVerifier, 'Base64url')\n const createdAt = new Date()\n const codePair = {\n codeVerifier,\n codeChallenge,\n createdAt\n }\n return codePair\n}\n\n/**\n\n * @param code\n * @param backUrl\n * @param backUrlParamName\n * @returns {Promise<{access_token: *, refresh_token: *, id_token: *, expires_in: *, error: *, error_description: *}>}\n */\nexport const emitAccessToken = async (code, backUrl = null, backUrlParamName = BACK_ULR_PARAM_NAME) => {\n\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n let redirectUri = getAuthCallback();\n let pkce = JSON.parse(getFromLocalStorage(PKCE, true));\n\n if (!pkce)\n throw Error(AUTH_ERROR_MISSING_PKCE_PARAM);\n\n if (backUrl != null)\n redirectUri += `?${backUrlParamName}=${encodeURIComponent(backUrl)}`;\n\n const payload = {\n 'code': code,\n 'grant_type': 'authorization_code',\n 'code_verifier': pkce.codeVerifier,\n \"client_id\": encodeURI(oauth2ClientId),\n \"redirect_uri\": encodeURI(redirectUri)\n };\n\n try {\n //const response = await http.post(`${baseUrl}/oauth2/token`, payload);\n //const {body: {access_token, refresh_token, id_token, expires_in}} = response;\n const response = await fetch(`${baseUrl}/oauth2/token`, {\n method: 'POST',\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(payload)\n }).catch(function (error) {\n console.log('Request failed:', error.message);\n });\n const json = await response.json();\n let {access_token, refresh_token, id_token, expires_in, error, error_description} = json;\n return {access_token, refresh_token, id_token, expires_in, error, error_description}\n } catch (err) {\n console.log(err);\n }\n};\n\nexport const MAX_RETRIES = 5;\nexport const BACKOFF_BASE_MS = 1000;\nexport const REFRESH_TOKEN_FETCH_TIMEOUT_MS = 10000;\n\nexport const retryWithBackoff = async (fn, maxRetries = MAX_RETRIES, baseDelayMs = BACKOFF_BASE_MS) => {\n for (let attempt = 0; attempt < maxRetries; attempt++) {\n try {\n return await fn();\n } catch (err) {\n // only retry transient network/server errors — everything else fails fast\n const isRetryable = err.message && err.message.startsWith(AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR);\n if (!isRetryable || attempt === maxRetries - 1) {\n throw err;\n }\n const delay = baseDelayMs * Math.pow(2, attempt);\n console.log(`retryWithBackoff retry ${attempt + 1}/${maxRetries} in ${delay}ms`);\n await new Promise(resolve => setTimeout(resolve, delay));\n }\n }\n};\n\nconst processRefreshToken = async (flow, refreshToken) => {\n\n if (flow === RESPONSE_TYPE_CODE && useOAuth2RefreshToken()) {\n if (!refreshToken) {\n clearAuthInfo();\n throw Error(AUTH_ERROR_MISSING_REFRESH_TOKEN);\n }\n\n let response = await retryWithBackoff(() => refreshAccessToken(refreshToken));\n let {access_token, expires_in, refresh_token, id_token} = response;\n if (typeof refresh_token === 'undefined') {\n refresh_token = null; // not using rotate policy\n }\n storeAuthInfo(access_token, expires_in, refresh_token, id_token);\n return access_token;\n }\n clearAuthInfo();\n throw Error(AUTH_ERROR_ACCESS_TOKEN_EXPIRED);\n}\n\n/**\n * @returns {Promise<*>}\n * @private\n */\nconst _getAccessToken = async () => {\n console.log(`openstack-uicore-foundation::Security::methods::_getAccessToken`);\n let authInfo = getAuthInfo();\n\n if (!authInfo) {\n console.log(`openstack-uicore-foundation::Security::methods::_getAccessToken AUTH_ERROR_MISSING_AUTH_INFO`);\n throw Error(AUTH_ERROR_MISSING_AUTH_INFO);\n }\n\n let {accessToken, expiresIn, accessTokenUpdatedAt, refreshToken} = authInfo;\n let flow = getOAuth2Flow();\n // check lifetime\n const now = moment().unix();\n let timeElapsedSecs = (now - accessTokenUpdatedAt);\n\n expiresIn = (expiresIn - ACCESS_TOKEN_SKEW_TIME);\n console.log(`openstack-uicore-foundation::Security::methods::_getAccessToken now ${now} accessTokenUpdatedAt ${accessTokenUpdatedAt} expiresIn ${expiresIn} timeElapsedSecs ${timeElapsedSecs}`)\n if (timeElapsedSecs >= expiresIn || accessToken == null) {\n console.log(`openstack-uicore-foundation::Security::methods::_getAccessToken access token expired, refreshing it ...`);\n accessToken = await processRefreshToken(flow, refreshToken);\n }\n return accessToken;\n}\n\n/**\n * @returns {Promise<*|undefined>}\n */\nexport const getAccessToken = async () => {\n if (typeof navigator !== 'undefined' && navigator.locks) {\n return await navigator.locks.request(GET_TOKEN_SILENTLY_LOCK_KEY, async lock => {\n console.log(`openstack-uicore-foundation::Security::methods::getAccessToken web lock api`, lock);\n return await _getAccessToken();\n });\n } else {\n if (\n await retryPromise(\n () => Lock.acquireLock(GET_TOKEN_SILENTLY_LOCK_KEY, GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT),\n 10\n )\n ) {\n try {\n return await _getAccessToken();\n } finally {\n await Lock.releaseLock(GET_TOKEN_SILENTLY_LOCK_KEY);\n }\n } else {\n // error on locking\n throw Error(AUTH_ERROR_LOCK_ACQUIRE_ERROR);\n }\n }\n}\n\n/**\n * @private\n */\nconst _clearAccessToken = () => {\n console.log(`openstack-uicore-foundation::Security::methods::_clearAccessToken`);\n\n let authInfo = getAuthInfo();\n\n if (!authInfo) {\n console.log(`openstack-uicore-foundation::Security::methods::_clearAccessToken AUTH_ERROR_MISSING_AUTH_INFO`);\n throw Error(AUTH_ERROR_MISSING_AUTH_INFO);\n }\n\n let {accessToken, expiresIn, accessTokenUpdatedAt, refreshToken} = authInfo;\n\n storeAuthInfo(null, 0, refreshToken)\n}\n\nexport const clearAccessToken = async () => {\n // see https://developer.mozilla.org/en-US/docs/Web/API/Web_Locks_API\n if (typeof navigator !== 'undefined' && navigator.locks) {\n await navigator.locks.request(GET_TOKEN_SILENTLY_LOCK_KEY, async lock => {\n console.log(`openstack-uicore-foundation::Security::methods::clearAccessToken web lock api`, lock);\n _clearAccessToken();\n });\n } else {\n if (\n await retryPromise(\n () => Lock.acquireLock(GET_TOKEN_SILENTLY_LOCK_KEY, GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT),\n 10\n )\n ) {\n try {\n _clearAccessToken();\n } finally {\n await Lock.releaseLock(GET_TOKEN_SILENTLY_LOCK_KEY);\n }\n } else {\n // error on locking\n throw Error(AUTH_ERROR_LOCK_ACQUIRE_ERROR);\n }\n }\n}\n\n\nexport const refreshAccessToken = async (refresh_token) => {\n\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n\n const payload = {\n 'grant_type': 'refresh_token',\n \"client_id\": encodeURI(oauth2ClientId),\n \"refresh_token\": refresh_token\n };\n\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), REFRESH_TOKEN_FETCH_TIMEOUT_MS);\n\n let response;\n try {\n response = await fetch(`${baseUrl}/oauth2/token`, {\n method: 'POST',\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(payload),\n signal: controller.signal\n });\n } catch (networkError) {\n // fetch rejects on network failures (DNS, timeout, no connectivity, abort)\n console.log('refreshAccessToken network error:', networkError.message);\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR}: ${networkError.message}`);\n } finally {\n clearTimeout(timeoutId);\n }\n\n if (!response.ok) {\n console.log(`refreshAccessToken server error: ${response.status} - ${response.statusText}`);\n if (response.status >= 500 || response.status === 408 || response.status === 429) {\n // transient error (server error, request timeout, rate limit) — should be retried\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR}: ${response.status} - ${response.statusText}`);\n }\n // token is genuinely revoked — this is a real auth error\n setSessionClearingState(true);\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR}: ${response.status} - ${response.statusText}`);\n }\n\n let json;\n try {\n json = await response.json();\n } catch (parseError) {\n // IDP returned non-JSON (HTML error page, empty body, etc.) — treat as transient\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR}: invalid JSON response from IDP`);\n }\n let {access_token, refresh_token: new_refresh_token, expires_in, id_token} = json;\n // Defensively ensure we never propagate an undefined access token.\n if (!access_token) {\n setSessionClearingState(true);\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR}: missing access_token in refresh response`);\n }\n return {access_token, refresh_token: new_refresh_token, expires_in, id_token}\n}\n\nexport const storeAuthInfo = (accessToken, expiresIn, refreshToken = null, idToken = null) => {\n\n let formerAuthInfo = getAuthInfo();\n\n let authInfo = {\n accessToken: accessToken,\n expiresIn: expiresIn,\n accessTokenUpdatedAt: Math.floor(Date.now() / 1000),\n };\n\n if (refreshToken == null && formerAuthInfo) {\n refreshToken = formerAuthInfo.refreshToken;\n }\n\n if (idToken == null && formerAuthInfo) {\n idToken = formerAuthInfo.idToken;\n }\n\n if (refreshToken) {\n authInfo['refreshToken'] = refreshToken;\n }\n\n if (idToken) {\n authInfo[ID_TOKEN] = idToken;\n Cookies.set(ID_TOKEN, idToken, {secure: true, sameSite: 'Lax'});\n } else {\n Cookies.remove(ID_TOKEN);\n }\n\n putOnLocalStorage(AUTH_INFO, JSON.stringify(authInfo));\n}\n\nexport const getAuthInfo = () => {\n try {\n let res = getFromLocalStorage(AUTH_INFO, false)\n if (!res) return null;\n return JSON.parse(res);\n } catch (err) {\n return null;\n }\n}\n\nexport const clearAuthInfo = () => {\n if (typeof window !== 'undefined') {\n removeFromLocalStorage(AUTH_INFO);\n Cookies.remove(ID_TOKEN);\n }\n};\n\nexport const getIdToken = () => {\n if (typeof window !== 'undefined') {\n const authInfo = getAuthInfo();\n if (authInfo) {\n return authInfo.idToken;\n }\n return null;\n }\n return null;\n};\n\nexport const getOAuth2ClientId = () => {\n if (typeof window !== 'undefined') {\n return window.OAUTH2_CLIENT_ID;\n }\n return null;\n};\n\nexport const getOAuth2Flow = () => {\n if (typeof window !== 'undefined') {\n return window.OAUTH2_FLOW || \"token id_token\";\n }\n return \"token id_token\";\n}\n\nexport const useOAuth2RefreshToken = () => {\n if (typeof window !== 'undefined') {\n return new Boolean(window.OAUTH2_USE_REFRESH_TOKEN || true);\n }\n return true;\n}\n\nexport const getOAuth2IDPBaseUrl = () => {\n if (typeof window !== 'undefined') {\n return window.IDP_BASE_URL;\n }\n return null;\n};\n\nexport const getOAuth2Scopes = () => {\n if (typeof window !== 'undefined') {\n return window.SCOPES;\n }\n return null;\n};\n\nexport const initLogOut = () => {\n let location = getCurrentLocation();\n location.replace(getLogoutUrl(getIdToken()).toString());\n}\n\nexport const validateIdToken = (idToken, issuer, audience) => {\n\n let verifier = new IdTokenVerifier({\n issuer: issuer,\n audience: audience\n });\n\n let storedNonce = getFromLocalStorage(NONCE, true);\n if (!storedNonce)\n throw Error(AUTH_ERROR_MISSING_NONCE_PARAM);\n\n let jwt = verifier.decode(idToken);\n let alg = jwt.header.alg;\n let kid = jwt.header.kid;\n let aud = jwt.payload.aud;\n let iss = jwt.payload.iss;\n let exp = jwt.payload.exp;\n let nbf = jwt.payload.nbf;\n let tnonce = jwt.payload.nonce || null;\n\n return tnonce == storedNonce && aud == audience && iss == issuer;\n}\n\nexport const passwordlessStart = (params) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let scopes = getOAuth2Scopes();\n let nonce = createNonce(NONCE_LEN);\n // store nonce to check it later\n putOnLocalStorage(NONCE, nonce);\n let baseUrl = getOAuth2IDPBaseUrl();\n let url = URI(`${baseUrl}/oauth2/auth`);\n\n let payload = {\n \"response_type\": \"otp\",\n \"scope\": encodeURI(scopes),\n \"nonce\": nonce,\n \"client_id\": encodeURI(oauth2ClientId),\n \"connection\": params.connection || \"email\",\n \"send\": params.send || \"code\",\n };\n\n if (params.hasOwnProperty('email')) {\n payload[\"email\"] = encodeURIComponent(params.email);\n }\n\n if (params.hasOwnProperty('phone_number')) {\n payload[\"phone_number\"] = encodeURIComponent(params.phone_number);\n }\n\n if (params.hasOwnProperty('redirect_uri')) {\n payload[\"redirect_uri\"] = encodeURIComponent(params.redirect_uri);\n }\n\n let req = http.post(url.toString());\n\n return req.send(payload).then((res) => {\n let json = res.body;\n return Promise.resolve({response: json});\n }).catch((err) => {\n return Promise.reject(err);\n });\n\n}\n\nexport const passwordlessLogin = (params) => (dispatch) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let scopes = getOAuth2Scopes();\n let baseUrl = getOAuth2IDPBaseUrl();\n let url = URI(`${baseUrl}/oauth2/token`);\n\n if (!params.hasOwnProperty(\"otp\")) {\n throw Error(AUTH_ERROR_MISSING_OTP_PARAM);\n }\n\n let payload = {\n \"grant_type\": \"passwordless\",\n \"connection\": params.connection || \"email\",\n \"scope\": encodeURI(scopes),\n \"client_id\": encodeURI(oauth2ClientId),\n \"otp\": params.otp\n };\n\n if (params.hasOwnProperty('email')) {\n payload[\"email\"] = encodeURIComponent(params.email);\n }\n\n if (params.hasOwnProperty('phone_number')) {\n payload[\"phone_number\"] = encodeURIComponent(params.phone_number);\n }\n\n let req = http.post(url.toString());\n\n return req.send(payload).then((res) => {\n try {\n // now we got token\n let json = res.body;\n let {access_token, expires_in, refresh_token, id_token} = json;\n\n if (typeof refresh_token === 'undefined') {\n refresh_token = null; // not using rotate policy\n }\n\n if (typeof id_token === 'undefined') {\n id_token = null; // not using rotate policy\n }\n\n // verify id token\n\n if (id_token) {\n if (!validateIdToken(id_token, baseUrl, oauth2ClientId)) {\n throw Error(AUTH_ERROR_ID_TOKEN_INVALID);\n }\n }\n\n storeAuthInfo(access_token, expires_in, refresh_token, id_token);\n\n if (dispatch) {\n dispatch({\n type: SET_LOGGED_USER,\n payload: {sessionState: null}\n });\n }\n\n return Promise.resolve({response: json});\n } catch (e) {\n console.log(e);\n return Promise.reject(e);\n }\n }).catch((err) => {\n return Promise.reject(err);\n });\n}\n\nexport const isIdTokenAlive = (nowEpoch = null) => () => {\n\n if (!nowEpoch) {\n nowEpoch = Math.floor(Date.now() / 1000);\n }\n\n const idToken = getIdToken();\n if (!idToken)\n throw Error('Id Token not set.');\n\n const issuer = getOAuth2IDPBaseUrl();\n const audience = getOAuth2ClientId();\n\n let verifier = new IdTokenVerifier({\n issuer: issuer,\n audience: audience\n });\n\n const jwt = verifier.decode(idToken);\n const exp = jwt.payload.exp;\n\n // check life time\n return exp - (nowEpoch + ACCESS_TOKEN_SKEW_TIME) > 0;\n}\n","/**\n * Copyright 2017 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific flanguage governing permissions and\n * limitations under the License.\n **/\n\nimport request from 'superagent/lib/client';\nimport URI from \"urijs\";\nURI.escapeQuerySpace = false;\n\nlet http = request;\nimport Swal from 'sweetalert2';\nimport T from \"i18n-react/dist/i18n-react\";\nimport { isClearingSessionState, setSessionClearingState, getCurrentPathName } from './methods';\nimport { CLEAR_SESSION_STATE } from '../components/security/actions';\nimport { doLogin, initLogOut } from '../components/security/methods';\nimport {CODE_200} from \"./constants\";\n\nexport const GENERIC_ERROR = \"Yikes. Something seems to be broken. Our web team has been notified, and we apologize for the inconvenience.\";\nexport const RESET_LOADING = 'RESET_LOADING';\nexport const START_LOADING = 'START_LOADING';\nexport const STOP_LOADING = 'STOP_LOADING';\nexport const VALIDATE = 'VALIDATE';\nexport const CLEAR_MESSAGE = 'CLEAR_MESSAGE';\nexport const SHOW_MESSAGE = 'SHOW_MESSAGE';\nexport const SET_SNACKBAR_MESSAGE = \"SET_SNACKBAR_MESSAGE\";\nexport const CLEAR_SNACKBAR_MESSAGE = \"CLEAR_SNACKBAR_MESSAGE\";\n\nexport const createAction = type => payload => ({\n type,\n payload\n});\n\nexport const resetLoading = createAction(RESET_LOADING);\nexport const startLoading = createAction(START_LOADING);\nexport const stopLoading = createAction(STOP_LOADING);\n\nexport const clearSnackbarMessage = () => (dispatch) => {\n dispatch(createAction(CLEAR_SNACKBAR_MESSAGE)({}));\n};\n\nexport const setSnackbarMessage = (message) => (dispatch) => {\n dispatch(createAction(SET_SNACKBAR_MESSAGE)(message));\n};\n\nexport const snackbarErrorHandler = (err, res) => (dispatch, state) => {\n authErrorHandler(err, res, setSnackbarMessage)(dispatch, state);\n};\n\nexport const snackbarSuccessHandler = (message) => (dispatch, state) =>\n setSnackbarMessage({ ...message, type: \"success\", code: CODE_200 })(\n dispatch,\n state\n );\n\nconst xhrs = {};\nconst etagCache = {};\n\nconst cancel = (key) => {\n if(xhrs[key]) {\n xhrs[key].abort();\n console.log(`aborted request ${key}`);\n delete xhrs[key];\n }\n}\n\nconst schedule = (key, req) => {\n // console.log(`scheduling ${key}`);\n xhrs[key] = req;\n};\n\nconst isObjectEmpty = (obj) => {\n return Object.keys(obj).length === 0 && obj.constructor === Object ;\n}\n\nconst buildNotifyHandlerPayload = (httpCode, title, content, type) => ({ httpCode, title, html: content, type });\nconst buildNotifyHandlerErrorPayload = (httpCode, title, content) => buildNotifyHandlerPayload(httpCode, title, content, \"error\");\nconst buildNotifyHandlerWarningPayload = (httpCode, title, content) => buildNotifyHandlerPayload(httpCode, title, content, \"warning\");\n\nconst initLogin = () => (dispatch) => {\n const currentLocation = getCurrentPathName();\n const clearingSessionState = isClearingSessionState();\n dispatch({\n type: CLEAR_SESSION_STATE,\n payload: {}\n });\n if (!clearingSessionState) {\n setSessionClearingState(true);\n console.log(\"authErrorHandler 401 - re login\");\n doLogin(currentLocation);\n }\n};\n\nconst normalizeFormDataPayload = (req, formData) => {\n if(!isObjectEmpty(formData)) {\n Object.keys(formData).forEach(function (key) {\n let value = formData[key];\n if (Array.isArray(value)) {\n value.forEach(item => {\n req.field(`${key}[]`, item);\n });\n } else {\n req.field(key, value);\n }\n });\n }\n};\n\nexport const authErrorHandler = (\n err,\n res,\n notifyErrorHandler = showMessage\n) => (dispatch) => {\n\n const code = err.status;\n let msg = \"\";\n let payload, callback;\n\n dispatch(stopLoading());\n\n switch (code) {\n case 401:\n if (notifyErrorHandler !== showMessage) {\n payload = buildNotifyHandlerErrorPayload(code, \"ERROR\", T.translate(\"errors.user_not_auth\"));\n callback = () => dispatch(initLogin());\n } else {\n dispatch(initLogin());\n }\n break;\n case 403:\n payload = buildNotifyHandlerErrorPayload(code, \"ERROR\", T.translate(\"errors.user_not_authz\"));\n callback = initLogOut;\n break;\n case 404:\n msg = err.response.body?.message || err.response.error?.message || err.message;\n if (err.response.body?.errors?.length) {\n msg += `<br>${err.response.body.errors.join(\"<br>\")}`;\n }\n payload = buildNotifyHandlerWarningPayload(code, \"Not Found\", msg);\n break;\n case 412:\n for (const [key, value] of Object.entries(err.response.body.errors)) {\n msg += isNaN(key) ? `${key}: ` : \"\";\n msg += `${value}<br>`;\n }\n dispatch({\n type: VALIDATE,\n payload: { errors: err.response.body.errors }\n });\n payload = buildNotifyHandlerWarningPayload(code, \"Validation error\", msg);\n break;\n default:\n payload = buildNotifyHandlerErrorPayload(code, \"ERROR\", T.translate(\"errors.server_error\"));\n }\n\n if (payload)\n dispatch(notifyErrorHandler(payload, callback));\n}\n\nexport const getRequest =(\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {},\n useEtag = false\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n let key = url.toString();\n\n if(!isObjectEmpty(params)) {\n // remove the access token\n const { access_token: _, ...newParams} = params;\n // and generate new key\n key = url.query(newParams).toString();\n url = url.query(params);\n }\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n cancel(key);\n\n return new Promise((resolve, reject) => {\n let req = http.get(url.toString());\n if(useEtag && etagCache.hasOwnProperty(key)){\n const { etag } = etagCache[key];\n if(etag){\n req.set('If-None-Match', etag)\n }\n }\n\n req.timeout({\n response: 60000,\n deadline: 60000,\n })\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject, key, useEtag))\n\n schedule(key, req);\n });\n};\n\nexport const putRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => ( dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n if(payload == null)\n payload = {};\n http.put(url.toString())\n .send(payload)\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject))\n });\n};\n\nexport const deleteRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params) => (dispatch, state) => {\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n if(payload == null)\n payload = {};\n\n http.delete(url)\n .send(payload)\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const postRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n let request = http.post(url);\n\n if(payload != null)\n request.send(payload);\n else // to be a simple CORS request\n request.set('Content-Type', 'text/plain');\n\n request.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const postFile = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n file,\n fileMetadata = {},\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n const req = http.post(url)\n .attach('file', file);\n\n normalizeFormDataPayload(req, fileMetadata);\n\n req.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const putFile = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n file = null,\n fileMetadata = {},\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n const req = http.put(url);\n\n if(file != null){\n req.attach('file', file);\n }\n\n normalizeFormDataPayload(req, fileMetadata)\n\n req.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const defaultErrorHandler = (err, res) => (dispatch) => {\n let body = res.body;\n let text = '';\n if(body instanceof Object){\n if(body.hasOwnProperty('message'))\n text = body.message;\n }\n Swal.fire(res.statusText, text, \"error\");\n}\n\nconst byLowerCase = toFind => value => toLowerCase(value) === toFind;\nconst toLowerCase = value => value.toLowerCase();\nconst getKeys = headers => Object.keys(headers);\n\nexport const getHeaderCaseInsensitive = (headerName, headers = {}) => {\n const key = getKeys(headers).find(byLowerCase(headerName));\n return key ? headers[key] : undefined;\n};\n\nexport const responseHandler = ( dispatch, state, receiveActionCreator, errorHandler, resolve, reject, key = null, useEtag= false ) =>\n\n (err, res) => {\n\n if (err || !res.ok) {\n let code = err.status;\n\n if(code === 304 && etagCache.hasOwnProperty(key) && useEtag){\n const { body } = etagCache[key];\n\n if(typeof receiveActionCreator === 'function') {\n dispatch(receiveActionCreator({response: body}));\n return resolve({response: body});\n }\n\n dispatch(receiveActionCreator);\n return resolve({response: body});\n }\n if(errorHandler) {\n errorHandler(err, res)(dispatch, state);\n }\n return reject({ err, res, dispatch, state })\n }\n\n let json = res.body;\n\n if(useEtag) {\n const responseETAG = getHeaderCaseInsensitive('etag', res.headers);\n if (responseETAG) {\n etagCache[key] = { etag: responseETAG, body: json};\n }\n }\n\n if(typeof receiveActionCreator === 'function') {\n dispatch(receiveActionCreator({response: json}));\n return resolve({response: json});\n }\n dispatch(receiveActionCreator);\n return resolve({response: json});\n}\n\n\nexport const fetchErrorHandler = (response) => {\n let code = response.status;\n let msg = response.statusText;\n\n switch (code) {\n case 403:\n Swal.fire(\"ERROR\", T.translate(\"errors.user_not_authz\"), \"warning\");\n break;\n case 401:\n Swal.fire(\"ERROR\", T.translate(\"errors.session_expired\"), \"error\");\n break;\n case 412:\n Swal.fire(\"ERROR\", msg, \"warning\");\n case 500:\n Swal.fire(\"ERROR\", T.translate(\"errors.server_error\"), \"error\");\n }\n}\n\nexport const fetchResponseHandler = (response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.json();\n }\n}\n\nexport const showMessage = (settings, callback = null) => (dispatch) => {\n dispatch(stopLoading());\n Swal.fire(settings).then((result) => {\n if (result.value && typeof callback === 'function') {\n callback();\n }\n });\n}\n\nexport const showSuccessMessage = (html) => (dispatch) => {\n dispatch(stopLoading());\n Swal.fire({\n title: T.translate(\"general.done\"),\n html: html,\n type: 'success'\n });\n}\n\nexport const downloadFileByContent = (filename, content, mime) => {\n let link = document.createElement('a');\n link.textContent = 'download';\n link.download = filename;\n link.href = `data:${mime},${encodeURIComponent(content)}`\n document.body.appendChild(link); // Required for FF\n link.click();\n document.body.removeChild(link);\n}\n\nexport const getCSV = (endpoint, params, filename, header = null) => (dispatch) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n dispatch(startLoading());\n\n return fetch(url.toString())\n .then((response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.text();\n }\n })\n .then((csv) => {\n dispatch(stopLoading());\n\n if (header) {\n csv = header + '\\r\\r' + csv;\n }\n downloadFileByContent(filename, csv, 'text/csv;charset=utf-8');\n })\n .catch(fetchErrorHandler);\n};\n\nexport const getRawCSV = (endpoint, params, header = null) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n return fetch(url.toString())\n .then((response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.text();\n }\n })\n .then((csv) => {\n if (header) {\n csv = header + '\\r\\r' + csv;\n }\n\n return csv;\n })\n .catch(fetchErrorHandler);\n};\n\nexport const escapeFilterValue = (value) => {\n value = String(value);\n // escape backslash first so you don't accidentally break your own escapes\n value = value.replace(/\\\\/g, \"\\\\\\\\\");\n value = value.replace(/,/g, \"\\\\,\");\n value = value.replace(/;/g, \"\\\\;\");\n // especial case for literal +\n value = value.replace(/\\+/g, \"%2B\");\n return value;\n};\n","export const CENTS_FACTOR = 100n;\nexport const TWO_DECIMAL_PLACES = 2;\nexport const THREE_DECIMAL_PLACES = 3;\nexport const ONE_CENT = 1n;\nexport const ZERO_INT = 0;\n\nexport const CODE_200 = 200;\n\nexport const DEBOUNCE_WAIT_250 = 250;\nexport const DEBOUNCE_WAIT = 500;\n\nexport const NOTIFICATION_TIMEOUT = 2000;\nexport const DEFAULT_PER_PAGE = 10;\nexport const TWENTY_PER_PAGE = 20;\nexport const FIFTY_PER_PAGE = 50;\nexport const MAX_PER_PAGE = 100;\n\nexport const INT_BASE = 10;\n\nexport const ONE_HUNDRED = 100;\nexport const MILLISECONDS_IN_SECOND = 1000;\n\nexport const MILLISECONDS_TO_SECONDS = 1000;\n\nexport const BYTES_PER_MB = 1_048_576; // 1024 * 1024\n\nexport const MAX_INVENTORY_IMAGE_UPLOAD_SIZE = 512000;\nexport const MAX_INVENTORY_IMAGES_UPLOAD_QTY = 5;\nexport const ALLOWED_INVENTORY_IMAGE_FORMATS = [\"jpg\", \"jpeg\", \"png\"];\n\nexport const METAFIELD_TYPES_WITH_OPTIONS = [\n \"CheckBoxList\",\n \"ComboBox\",\n \"RadioButtonList\"\n];\n\nexport const METAFIELD_TYPES = [\n \"CheckBox\",\n ...METAFIELD_TYPES_WITH_OPTIONS,\n \"Text\",\n \"TextArea\",\n \"Quantity\",\n \"DateTime\",\n \"Time\"\n];\n\nexport const DISCOUNT_TYPES = {\n AMOUNT: \"Amount\",\n RATE: \"Rate\"\n};\n\nexport const RATE_FIELDS = {\n EARLY_BIRD: \"early_bird_rate\",\n STANDARD: \"standard_rate\",\n ONSITE: \"onsite_rate\"\n};\n\nexport const DECIMAL_DIGITS = 2;\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"spark-md5\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/sha256\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/enc-base64url\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/enc-hex\");","import SparkMD5 from \"spark-md5\";\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nconst MAX_BYTES = 65536\n// Node supports requesting up to this number of bytes\n// https://github.com/nodejs/node/blob/master/lib/internal/crypto/random.js#L48\nconst MAX_UINT32 = 4294967295\nconst crypto = typeof window !== 'undefined' ? (window.crypto || window.msCrypto) : null;\nimport sha256 from 'crypto-js/sha256';\nimport Base64url from 'crypto-js/enc-base64url'\nimport Hex from 'crypto-js/enc-hex'\nexport const getRandomBytes = (size) => {\n // phantomjs needs to throw\n if (size > MAX_UINT32) throw new RangeError('requested too many random bytes')\n const bytes = Buffer.allocUnsafe(size)\n if(!crypto) return a;\n if (size > 0) { // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) { // this is the max bytes crypto.getRandomValues\n // can do at once see https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n for (let generated = 0; generated < size; generated += MAX_BYTES) {\n // buffer.slice automatically checks if the end is past the end of\n // the buffer so we don't have to here\n crypto.getRandomValues(bytes.slice(generated, generated + MAX_BYTES))\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n return bytes\n}\n\nexport const getSHA256 = (message, format = 'hex') => {\n\n let f = Hex;\n if(format === 'Base64url')\n f = Base64url;\n\n return sha256(message).toString(f);\n}\n\nexport const getMD5 = (file) => {\n return new Promise((resolve, reject) => {\n const chunkSize = 2 * 1024 * 1024; // 2 MB by chunk\n const spark = new SparkMD5.ArrayBuffer();\n const fileReader = new FileReader();\n let cursor = 0;\n\n fileReader.onload = e => {\n spark.append(e.target.result); \n cursor += chunkSize;\n\n if (cursor < file.size) {\n readNextChunk();\n } else {\n resolve(spark.end()); // final MD5\n }\n };\n\n fileReader.onerror = () => reject(\"Error reading the file\");\n\n function readNextChunk() {\n const slice = file.slice(cursor, cursor + chunkSize);\n fileReader.readAsArrayBuffer(slice);\n }\n\n readNextChunk();\n });\n}","/**\n * Copyright 2018 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport moment from 'moment-timezone';\nimport URI from \"urijs\";\n\nexport const findElementPos = (obj) => {\n var curtop = -70;\n if (obj.offsetParent) {\n do {\n curtop += obj.offsetTop;\n } while (obj = obj.offsetParent);\n return [curtop];\n }\n};\n\nexport const epochToMoment = (atime) => {\n if(!atime) return atime;\n atime = atime * 1000;\n return moment(atime);\n};\n\nexport const epochToMomentTimeZone = (atime, time_zone) => {\n if(!atime) return atime;\n atime = atime * 1000;\n return moment(atime).tz(time_zone);\n};\n\nexport const formatEpoch = (atime, format = 'M/D/YYYY h:mm a') => {\n if(!atime) return atime;\n return epochToMoment(atime).format(format);\n};\n\nexport const parseLocationHour = (hour) => {\n let parsedHour = hour.toString();\n if(parsedHour.length < 4) parsedHour = `0${parsedHour}`;\n parsedHour = parsedHour.match(/.{2}/g);\n parsedHour = parsedHour.join(':');\n return parsedHour;\n}\n\nexport const objectToQueryString = (obj) => {\n var str = \"\";\n for (var key in obj) {\n if (str != \"\") {\n str += \"&\";\n }\n str += key + \"=\" + encodeURIComponent(obj[key]);\n }\n\n return str;\n};\n\nexport const getBackURL = () => {\n let url = URI(window.location.href);\n let query = url.search(true);\n let fragment = url.fragment();\n let backUrl = query.hasOwnProperty('BackUrl') ? query['BackUrl'] : null;\n if(backUrl != null && fragment != null && fragment != ''){\n backUrl += `#${fragment}`;\n }\n return backUrl;\n};\n\nexport const toSlug = (text) =>{\n text = text.toLowerCase();\n return text.replace(/[^a-zA-Z0-9]+/g,'_');\n}\n\nexport const getAuthCallback = () => {\n if(typeof window !== 'undefined') {\n return `${window.location.origin}/auth/callback`;\n }\n return null;\n};\n\nexport const getCurrentLocation = () => {\n let location = '';\n if(typeof window !== 'undefined') {\n location = window.location;\n // check if we are on iframe\n if (window.top)\n location = window.top.location;\n }\n return location;\n};\n\nexport const getOrigin = () => {\n if(typeof window !== 'undefined') {\n return window.location.origin;\n }\n return null;\n};\n\nexport const getCurrentPathName = () => {\n if(typeof window !== 'undefined') {\n return window.location.pathname;\n }\n return null;\n};\n\nexport const getCurrentHref = () => {\n if(typeof window !== 'undefined') {\n return window.location.href;\n }\n return null;\n};\n\nexport const getAllowedUserGroups = () => {\n if(typeof window !== 'undefined') {\n return window.ALLOWED_USER_GROUPS || '';\n }\n return null;\n};\n\nexport const buildAPIBaseUrl = (relativeUrl) => {\n if(typeof window !== 'undefined'){\n return `${window.API_BASE_URL}${relativeUrl}`;\n }\n return null``;\n};\n\nexport const putOnLocalStorage = (key, value) => {\n if(typeof window !== 'undefined') {\n window.localStorage.setItem(key, value);\n }\n};\n\nexport const getFromLocalStorage = (key, removeIt) => {\n if(typeof window !== 'undefined') {\n let val = window.localStorage.getItem(key);\n if(removeIt){\n console.log(`getFromLocalStorage removing key ${key}`);\n removeFromLocalStorage(key);\n }\n return val;\n }\n return null;\n};\n\nexport const removeFromLocalStorage = (key) => {\n if(typeof window !== 'undefined') {\n window.localStorage.removeItem(key);\n }\n}\n\nexport const isClearingSessionState = () => {\n if(typeof window !== 'undefined') {\n return window.clearing_session_state;\n }\n return false;\n};\n\nexport const setSessionClearingState = (val) => {\n if(typeof window !== 'undefined') {\n window.clearing_session_state = val;\n }\n};\n\nexport const getCurrentUserLanguage = () => {\n let language = 'en';\n if(typeof navigator !== 'undefined') {\n language = (navigator.languages && navigator.languages[0]) || navigator.language || navigator.userLanguage;\n }\n return language;\n};\n\nexport const scrollToError = (errors) => {\n if(Object.keys(errors).length > 0) {\n const firstError = Object.keys(errors)[0];\n const firstNode = document.getElementById(firstError);\n if (firstNode) window.scrollTo(0, findElementPos(firstNode));\n }\n};\n\nexport const hasErrors = (field, errors) => {\n if(field in errors) {\n return errors[field];\n }\n return '';\n};\n\nexport const shallowEqual = (object1, object2) => {\n const keys1 = Object.keys(object1);\n const keys2 = Object.keys(object2);\n\n if (keys1.length !== keys2.length) {\n return false;\n }\n\n for (let key of keys1) {\n if (object1[key] !== object2[key]) {\n return false;\n }\n }\n\n return true;\n};\n\nexport const arraysEqual = (a1, a2) =>\n a1.length === a2.length && a1.every((o, idx) => shallowEqual(o, a2[idx]));\n\nexport const isEmpty = (obj) => {\n return Object.keys(obj).length === 0;\n};\n\n\nexport const base64URLEncode = (str) => {\n return str\n .toString('base64')\n .replace(/\\+/g, '-')\n .replace(/\\//g, '_')\n .replace(/=/g, '')\n}\n\nexport const retryPromise = async (\n cb,\n maxNumberOfRetries = 3\n) => {\n for (let i = 0; i < maxNumberOfRetries; i++) {\n if (await cb()) {\n return true;\n }\n }\n\n return false;\n}\n\nexport const getTimeServiceUrl = () => {\n if(typeof window !== 'undefined') {\n return window.TIMEINTERVALSINCE1970_API_URL || process.env.TIMEINTERVALSINCE1970_API_URL;\n }\n return null;\n};\n\nexport const getEventLocation = (event, summitVenueCount, summitShowLocDate = null, nowUtc = null) => {\n const shouldShowVenues = (summitShowLocDate && nowUtc) ? summitShowLocDate * 1000 < nowUtc : true;\n const locationName = [];\n const { location } = event;\n\n if (!shouldShowVenues) return 'TBA';\n\n if (!location) return 'TBA';\n\n if (summitVenueCount > 1 && location.venue?.name) locationName.push(location.venue.name);\n if (location.floor?.name) locationName.push(location.floor.name);\n if (location.name) locationName.push(location.name);\n\n return locationName.length > 0 ? locationName.join(' - ') : 'TBA';\n};\n\nexport const getEventHosts = (event) => {\n let hosts = [];\n if (event.speakers?.length > 0) {\n hosts = [...event.speakers];\n }\n if (event.moderator) hosts.push(event.moderator);\n\n return hosts;\n};\n\nconst loadImage = async url => {\n const img = document.createElement('img')\n img.src = url\n img.crossOrigin = 'anonymous'\n\n return new Promise((resolve, reject) => {\n img.onload = () => resolve(img)\n img.onerror = reject\n })\n}\n\nexport const convertSVGtoImg = async (svgUrl) => {\n const img = await loadImage(svgUrl)\n const newWidth = 100\n const newHeight = Math.floor(img.naturalHeight * 100 / img.naturalWidth)\n\n const canvas = document.createElement('canvas')\n canvas.width = newWidth\n canvas.height = newHeight\n canvas.getContext('2d').drawImage(img, 0, 0, newWidth, newHeight)\n\n const url = await canvas.toDataURL(`image/png`, 1.0)\n console.log(url, newWidth, newHeight);\n return {url, width: newWidth, height: newHeight}\n}\n\nexport const isRateEnabled = (value) =>\n value !== null && value !== undefined && value !== \"\";\n\n/**\n * Returns true if value is null, undefined, empty/whitespace string,\n * empty array, or empty object.\n */\nexport const empty = (value) => {\n if (value === null || value === undefined) return true;\n if (typeof value === \"string\") return value.trim().length === 0;\n if (Array.isArray(value)) return value.length === 0;\n if (typeof value === \"object\") return Object.keys(value).length === 0;\n return false;\n};\n","/**\n * Copyright 2018 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport { fetchErrorHandler, fetchResponseHandler, escapeFilterValue } from \"./actions\";\nimport { getAccessToken } from '../components/security/methods';\nimport { buildAPIBaseUrl } from \"./methods\";\nimport _ from 'lodash';\nimport moment from 'moment-timezone'\n\nexport const RECEIVE_COUNTRIES = 'RECEIVE_COUNTRIES';\nimport URI from \"urijs\";\nimport {DEBOUNCE_WAIT, DEFAULT_PER_PAGE, MAX_PER_PAGE} from \"./constants\";\n\nURI.escapeQuerySpace = false;\n\nconst _fetchPublic = async (endpoint, callback, options = {}) => {\n return fetch(buildAPIBaseUrl(endpoint.toString()), options)\n .then(fetchResponseHandler)\n .then((json) => {\n if(typeof callback === 'function')\n callback(json.data);\n })\n .catch(response => {\n const code = response.status;\n if (code === 404) callback([]);\n return response;\n })\n .catch(fetchErrorHandler);\n}\n\nconst _fetchPromise = async (endpoint, options = {}) => {\n let accessToken;\n\n try {\n accessToken = await getAccessToken();\n } catch (e) {\n return Promise.reject(e);\n }\n\n endpoint.addQuery('access_token', accessToken);\n\n return fetch(buildAPIBaseUrl(endpoint.toString()), options)\n .then(fetchResponseHandler)\n .catch(fetchErrorHandler);\n}\n\n/**\n * @param endpoint\n * @param callback\n * @param options\n * @returns {Promise<Response | void>}\n * @private\n */\nconst _fetch = async (endpoint, callback, options = {}) => {\n\n let accessToken;\n\n try {\n accessToken = await getAccessToken();\n } catch (e) {\n if(typeof callback === 'function')\n callback(e);\n return Promise.reject();\n }\n\n endpoint.addQuery('access_token', accessToken);\n\n return _fetchPublic(endpoint, callback, options);\n}\n\n/**\n *\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryMembers = _.debounce(async (input, callback, per_page= DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/members`);\n\n endpoint.addQuery('expand', `tickets,rsvp,schedule_summit_events,all_affiliations`);\n endpoint.addQuery('order','first_name,last_name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `full_name@@${input},first_name@@${input},last_name@@${input},email@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n *\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryAttendees = _.debounce(async (summitId, input, callback, per_page= DEFAULT_PER_PAGE) => {\n \n let endpoint = URI(`/api/v1/summits/${summitId}/attendees`);\n \n endpoint.addQuery('order','first_name,last_name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n \n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `full_name=@${input},email=@${input}`);\n }\n \n _fetch(endpoint, callback);\n \n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const querySummits = _.debounce(async (input, callback, per_page= DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/all`);\n\n endpoint.addQuery('expand', `tickets,rsvp,schedule_summit_events,all_affiliations`);\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n\nexport const fetchAllSummits = async (onlyActive) => {\n\n let endpoint = URI(`/api/v2/summits/all`);\n\n endpoint.addQuery('fields', 'id,name,start_date,end_date');\n endpoint.addQuery('expand', 'none');\n endpoint.addQuery('relations', 'none');\n endpoint.addQuery('order','-start_date');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', MAX_PER_PAGE);\n\n if (onlyActive) {\n const now = moment().tz(\"UTC\").unix();\n endpoint.addQuery('filter[]', `end_date>=${now}`);\n }\n\n return _fetchPromise(endpoint)\n .then((json) => json.data);\n};\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const querySpeakers = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE ) => {\n\n\n let endpoint = URI(`/api/v1/${summitId ? `summits/${summitId}/speakers`:`speakers`}`);\n\n endpoint.addQuery('expand', `member,registration_request`);\n endpoint.addQuery('order','first_name,last_name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `full_name@@${input},first_name@@${input},last_name@@${input},email@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryTags = _.debounce(async (summitId, input, callback, per_page = 50) => {\n\n let endpoint = URI(`/api/v1/${summitId ? `summits/${summitId}/track-tag-groups/all/allowed-tags`:`tags`}`);\n\n if(summitId)\n endpoint.addQuery('expand', `tag,track_tag_group`);\n\n endpoint.addQuery('order','tag');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `tag@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryTracks = _.debounce(async (summitId, input, callback, excludedIds = [], per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/tracks`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if (excludedIds?.length > 0) {\n endpoint.addQuery('filter[]', `not_id==${excludedIds.join(\"||\")}`);\n }\n\n if (input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryTrackGroups = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/track-groups`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=, *): Promise<void>)|*>}\n */\nexport const queryEvents = _.debounce(async (summitId, input, onlyPublished = false, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/events` + (onlyPublished ? '/published' : ''));\n\n endpoint.addQuery('order','title');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `title@@${input}`);\n }\n\n _fetch(endpoint, callback);\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=, *=): Promise<void>)|*>}\n */\nexport const queryEventTypes = _.debounce(async (summitId, input, callback, eventTypeClassName = null, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/event-types`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n if (eventTypeClassName) {\n eventTypeClassName = escapeFilterValue(eventTypeClassName);\n endpoint.addQuery('filter[]', `class_name==${eventTypeClassName}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryGroups = _.debounce(async (input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/groups`);\n\n endpoint.addQuery('order','title,code');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `title@@${input},code@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryCompanies = _.debounce(async (input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/companies`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryRegistrationCompanies = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/registration-companies`);\n\n endpoint.addQuery('order','name')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const querySponsors = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/sponsors`);\n\n endpoint.addQuery('expand','company,sponsorship,sponsorship.type')\n endpoint.addQuery('order','id')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `company_name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\nexport const querySponsorsV2 = _.debounce(async (input, summitId, callback) => {\n const endpoint = URI(\n `/api/v2/summits/${summitId}/sponsors`\n );\n const escapedInput = escapeFilterValue(input);\n endpoint.addQuery(\"fields\", \"id,company.name,company.id\");\n endpoint.addQuery(\"relations\", \"company\");\n endpoint.addQuery(\"expand\", \"company\");\n if (escapedInput) {\n endpoint.addQuery(\"filter\", `company_name=@${escapedInput}`);\n }\n _fetchPromise(endpoint)\n .then((json) => {\n const options = [...json.data].map((sp) => ({\n id: sp.id,\n name: sp.company.name\n }));\n callback(options);\n })\n .catch(fetchErrorHandler);\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const querySponsorsWithBadgeScans = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/sponsors`);\n\n endpoint.addQuery('expand','company,sponsorship,sponsorship.type');\n endpoint.addQuery('fields','id,company.name,sponsorship.type.name');\n endpoint.addQuery('relations','none,company.none,sponsorship.type.none');\n endpoint.addQuery('filter[]','badge_scans_count>0');\n endpoint.addQuery('order','+company_name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `company_name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryAccessLevels = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/summits/${summitId}/access-level-types`);\n\n endpoint.addQuery('order','name')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const queryOrganizations = _.debounce(async (input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/v1/organizations`);\n\n endpoint.addQuery('order','name')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\nexport const getLanguageList = (callback, signal) => {\n return _fetchPublic(new URI(`/api/public/v1/languages`), callback, { signal });\n};\n\nexport const getCountryList = (callback, signal) => {\n return _fetchPublic(new URI(`/api/public/v1/countries`), callback, { signal });\n};\n\nlet geocoder;\n\nexport const geoCodeAddress = (address) => {\n\n if (!geocoder) geocoder = new google.maps.Geocoder();\n\n // return a Promise\n return new Promise(function(resolve,reject) {\n geocoder.geocode( { 'address': address}, function(results, status) {\n if (status == google.maps.GeocoderStatus.OK) {\n // resolve results upon a successful status\n resolve(results);\n } else {\n // reject status upon un-successful status\n reject(status);\n }\n });\n });\n};\n\nexport const geoCodeLatLng = (lat, lng) => {\n\n if (!geocoder) geocoder = new google.maps.Geocoder();\n\n let latlng = {lat: parseFloat(lat), lng: parseFloat(lng)};\n // return a Promise\n return new Promise(function(resolve,reject) {\n geocoder.geocode( { 'location': latlng}, function(results, status) {\n if (status == google.maps.GeocoderStatus.OK) {\n // resolve results upon a successful status\n resolve(results);\n } else {\n // reject status upon un-successful status\n reject(status);\n }\n });\n });\n};\n\n/**\n * @type {DebouncedFunc<(function(*, *=, *, *=, *=): Promise<void>)|*>}\n */\nexport const queryTicketTypes = _.debounce(async (summitId, filters = {}, callback, version = 'v1', per_page = DEFAULT_PER_PAGE) => {\n\n let endpoint = URI(`/api/${version}/summits/${summitId}/ticket-types`);\n\n endpoint.addQuery('order','name');\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(filters.hasOwnProperty('name')) {\n const name = escapeFilterValue(filters.name);\n if(name && name != '')\n endpoint.addQuery('filter[]', `name@@${name}`);\n }\n\n if(filters.hasOwnProperty('audience')){\n const audience = escapeFilterValue(filters.audience);\n if(audience && audience != '')\n endpoint.addQuery('filter[]', `audience==${audience}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *=): Promise<void>)|*>}\n */\nexport const querySponsoredProjects = _.debounce(async (input, callback, per_page = DEFAULT_PER_PAGE) => {\n\n\n const endpoint = URI(`/api/v1/sponsored-projects`);\n\n endpoint.addQuery('order','name')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `name@@${input}`);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n/**\n * @type {DebouncedFunc<(function(*, *, *, *=): Promise<void>)|*>}\n */\nexport const queryPromocodes = _.debounce(async (summitId, input, callback, per_page = DEFAULT_PER_PAGE, extraFilters = []) => {\n\n\n let endpoint = URI(`/api/v1/summits/${summitId}/promo-codes`);\n\n endpoint.addQuery('order','code')\n endpoint.addQuery('page', 1);\n endpoint.addQuery('per_page', per_page);\n\n if(input) {\n input = escapeFilterValue(input);\n endpoint.addQuery('filter[]', `code@@${input}`);\n }\n\n //eg: filter = 'class_name==SummitRegistrationPromoCode'\n for (const filter of extraFilters) {\n endpoint.addQuery('filter[]', filter);\n }\n\n _fetch(endpoint, callback);\n\n}, DEBOUNCE_WAIT);\n\n\nexport const querySponsorAddons = async (\n summitId,\n sponsorId,\n sponsorshipIds,\n callback\n) => {\n try {\n const promises = sponsorshipIds.map((sponsorshipId) => {\n const endpoint = URI(\n `/api/v1/summits/${summitId}/sponsors/${sponsorId}/sponsorships/${sponsorshipId}/add-ons`\n );\n endpoint.addQuery(\n \"fields\",\n \"id,name,sponsorship.type,sponsorship.type.id,sponsorship.type.type.name\"\n );\n endpoint.addQuery(\n \"expand\",\n \"sponsorship,sponsorship.type,sponsorship.type.type\"\n );\n endpoint.addQuery(\"relations\", \"sponsorship.none\");\n return _fetchPromise(endpoint)\n .then(fetchResponseHandler)\n .then((json) => json.data)\n .catch((error) => {\n fetchErrorHandler(error);\n return [];\n });\n });\n const results = await Promise.all(promises);\n const allAddons = results.flat();\n callback(allAddons);\n } catch (error) {\n fetchErrorHandler(error);\n }\n};\n\n\nexport const querySummitAddons = async (\n summitId,\n callback\n) => {\n const endpoint = URI(\n `/api/v1/summits/${summitId}/add-ons/metadata`\n );\n endpoint.addQuery(\"page\", 1);\n endpoint.addQuery(\"per_page\", MAX_PER_PAGE);\n\n _fetch(endpoint, callback);\n};\n\n\nexport const querySponsorships = _.debounce(async (input, callback) => {\n const endpoint = URI(`/api/v1/sponsorship-types`);\n input = escapeFilterValue(input);\n if (input) {\n endpoint.addQuery(\"filter\", `name=@${input}`);\n }\n _fetch(endpoint, callback);\n}, DEBOUNCE_WAIT);\n\n\nexport const querySponsorshipsBySummit = _.debounce(\n async (input, summitId, callback) => {\n const endpoint = URI(\n `/api/v1/summits/${summitId}/sponsorships-types`\n );\n input = escapeFilterValue(input);\n endpoint.addQuery(\"page\", 1);\n endpoint.addQuery(\"per_page\", MAX_PER_PAGE);\n endpoint.addQuery(\"expand\", \"type\");\n endpoint.addQuery(\"order\", \"+name\");\n if (input) {\n endpoint.addQuery(\"filter\", `name=@${input}`);\n }\n _fetch(endpoint, callback);\n },\n DEBOUNCE_WAIT\n);\n","module.exports = require(\"@babel/runtime/helpers/defineProperty\");","module.exports = require(\"@babel/runtime/helpers/extends\");","module.exports = require(\"@babel/runtime/helpers/objectWithoutProperties\");","module.exports = require(\"i18n-react/dist/i18n-react\");","module.exports = require(\"idtoken-verifier\");","module.exports = require(\"lodash\");","module.exports = require(\"moment-timezone\");","module.exports = require(\"react\");","module.exports = require(\"react-select/lib/Async\");","module.exports = require(\"superagent/lib/client\");","module.exports = require(\"sweetalert2\");","module.exports = require(\"urijs\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","/**\n * Copyright 2017 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport React from 'react';\nimport AsyncSelect from 'react-select/lib/Async';\nimport {queryGroups} from '../../utils/query-actions';\n\nexport default class GroupInput extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.handleChange = this.handleChange.bind(this);\n this.getGroups = this.getGroups.bind(this);\n }\n\n handleChange(value) {\n\n let ev = {target: {\n id: this.props.id,\n value: value,\n type: 'groupinput'\n }};\n\n this.props.onChange(ev);\n }\n\n getGroups (input, callback) {\n if (!input) {\n return Promise.resolve({ options: [] });\n }\n\n queryGroups(input, callback);\n }\n\n render() {\n let {value, onChange, id, multi, ...rest} = this.props;\n let isMulti = (this.props.hasOwnProperty('multi'));\n\n return (\n <AsyncSelect\n value={value}\n onChange={this.handleChange}\n loadOptions={this.getGroups}\n getOptionValue={option => option.id}\n getOptionLabel={option => option.title}\n isMulti={isMulti}\n {...rest}\n />\n );\n\n }\n}\n\n"],"names":["root","factory","exports","module","define","amd","this","AUTH_ERROR_MISSING_AUTH_INFO","AUTH_ERROR_MISSING_REFRESH_TOKEN","AUTH_ERROR_ACCESS_TOKEN_EXPIRED","AUTH_ERROR_LOCK_ACQUIRE_ERROR","AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR","AUTH_ERROR_REFRESH_TOKEN_NETWORK_ERROR","require","Lock","SuperTokensLock","GET_TOKEN_SILENTLY_LOCK_KEY","RESPONSE_TYPE_CODE","AUTH_INFO","ID_TOKEN","processRefreshToken","async","flow","refreshToken","useOAuth2RefreshToken","clearAuthInfo","Error","response","fn","maxRetries","baseDelayMs","attempt","err","message","startsWith","delay","Math","pow","console","log","Promise","resolve","setTimeout","retryWithBackoff","refreshAccessToken","access_token","expires_in","refresh_token","id_token","storeAuthInfo","_getAccessToken","authInfo","getAuthInfo","accessToken","expiresIn","accessTokenUpdatedAt","getOAuth2Flow","now","moment","unix","timeElapsedSecs","getAccessToken","navigator","locks","request","lock","retryPromise","acquireLock","releaseLock","baseUrl","getOAuth2IDPBaseUrl","oauth2ClientId","getOAuth2ClientId","payload","encodeURI","controller","AbortController","timeoutId","abort","json","fetch","method","headers","body","JSON","stringify","signal","networkError","clearTimeout","ok","status","statusText","setSessionClearingState","parseError","new_refresh_token","idToken","formerAuthInfo","floor","Date","Cookies","secure","sameSite","putOnLocalStorage","res","getFromLocalStorage","parse","window","removeFromLocalStorage","OAUTH2_CLIENT_ID","OAUTH2_FLOW","Boolean","OAUTH2_USE_REFRESH_TOKEN","IDP_BASE_URL","URI","createAction","type","fetchErrorHandler","code","msg","Swal","T","fetchResponseHandler","escapeFilterValue","value","String","replace","DEBOUNCE_WAIT","DEFAULT_PER_PAGE","MAX_PER_PAGE","crypto","msCrypto","buildAPIBaseUrl","relativeUrl","API_BASE_URL","key","localStorage","setItem","removeIt","val","getItem","removeItem","clearing_session_state","cb","maxNumberOfRetries","i","_fetchPublic","endpoint","callback","options","toString","then","data","catch","_fetchPromise","e","reject","addQuery","_fetch","queryGroups","_","input","per_page","summitId","excludedIds","length","join","onlyPublished","eventTypeClassName","escapedInput","map","sp","id","name","company","filters","version","hasOwnProperty","audience","extraFilters","filter","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","o","Object","defineProperty","enumerable","get","obj","prop","prototype","call","r","Symbol","toStringTag","GroupInput","React","constructor","props","super","handleChange","bind","getGroups","ev","target","onChange","render","multi","rest","isMulti","loadOptions","getOptionValue","option","getOptionLabel","title"],"sourceRoot":""}