@rpcbase/client 0.227.0 → 0.231.0

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 (237) hide show
  1. package/package.json +11 -113
  2. package/src/apiClient/getServerApiClient.ts +131 -0
  3. package/src/apiClient/index.ts +86 -0
  4. package/src/index.ts +3 -0
  5. package/src/initClient.ts +32 -0
  6. package/src/types.ts +7 -0
  7. package/AppProvider/AnalyticsContainer.js +0 -56
  8. package/AppProvider/debug.js +0 -4
  9. package/AppProvider/index.tsx +0 -79
  10. package/access-control/ACLForm/components/GrantField/OpSelector.tsx +0 -129
  11. package/access-control/ACLForm/components/GrantField/ResourceSelector.tsx +0 -86
  12. package/access-control/ACLForm/components/GrantField/UsersSelector.tsx +0 -96
  13. package/access-control/ACLForm/components/GrantField/grant-field.scss +0 -26
  14. package/access-control/ACLForm/components/GrantField/icons/CheckMark.tsx +0 -16
  15. package/access-control/ACLForm/components/GrantField/icons/CollapseArrow.tsx +0 -14
  16. package/access-control/ACLForm/components/GrantField/icons/ExpandArrow.tsx +0 -14
  17. package/access-control/ACLForm/components/GrantField/index.tsx +0 -91
  18. package/access-control/ACLForm/components/GrantsList.tsx +0 -48
  19. package/access-control/ACLForm/components/RoleForm.tsx +0 -134
  20. package/access-control/ACLForm/components/RoleView.tsx +0 -115
  21. package/access-control/ACLForm/components/RolesList.tsx +0 -79
  22. package/access-control/ACLForm/components/constants.tsx +0 -1
  23. package/access-control/ACLForm/components/resolver.ts +0 -57
  24. package/access-control/ACLForm/components/role-form.scss +0 -19
  25. package/access-control/ACLForm/index.tsx +0 -48
  26. package/access-control/ACLModal/acl-modal.scss +0 -7
  27. package/access-control/ACLModal/index.tsx +0 -66
  28. package/access-control/PolicyEditor/TargetSelector/QueryBuilder.tsx +0 -48
  29. package/access-control/PolicyEditor/TargetSelector/index.tsx +0 -5
  30. package/access-control/PolicyEditor/TargetSelector/query-builder.scss +0 -9
  31. package/access-control/PolicyEditor/index.tsx +0 -165
  32. package/access-control/index.ts +0 -3
  33. package/apiClient.js +0 -15
  34. package/auth/authProps.js +0 -8
  35. package/auth/components/AccountsList/AccountListItem.js +0 -61
  36. package/auth/components/AccountsList/account-list-item.scss +0 -5
  37. package/auth/components/AccountsList/index.js +0 -17
  38. package/auth/components/Footer/index.js +0 -11
  39. package/auth/components/ForgotPassword/forgot-password.scss +0 -37
  40. package/auth/components/ForgotPassword/index.js +0 -114
  41. package/auth/components/SetNewPassword/index.js +0 -130
  42. package/auth/components/SetNewPassword/set-new-password.scss +0 -47
  43. package/auth/components/SignIn/SignInEmailForm.tsx +0 -115
  44. package/auth/components/SignIn/index.js +0 -69
  45. package/auth/components/SignIn/sign-in.scss +0 -56
  46. package/auth/components/SignOut/index.js +0 -144
  47. package/auth/components/SignOut/sign-out.scss +0 -34
  48. package/auth/components/SignUp/SignUpEmailForm.tsx +0 -98
  49. package/auth/components/SignUp/index.js +0 -66
  50. package/auth/components/SignUp/sign-up.scss +0 -56
  51. package/auth/getTenantId.js +0 -12
  52. package/auth/getUid.js +0 -11
  53. package/auth/helpers/redirectSignIn.native.js +0 -9
  54. package/auth/helpers/redirectSignIn.web.js +0 -7
  55. package/auth/index.js +0 -146
  56. package/auth/signOut.js +0 -20
  57. package/auth/useAuthRouter.js +0 -56
  58. package/env.d.ts +0 -3
  59. package/firebase/index.js +0 -1
  60. package/firebase/sw.js +0 -1
  61. package/form/FileInput/FileUploadContext.tsx +0 -162
  62. package/form/FileInput/FileUploadForm/index.tsx +0 -139
  63. package/form/FileInput/FileUploadForm/usePreventUnload.js +0 -21
  64. package/form/FileInput/UploadButton.tsx +0 -23
  65. package/form/FileInput/constants.ts +0 -16
  66. package/form/FileInput/file-input.scss +0 -1
  67. package/form/FileInput/index.tsx +0 -21
  68. package/form/FileInput/upload-worker/get_file_hash.js +0 -63
  69. package/form/FileInput/upload-worker/index.js +0 -16
  70. package/form/FileInput/upload-worker/no_compress_exts.ts +0 -33
  71. package/form/FileInput/upload-worker/upload_file.js +0 -129
  72. package/form/Form.tsx +0 -23
  73. package/form/Input.tsx +0 -62
  74. package/form/SubmitButton/index.tsx +0 -58
  75. package/form/hook-form.tsx +0 -7
  76. package/form/index.tsx +0 -5
  77. package/getBaseUrl.js +0 -14
  78. package/getObjectId.ts +0 -31
  79. package/hashState.js +0 -158
  80. package/helpers/createBatcher/index.js +0 -36
  81. package/helpers/getInitials.js +0 -39
  82. package/helpers/onReady.js +0 -15
  83. package/helpers/post.js +0 -18
  84. package/helpers/postRPC.js +0 -42
  85. package/helpers/useRPC.js +0 -41
  86. package/helpers/useStoredValue/batchedGetStoredValues.js +0 -30
  87. package/helpers/useStoredValue/index.js +0 -107
  88. package/helpers/useStoredValue/setStoredValues.js +0 -14
  89. package/i18n/en/rb.nav.json +0 -13
  90. package/i18n/en/rb.sign_in.json +0 -11
  91. package/i18n/en/rb.sign_out.json +0 -5
  92. package/i18n/fr/rb.sign_in.json +0 -11
  93. package/i18n/fr/rb.sign_out.json +0 -5
  94. package/i18n/index.js +0 -63
  95. package/index.js +0 -6
  96. package/isEqualValues.js +0 -47
  97. package/jest.config.js +0 -16
  98. package/notifications/Notification/index.js +0 -36
  99. package/notifications/Notification/notification.scss +0 -1
  100. package/notifications/NotificationItem/HeaderStatus.js +0 -93
  101. package/notifications/NotificationItem/index.js +0 -65
  102. package/notifications/NotificationItem/notification-item.scss +0 -25
  103. package/notifications/NotificationsContainer/index.js +0 -37
  104. package/notifications/NotificationsContainer/notifications-container.scss +0 -38
  105. package/notifications/NotificationsContainer/useLLTs.js +0 -28
  106. package/notifications/NotificationsContext/index.js +0 -71
  107. package/notifications/NotificationsContext/useNotificationsList.js +0 -75
  108. package/notifications/NotificationsSettingsModal/SettingsForm.js +0 -52
  109. package/notifications/NotificationsSettingsModal/index.js +0 -48
  110. package/notifications/NotificationsSettingsModal/notifications-settings.scss +0 -1
  111. package/notifications/config.js +0 -1
  112. package/notifications/index.js +0 -4
  113. package/page.js +0 -9
  114. package/publish-output.txt +0 -0
  115. package/rpc.js +0 -32
  116. package/rr-trace/get_fingerprint.js +0 -10
  117. package/rr-trace/get_perf_vitals.js +0 -24
  118. package/rr-trace/get_session_id.js +0 -29
  119. package/rr-trace/index.js +0 -138
  120. package/rr-trace/write_session_data.js +0 -86
  121. package/rts/boot.js +0 -3
  122. package/rts/getUseDocument.js +0 -21
  123. package/rts/getUseQuery/index.js +0 -233
  124. package/rts/getUseQuery/useData.js +0 -55
  125. package/rts/index.js +0 -10
  126. package/rts/rts.js +0 -243
  127. package/rts/signout.ts +0 -8
  128. package/rts/store/constants.js +0 -3
  129. package/rts/store/debug.js +0 -24
  130. package/rts/store/get_collection.js +0 -55
  131. package/rts/store/index.js +0 -100
  132. package/rts/store/replace_query_keys.js +0 -30
  133. package/rts/store/satisfies_projection.js +0 -32
  134. package/rts/store/update_docs.js +0 -47
  135. package/storage/index.jest.js +0 -15
  136. package/storage/index.native.js +0 -38
  137. package/storage/index.web.js +0 -25
  138. package/types.ts +0 -6
  139. package/ui/ActivityIndicator/index.js +0 -113
  140. package/ui/Avatar/index.native.js +0 -31
  141. package/ui/Avatar/index.web.js +0 -37
  142. package/ui/Avatar/styles.js +0 -41
  143. package/ui/ErrorBoundary/index.js +0 -12
  144. package/ui/ExpandableFloatView/exp.scss +0 -15
  145. package/ui/ExpandableFloatView/index.tsx +0 -123
  146. package/ui/ExpandableFloatView/useBackdrop.js +0 -45
  147. package/ui/LottiePlayer/LottiePlayer.js +0 -4
  148. package/ui/LottiePlayer/index.js +0 -8
  149. package/ui/Modal/HashStateModal.js +0 -30
  150. package/ui/Modal/Modal.js +0 -93
  151. package/ui/Modal/ModalForm/AlertBanner.js +0 -82
  152. package/ui/Modal/ModalForm/index.js +0 -188
  153. package/ui/Modal/ModalForm/modal-form.scss +0 -63
  154. package/ui/Modal/index.js +0 -10
  155. package/ui/Modal/modal.scss +0 -101
  156. package/ui/Modal/withHashStateModal.js +0 -24
  157. package/ui/RedboxError/index.js +0 -3
  158. package/ui/Search/SearchHistory/index.js +0 -45
  159. package/ui/Search/SearchHistory/search-history.scss +0 -9
  160. package/ui/Search/SearchHistory/useSearchHistory.tsx +0 -57
  161. package/ui/Search/SearchResults/index.tsx +0 -90
  162. package/ui/Search/index.tsx +0 -298
  163. package/ui/Search/search.scss +0 -0
  164. package/ui/SelectPills/index.tsx +0 -96
  165. package/ui/SelectPills/select-pills.scss +0 -66
  166. package/ui/Tabs/index.tsx +0 -161
  167. package/ui/Tabs/tabs.scss +0 -53
  168. package/ui/Tree/index.js +0 -257
  169. package/ui/Tree/model.js +0 -71
  170. package/ui/Tree/node.js +0 -112
  171. package/ui/Tree/tree.scss +0 -98
  172. package/ui/UserAvatar/default_colors.json +0 -82
  173. package/ui/UserAvatar/index.js +0 -55
  174. package/ui/View/index.tsx +0 -17
  175. package/ui/View/index.web.js +0 -44
  176. package/ui/animations/checkmark.json +0 -1
  177. package/ui/helpers/SizeContext/index.tsx +0 -11
  178. package/ui/helpers/helpers.scss +0 -61
  179. package/ui/helpers/index.ts +0 -6
  180. package/ui/helpers/stopEventPropagation.js +0 -5
  181. package/ui/helpers/useActiveListItemIndex/index.tsx +0 -45
  182. package/ui/helpers/useScrollSelectorIntoView/index.tsx +0 -14
  183. package/ui/helpers/useThrottledMeasure/index.js +0 -47
  184. package/ui/helpers/withSuspense/index.js +0 -37
  185. package/ui/icons/AddAccount.tsx +0 -5
  186. package/ui/icons/Billing.tsx +0 -6
  187. package/ui/icons/Close.tsx +0 -14
  188. package/ui/icons/Organization.tsx +0 -5
  189. package/ui/icons/Signout.tsx +0 -5
  190. package/ui/icons/index.tsx +0 -6
  191. package/ui/nav/AccountsDropdown/SwitchAccounts.tsx +0 -28
  192. package/ui/nav/AccountsDropdown/accounts-dropdown.scss +0 -51
  193. package/ui/nav/AccountsDropdown/index.tsx +0 -90
  194. package/ui/nav/AccountsToggle/index.tsx +0 -24
  195. package/ui/nav/ContentView/ContentViewContext.ts +0 -23
  196. package/ui/nav/ContentView/index.tsx +0 -115
  197. package/ui/nav/HeaderContainer/header.scss +0 -52
  198. package/ui/nav/HeaderContainer/index.tsx +0 -23
  199. package/ui/nav/HeaderContainer/variables.scss +0 -1
  200. package/ui/nav/MorphingDropdown/MorphingDropdownContext.tsx +0 -151
  201. package/ui/nav/MorphingDropdown/MorphingDropdownMenu.tsx +0 -38
  202. package/ui/nav/MorphingDropdown/MorphingDropdownPortal.tsx +0 -166
  203. package/ui/nav/MorphingDropdown/MorphingDropdownToggle.tsx +0 -34
  204. package/ui/nav/MorphingDropdown/index.tsx +0 -16
  205. package/ui/nav/MorphingDropdown/morphing-dropdown.scss +0 -35
  206. package/ui/nav/NotificationsDropdown/index.tsx +0 -52
  207. package/ui/nav/NotificationsDropdown/notifications-dropdown.scss +0 -5
  208. package/ui/nav/NotificationsToggle/NotificationsGlyph.tsx +0 -54
  209. package/ui/nav/NotificationsToggle/index.tsx +0 -12
  210. package/ui/nav/NotificationsToggle/notification-animation.json +0 -1
  211. package/ui/nav/NotificationsToggle/notifications-toggle.scss +0 -26
  212. package/ui/nav/SidebarContainer/index.tsx +0 -48
  213. package/ui/nav/SidebarContainer/sidebar-container.scss +0 -21
  214. package/ui/nav/SlideoutContainer/components/Body.tsx +0 -19
  215. package/ui/nav/SlideoutContainer/components/Header.tsx +0 -23
  216. package/ui/nav/SlideoutContainer/components/Wrapper.tsx +0 -46
  217. package/ui/nav/SlideoutContainer/index.tsx +0 -50
  218. package/ui/nav/SlideoutContainer/slideout-container.scss +0 -40
  219. package/ui/nav/index.ts +0 -13
  220. package/ui/oauth/GitHub.js +0 -38
  221. package/ui/oauth/getGitHubSigninUrl.js +0 -30
  222. package/ui/oauth/index.js +0 -9
  223. package/ui/oauth/oauth.scss +0 -16
  224. package/ui/sortable-hoc/AutoScroller.js +0 -76
  225. package/ui/sortable-hoc/DragHandle.js +0 -31
  226. package/ui/sortable-hoc/Manager.js +0 -54
  227. package/ui/sortable-hoc/README.md +0 -1
  228. package/ui/sortable-hoc/SortableContainer/defaultGetHelperDimensions.js +0 -7
  229. package/ui/sortable-hoc/SortableContainer/defaultShouldCancelStart.js +0 -24
  230. package/ui/sortable-hoc/SortableContainer/index.js +0 -994
  231. package/ui/sortable-hoc/SortableContainer/props.js +0 -81
  232. package/ui/sortable-hoc/SortableElement.js +0 -111
  233. package/ui/sortable-hoc/SortableHandle.js +0 -45
  234. package/ui/sortable-hoc/drag-handle.scss +0 -14
  235. package/ui/sortable-hoc/index.js +0 -9
  236. package/ui/sortable-hoc/utils.js +0 -292
  237. package/ui/springs.ts +0 -17
@@ -1,34 +0,0 @@
1
- @import "helpers";
2
-
3
- #sign-out-wrapper {
4
- height: 100%;
5
- display: flex;
6
- flex-direction: column;
7
- align-items: center;
8
- padding-top: 40px;
9
- padding-bottom: 40px;
10
- // background-color: var(--bs-secondary);
11
- background-color: $gray-500;
12
-
13
- footer {
14
- color: $light !important;
15
- border-top: none !important;
16
- padding-top: 0 !important;
17
- margin-bottom: 0 !important;
18
- }
19
-
20
-
21
- .form-signout {
22
- width: 100%;
23
- max-width: 380px;
24
- margin: auto;
25
- background-color: $light;
26
- border-radius: 22px;
27
- // border: 1px solid $gray-600;
28
- }
29
-
30
- .form-signout .checkbox {
31
- font-weight: 400;
32
- }
33
-
34
- }
@@ -1,98 +0,0 @@
1
- import {useState} from "react"
2
-
3
- import page from "../../../page"
4
- import {reconnect as rts_reconnect} from "../../../rts/rts"
5
-
6
- import {setIsSignedIn, setUid, setTenantId} from "../../index"
7
- import post from "../../../helpers/post"
8
-
9
-
10
- export const SignUpEmailForm = ({onSuccessRedirect, onSuccess}) => {
11
- const [email, setEmail] = useState("")
12
- const [password, setPassword] = useState("")
13
- const [passwordConfirm, setPasswordConfirm] = useState("")
14
- const [error, setError] = useState(null)
15
-
16
- const onSubmit = async() => {
17
- setError(null)
18
- if (!password || password !== passwordConfirm) {
19
- setError("Passwords do not match")
20
- return
21
- }
22
- const res = await post("/public/v1/auth/sign_up", {email, password})
23
-
24
- if (res.status === "ok") {
25
- const {user_id} = res
26
- setUid(user_id)
27
-
28
- const tenantId = user_id.slice(8, 16)
29
- setTenantId(tenantId)
30
- setIsSignedIn(true)
31
-
32
- // we must now reconnect on the websocket as we have a new cookie
33
- rts_reconnect(tenantId, user_id)
34
- onSuccess()
35
- page(onSuccessRedirect)
36
- } else if (res.status === "error") {
37
- setError(res.message)
38
- }
39
- }
40
-
41
- const onChangeEmail = (e) => {
42
- setEmail(e.target.value)
43
- }
44
-
45
- const onChangePassword = (e) => {
46
- setPassword(e.target.value)
47
- }
48
-
49
- const onChangePasswordConfirm = (e) => {
50
- setPasswordConfirm(e.target.value)
51
- }
52
-
53
-
54
- return (
55
- <>
56
- {error && (
57
- <div className="invalid-feedback d-flex text-start">
58
- {error}
59
- </div>
60
- )}
61
-
62
- <div className="form-floating text-start">
63
- <input type="email"
64
- className="form-control"
65
- id="input-email"
66
- placeholder="name@example.com"
67
- value={email}
68
- onChange={onChangeEmail} />
69
- <label htmlFor="input-email">Email Address</label>
70
- </div>
71
- <div className="form-floating text-start">
72
- <input type="password"
73
- className="form-control"
74
- id="input-password"
75
- placeholder="Password"
76
- value={password}
77
- onChange={onChangePassword} />
78
- <label htmlFor="input-password">Password</label>
79
- </div>
80
- <div className="form-floating text-start">
81
- <input type="password"
82
- className="form-control"
83
- id="input-password-confirm"
84
- placeholder="Confirm Password"
85
- value={passwordConfirm}
86
- onChange={onChangePasswordConfirm} />
87
- <label htmlFor="input-password-confirm">Confirm Password</label>
88
- </div>
89
-
90
- <div className="checkbox mt-3 mb-3 text-start">
91
- <label style={{cursor: "pointer", userSelect: "none"}}>
92
- <input type="checkbox" value="terms-accepted" /> I agree to the terms and privacy policy.
93
- </label>
94
- </div>
95
- <button className="w-100 btn btn-lg btn-primary" type="submit" onClick={onSubmit}>Sign Up</button>
96
- </>
97
- )
98
- }
@@ -1,66 +0,0 @@
1
- /* @flow */
2
- import assert from "assert"
3
-
4
- import authConfig from "@rpcbase/dot-rb/auth"
5
-
6
- import {AUTH_BUTTONS} from "../../../ui/oauth"
7
-
8
- import {Footer} from "../Footer"
9
-
10
- import {SignUpEmailForm} from "./SignUpEmailForm"
11
-
12
- import "./sign-up.scss"
13
-
14
-
15
- const hasOAuth = authConfig.oauth_providers?.length > 0
16
- const hasEmail = authConfig.has_email_signup
17
-
18
- export const SignUp = ({
19
- logo,
20
- name,
21
- onSuccessRedirect = "/",
22
- onSuccess = () => null,
23
- }) => {
24
-
25
- return (
26
- <div id="sign-up-wrapper">
27
- <div className="form-signup text-center px-4 py-4 shadow-lg">
28
- <div>
29
- <div className="d-flex align-items-center justify-content-center">
30
- {logo}
31
- </div>
32
-
33
- <hr />
34
-
35
- <h1 className="h4 mt-3 mb-3 fw-normal">Sign Up</h1>
36
- <p className="text-start text-muted">
37
- Already have an account ? <a href="/signin" className="ms-1">Sign in here</a>
38
- </p>
39
-
40
- {hasEmail && (
41
- <SignUpEmailForm
42
- onSuccess={onSuccess}
43
- onSuccessRedirect={onSuccessRedirect}
44
- />
45
- )}
46
-
47
- {hasEmail && hasOAuth && (
48
- <>
49
- <hr />
50
- <p className="text-muted">OR</p>
51
- </>
52
- )}
53
-
54
- {hasOAuth && authConfig.oauth_providers.map((provider, index) => {
55
- const Comp = AUTH_BUTTONS[provider.id]
56
- assert(Comp, `unable to find oauth button for provider: ${JSON.stringify(provider)}`)
57
-
58
- return <Comp key={`${provider.id}-${index}`} text="Sign up" className="w-100 justify-content-center" />
59
- })}
60
- </div>
61
- </div>
62
-
63
- <Footer name={name} />
64
- </div>
65
- )
66
- }
@@ -1,56 +0,0 @@
1
- @import "helpers";
2
-
3
- #sign-up-wrapper {
4
- height: 100%;
5
- display: flex;
6
- flex-direction: column;
7
- align-items: center;
8
- padding-top: 40px;
9
- padding-bottom: 40px;
10
- background-color: $gray-500;
11
-
12
- hr {
13
- background-color: $gray-500;
14
- }
15
-
16
- footer {
17
- color: $light !important;
18
- border-top: none !important;
19
- padding-top: 0 !important;
20
- margin-bottom: 0 !important;
21
- }
22
-
23
- .form-signup {
24
- width: 100%;
25
- max-width: 380px;
26
- margin: auto;
27
- background-color: $light;
28
- border-radius: 22px;
29
- // border: 1px solid $gray-600;
30
- }
31
-
32
- .form-signup .checkbox {
33
- font-weight: 400;
34
- }
35
-
36
- .form-signup .form-floating:focus-within {
37
- z-index: 2;
38
- }
39
-
40
- .form-signup input[type="email"] {
41
- margin-bottom: -1px;
42
- border-bottom-right-radius: 0;
43
- border-bottom-left-radius: 0;
44
- }
45
-
46
- .form-signup #input-password {
47
- border-radius: 0;
48
- }
49
-
50
- .form-signup #input-password-confirm {
51
- margin-bottom: 10px;
52
- border-top-left-radius: 0;
53
- border-top-right-radius: 0;
54
- border-top: none;
55
- }
56
- }
@@ -1,12 +0,0 @@
1
- /* @flow */
2
- import {Platform} from "react-native"
3
-
4
- import {getTenantId} from "./index"
5
-
6
-
7
- const getTenantIdFn = Platform.OS === "web" ? getTenantId : () => {
8
- console.warn("native should not call getTenantId, use tenantId from AuthContext")
9
- return null
10
- }
11
-
12
- export default getTenantIdFn
package/auth/getUid.js DELETED
@@ -1,11 +0,0 @@
1
- /* @flow */
2
- import {Platform} from "react-native"
3
-
4
- import {privateGetUid} from "./index"
5
-
6
- export const getUid = Platform.OS === "web" ? privateGetUid : () => {
7
- console.warn("native should not call getUid, use userId from AuthContext")
8
- return null
9
- }
10
-
11
- export default getUid
@@ -1,9 +0,0 @@
1
- /* @flow */
2
-
3
- export const redirectSignIn = (ctx) => {
4
- console.log("REDIRECT SIGN IN NYI NATIVE")
5
- console.log("CTX", ctx)
6
-
7
- // const redirect_path = ctx.canonicalPath
8
- // page.redirect(`/signin?redirect=${encodeURIComponent(redirect_path)}`)
9
- }
@@ -1,7 +0,0 @@
1
- /* @flow */
2
- import page from "../../page"
3
-
4
- export const redirectSignIn = (ctx) => {
5
- const redirect_path = ctx.canonicalPath
6
- page.redirect(`/signin?redirect=${encodeURIComponent(redirect_path)}`)
7
- }
package/auth/index.js DELETED
@@ -1,146 +0,0 @@
1
- /* @flow */
2
- import debug from "debug"
3
- import {Platform} from "react-native"
4
- import isHexadecimal from "validator/lib/isHexadecimal"
5
-
6
- import storage from "../storage"
7
- import {disconnect as rtsDisconnect} from "../rts/rts"
8
- import post from "../helpers/post"
9
-
10
- import {redirectSignIn} from "./helpers/redirectSignIn"
11
-
12
-
13
- const LAST_TENANT_KEY = "rb.last_tenant_id"
14
- const uidStorageKey = (tenant_id) => `rb.${tenant_id}.user_id`
15
-
16
- const log = debug("rb:auth")
17
-
18
- let __isSignedIn = null
19
-
20
- let __tenantId = typeof storage !== "undefined" && storage.getItem(LAST_TENANT_KEY)
21
- let __userId = typeof storage !== "undefined" && __tenantId && storage.getItem(uidStorageKey(__tenantId))
22
-
23
- let __pendingSignedInStatusCallbacks = []
24
-
25
- const purgePendingSignedInStatusCallbacks = () => {
26
- __pendingSignedInStatusCallbacks.forEach((fn) => fn(__isSignedIn))
27
- __pendingSignedInStatusCallbacks = []
28
- }
29
-
30
- export const setIsSignedIn = (val) => {
31
- __isSignedIn = val
32
- purgePendingSignedInStatusCallbacks() // IMPORTANT: call and purge all pending callbacks
33
- }
34
-
35
- export const getIsSignedIn = () => __isSignedIn
36
-
37
-
38
- const getQueryStringAuthId = () => {
39
- const url = new URL(window.location.href)
40
- const val = url.searchParams.get("auth_id")
41
- if (!val) return null
42
-
43
- if (isHexadecimal(val) && val.length === 24) return val
44
-
45
- return null
46
- }
47
-
48
- const runSessionCheck = async() => {
49
- // TODO: TMP: we're skipping the session check on mobile for now,
50
- // this assumes having a token on mobile means we're authenticated
51
- if (Platform.OS !== "web") {
52
- return
53
- }
54
-
55
- const auth_user_id = getQueryStringAuthId()
56
-
57
- if (auth_user_id) {
58
- log("check_session with auth user_id", auth_user_id)
59
- }
60
-
61
- const res = await post("/rb-api/v1/auth/check_session", {auth_user_id})
62
-
63
- log("check_session response", res)
64
-
65
- __isSignedIn = res.is_signed_in
66
- purgePendingSignedInStatusCallbacks() // IMPORTANT: call and purge all pending callbacks
67
-
68
- // if not authenticated, clear __userId + __tenantId and disconnect socket
69
- if (!__isSignedIn) {
70
- __userId = null
71
- __tenantId = null
72
- rtsDisconnect()
73
- return
74
- }
75
-
76
- __userId = res.user_id
77
- __tenantId = __userId.slice(8, 16)
78
-
79
- // save tenant id
80
- if (__tenantId) {
81
- storage.setItem(LAST_TENANT_KEY, __tenantId)
82
-
83
- // cache user_id in storage
84
- if (__userId) {
85
- storage.setItem(uidStorageKey(__tenantId), __userId)
86
- }
87
- }
88
- }
89
-
90
-
91
- // Force trigger run first session check (when we are not in a webworker (or mobile))
92
- const isJest = !!process?.env?.JEST_WORKER_ID
93
- if (typeof window !== "undefined" && !isJest) runSessionCheck()
94
-
95
-
96
- export const getSessionRestrictMiddleware = () => (ctx, next) => {
97
- log("session_restrict:__isSignedIn", __isSignedIn)
98
-
99
- if (typeof __isSignedIn !== "boolean") {
100
- log("session_restrict: will run session check")
101
-
102
- runSessionCheck()
103
- .then(() => {
104
- if (__isSignedIn) {
105
- next()
106
- } else {
107
- redirectSignIn(ctx)
108
- }
109
- })
110
- .catch((err) => {
111
- console.log("warning error in check session request", err)
112
- throw err
113
- })
114
- } else if (__isSignedIn) {
115
- next()
116
- } else {
117
- log("AUTH", JSON.stringify(__isSignedIn))
118
- log("NOT SIGNED IN, REDIRECT HERE")
119
- redirectSignIn(ctx)
120
- }
121
- }
122
-
123
-
124
- export const privateGetUid = () => __userId
125
- export const setUid = (val) => {
126
- __userId = val
127
-
128
- if (typeof val === "string") {
129
- const tenant_id_prefix = val.slice(8, 16)
130
- storage.setItem(uidStorageKey(tenant_id_prefix), val)
131
- }
132
- }
133
-
134
- export const getTenantId = () => __tenantId
135
- export const setTenantId = (val) => {
136
- __tenantId = val
137
- storage.setItem(LAST_TENANT_KEY, val)
138
- }
139
-
140
- export const waitForSignedInStatus = () => new Promise((resolve) => {
141
- if (typeof __isSignedIn === "boolean") {
142
- resolve(__isSignedIn)
143
- } else {
144
- __pendingSignedInStatusCallbacks.push(resolve)
145
- }
146
- })
package/auth/signOut.js DELETED
@@ -1,20 +0,0 @@
1
- /* @flow */
2
- import {setIsSignedIn, setUid, setTenantId} from "./index"
3
- import {signout as rtsSignout} from "../rts/signout"
4
-
5
-
6
- export const signOut = async() => {
7
- setUid(null)
8
- setTenantId(null)
9
- setIsSignedIn(false)
10
- localStorage.clear()
11
-
12
- rtsSignout()
13
-
14
- const dbs = await indexedDB.databases()
15
- for (const db of dbs) {
16
- if (db.name) {
17
- indexedDB.deleteDatabase(db.name)
18
- }
19
- }
20
- }
@@ -1,56 +0,0 @@
1
- import {useState} from "react"
2
-
3
- import page from "../page"
4
-
5
- import {SignIn} from "./components/SignIn"
6
- import {SignUp} from "./components/SignUp"
7
- import {SignOut} from "./components/SignOut"
8
- import {ForgotPassword} from "./components/ForgotPassword"
9
- import {SetNewPassword} from "./components/SetNewPassword"
10
- import { getAuthProps } from "./authProps"
11
-
12
- const hasInitialized = false
13
-
14
- export const useAuthRouter = () => {
15
- const [authComponent, setAuthComponent] = useState(null)
16
-
17
- // this method is used because the child component's effects are executed before the parent's one
18
- if (!hasInitialized) {
19
- page("/signin", (ctx, next) => {
20
- const authProps = getAuthProps()
21
- console.log("AUTHPROPS", authProps)
22
- setAuthComponent(<SignIn {...authProps} />)
23
- })
24
-
25
- page("/signout", (ctx, next) => {
26
- const authProps = getAuthProps()
27
- setAuthComponent(
28
- <SignOut {...authProps} />
29
- )
30
- })
31
-
32
- page("/signup", (ctx, next) => {
33
- const authProps = getAuthProps()
34
- console.log("AUTHPROPS", authProps)
35
- setAuthComponent(<SignUp {...authProps} />)
36
- })
37
-
38
- page("/forgot-password", (ctx, next) => {
39
- const authProps = getAuthProps()
40
- setAuthComponent(<ForgotPassword {...authProps} />)
41
- })
42
-
43
- page("/set-new-password", (ctx, next) => {
44
- const authProps = getAuthProps()
45
- setAuthComponent(<SetNewPassword {...authProps} />)
46
- })
47
-
48
- page("*", (ctx, next) => {
49
- setAuthComponent(null)
50
- next()
51
- })
52
-
53
- }
54
-
55
- return {authComponent}
56
- }
package/env.d.ts DELETED
@@ -1,3 +0,0 @@
1
- declare module "env" {
2
- export const RB_TENANT_ID: string;
3
- }
package/firebase/index.js DELETED
@@ -1 +0,0 @@
1
- (()=>{"use strict";var e={d:(t,n)=>{for(var r in n)e.o(n,r)&&!e.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:n[r]})}};e.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),e.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),e.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var t={};e.r(t),e.d(t,{getMessaging:()=>xt,getToken:()=>Vt,initializeApp:()=>oe});const n=function(e){const t=[];let n=0;for(let r=0;r<e.length;r++){let i=e.charCodeAt(r);i<128?t[n++]=i:i<2048?(t[n++]=i>>6|192,t[n++]=63&i|128):55296==(64512&i)&&r+1<e.length&&56320==(64512&e.charCodeAt(r+1))?(i=65536+((1023&i)<<10)+(1023&e.charCodeAt(++r)),t[n++]=i>>18|240,t[n++]=i>>12&63|128,t[n++]=i>>6&63|128,t[n++]=63&i|128):(t[n++]=i>>12|224,t[n++]=i>>6&63|128,t[n++]=63&i|128)}return t},r={byteToCharMap_:null,charToByteMap_:null,byteToCharMapWebSafe_:null,charToByteMapWebSafe_:null,ENCODED_VALS_BASE:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",get ENCODED_VALS(){return this.ENCODED_VALS_BASE+"+/="},get ENCODED_VALS_WEBSAFE(){return this.ENCODED_VALS_BASE+"-_."},HAS_NATIVE_SUPPORT:"function"==typeof atob,encodeByteArray(e,t){if(!Array.isArray(e))throw Error("encodeByteArray takes an array as a parameter");this.init_();const n=t?this.byteToCharMapWebSafe_:this.byteToCharMap_,r=[];for(let t=0;t<e.length;t+=3){const i=e[t],a=t+1<e.length,o=a?e[t+1]:0,s=t+2<e.length,c=s?e[t+2]:0,u=i>>2,l=(3&i)<<4|o>>4;let d=(15&o)<<2|c>>6,p=63&c;s||(p=64,a||(d=64)),r.push(n[u],n[l],n[d],n[p])}return r.join("")},encodeString(e,t){return this.HAS_NATIVE_SUPPORT&&!t?btoa(e):this.encodeByteArray(n(e),t)},decodeString(e,t){return this.HAS_NATIVE_SUPPORT&&!t?atob(e):function(e){const t=[];let n=0,r=0;for(;n<e.length;){const i=e[n++];if(i<128)t[r++]=String.fromCharCode(i);else if(i>191&&i<224){const a=e[n++];t[r++]=String.fromCharCode((31&i)<<6|63&a)}else if(i>239&&i<365){const a=((7&i)<<18|(63&e[n++])<<12|(63&e[n++])<<6|63&e[n++])-65536;t[r++]=String.fromCharCode(55296+(a>>10)),t[r++]=String.fromCharCode(56320+(1023&a))}else{const a=e[n++],o=e[n++];t[r++]=String.fromCharCode((15&i)<<12|(63&a)<<6|63&o)}}return t.join("")}(this.decodeStringToByteArray(e,t))},decodeStringToByteArray(e,t){this.init_();const n=t?this.charToByteMapWebSafe_:this.charToByteMap_,r=[];for(let t=0;t<e.length;){const a=n[e.charAt(t++)],o=t<e.length?n[e.charAt(t)]:0;++t;const s=t<e.length?n[e.charAt(t)]:64;++t;const c=t<e.length?n[e.charAt(t)]:64;if(++t,null==a||null==o||null==s||null==c)throw new i;const u=a<<2|o>>4;if(r.push(u),64!==s){const e=o<<4&240|s>>2;if(r.push(e),64!==c){const e=s<<6&192|c;r.push(e)}}}return r},init_(){if(!this.byteToCharMap_){this.byteToCharMap_={},this.charToByteMap_={},this.byteToCharMapWebSafe_={},this.charToByteMapWebSafe_={};for(let e=0;e<this.ENCODED_VALS.length;e++)this.byteToCharMap_[e]=this.ENCODED_VALS.charAt(e),this.charToByteMap_[this.byteToCharMap_[e]]=e,this.byteToCharMapWebSafe_[e]=this.ENCODED_VALS_WEBSAFE.charAt(e),this.charToByteMapWebSafe_[this.byteToCharMapWebSafe_[e]]=e,e>=this.ENCODED_VALS_BASE.length&&(this.charToByteMap_[this.ENCODED_VALS_WEBSAFE.charAt(e)]=e,this.charToByteMapWebSafe_[this.ENCODED_VALS.charAt(e)]=e)}}};class i extends Error{constructor(){super(...arguments),this.name="DecodeBase64StringError"}}const a=function(e){return function(e){const t=n(e);return r.encodeByteArray(t,!0)}(e).replace(/\./g,"")},o=()=>{try{return function(){if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==e.g)return e.g;throw new Error("Unable to locate global object.")}().__FIREBASE_DEFAULTS__||(()=>{if("undefined"==typeof process||void 0===process.env)return;const e=process.env.__FIREBASE_DEFAULTS__;return e?JSON.parse(e):void 0})()||(()=>{if("undefined"==typeof document)return;let e;try{e=document.cookie.match(/__FIREBASE_DEFAULTS__=([^;]+)/)}catch(e){return}const t=e&&function(e){try{return r.decodeString(e,!0)}catch(e){console.error("base64Decode failed: ",e)}return null}(e[1]);return t&&JSON.parse(t)})()}catch(e){return void console.info(`Unable to get __FIREBASE_DEFAULTS__ due to: ${e}`)}},s=()=>{var e;return null===(e=o())||void 0===e?void 0:e.config};class c{constructor(){this.reject=()=>{},this.resolve=()=>{},this.promise=new Promise(((e,t)=>{this.resolve=e,this.reject=t}))}wrapCallback(e){return(t,n)=>{t?this.reject(t):this.resolve(n),"function"==typeof e&&(this.promise.catch((()=>{})),1===e.length?e(t):e(t,n))}}}function u(){try{return"object"==typeof indexedDB}catch(e){return!1}}function l(){return new Promise(((e,t)=>{try{let n=!0;const r="validate-browser-context-for-indexeddb-analytics-module",i=self.indexedDB.open(r);i.onsuccess=()=>{i.result.close(),n||self.indexedDB.deleteDatabase(r),e(!0)},i.onupgradeneeded=()=>{n=!1},i.onerror=()=>{var e;t((null===(e=i.error)||void 0===e?void 0:e.message)||"")}}catch(e){t(e)}}))}class d extends Error{constructor(e,t,n){super(t),this.code=e,this.customData=n,this.name="FirebaseError",Object.setPrototypeOf(this,d.prototype),Error.captureStackTrace&&Error.captureStackTrace(this,p.prototype.create)}}class p{constructor(e,t,n){this.service=e,this.serviceName=t,this.errors=n}create(e,...t){const n=t[0]||{},r=`${this.service}/${e}`,i=this.errors[e],a=i?function(e,t){return e.replace(h,((e,n)=>{const r=t[n];return null!=r?String(r):`<${n}?>`}))}(i,n):"Error",o=`${this.serviceName}: ${a} (${r}).`;return new d(r,o,n)}}const h=/\{\$([^}]+)}/g;function f(e,t){if(e===t)return!0;const n=Object.keys(e),r=Object.keys(t);for(const i of n){if(!r.includes(i))return!1;const n=e[i],a=t[i];if(g(n)&&g(a)){if(!f(n,a))return!1}else if(n!==a)return!1}for(const e of r)if(!n.includes(e))return!1;return!0}function g(e){return null!==e&&"object"==typeof e}function m(e){return e&&e._delegate?e._delegate:e}class b{constructor(e,t,n){this.name=e,this.instanceFactory=t,this.type=n,this.multipleInstances=!1,this.serviceProps={},this.instantiationMode="LAZY",this.onInstanceCreated=null}setInstantiationMode(e){return this.instantiationMode=e,this}setMultipleInstances(e){return this.multipleInstances=e,this}setServiceProps(e){return this.serviceProps=e,this}setInstanceCreatedCallback(e){return this.onInstanceCreated=e,this}}const w="[DEFAULT]";class y{constructor(e,t){this.name=e,this.container=t,this.component=null,this.instances=new Map,this.instancesDeferred=new Map,this.instancesOptions=new Map,this.onInitCallbacks=new Map}get(e){const t=this.normalizeInstanceIdentifier(e);if(!this.instancesDeferred.has(t)){const e=new c;if(this.instancesDeferred.set(t,e),this.isInitialized(t)||this.shouldAutoInitialize())try{const n=this.getOrInitializeService({instanceIdentifier:t});n&&e.resolve(n)}catch(e){}}return this.instancesDeferred.get(t).promise}getImmediate(e){var t;const n=this.normalizeInstanceIdentifier(null==e?void 0:e.identifier),r=null!==(t=null==e?void 0:e.optional)&&void 0!==t&&t;if(!this.isInitialized(n)&&!this.shouldAutoInitialize()){if(r)return null;throw Error(`Service ${this.name} is not available`)}try{return this.getOrInitializeService({instanceIdentifier:n})}catch(e){if(r)return null;throw e}}getComponent(){return this.component}setComponent(e){if(e.name!==this.name)throw Error(`Mismatching Component ${e.name} for Provider ${this.name}.`);if(this.component)throw Error(`Component for ${this.name} has already been provided`);if(this.component=e,this.shouldAutoInitialize()){if(function(e){return"EAGER"===e.instantiationMode}(e))try{this.getOrInitializeService({instanceIdentifier:w})}catch(e){}for(const[e,t]of this.instancesDeferred.entries()){const n=this.normalizeInstanceIdentifier(e);try{const e=this.getOrInitializeService({instanceIdentifier:n});t.resolve(e)}catch(e){}}}}clearInstance(e=w){this.instancesDeferred.delete(e),this.instancesOptions.delete(e),this.instances.delete(e)}async delete(){const e=Array.from(this.instances.values());await Promise.all([...e.filter((e=>"INTERNAL"in e)).map((e=>e.INTERNAL.delete())),...e.filter((e=>"_delete"in e)).map((e=>e._delete()))])}isComponentSet(){return null!=this.component}isInitialized(e=w){return this.instances.has(e)}getOptions(e=w){return this.instancesOptions.get(e)||{}}initialize(e={}){const{options:t={}}=e,n=this.normalizeInstanceIdentifier(e.instanceIdentifier);if(this.isInitialized(n))throw Error(`${this.name}(${n}) has already been initialized`);if(!this.isComponentSet())throw Error(`Component ${this.name} has not been registered yet`);const r=this.getOrInitializeService({instanceIdentifier:n,options:t});for(const[e,t]of this.instancesDeferred.entries())n===this.normalizeInstanceIdentifier(e)&&t.resolve(r);return r}onInit(e,t){var n;const r=this.normalizeInstanceIdentifier(t),i=null!==(n=this.onInitCallbacks.get(r))&&void 0!==n?n:new Set;i.add(e),this.onInitCallbacks.set(r,i);const a=this.instances.get(r);return a&&e(a,r),()=>{i.delete(e)}}invokeOnInitCallbacks(e,t){const n=this.onInitCallbacks.get(t);if(n)for(const r of n)try{r(e,t)}catch(e){}}getOrInitializeService({instanceIdentifier:e,options:t={}}){let n=this.instances.get(e);if(!n&&this.component&&(n=this.component.instanceFactory(this.container,{instanceIdentifier:(r=e,r===w?void 0:r),options:t}),this.instances.set(e,n),this.instancesOptions.set(e,t),this.invokeOnInitCallbacks(n,e),this.component.onInstanceCreated))try{this.component.onInstanceCreated(this.container,e,n)}catch(e){}var r;return n||null}normalizeInstanceIdentifier(e=w){return this.component?this.component.multipleInstances?e:w:e}shouldAutoInitialize(){return!!this.component&&"EXPLICIT"!==this.component.instantiationMode}}class v{constructor(e){this.name=e,this.providers=new Map}addComponent(e){const t=this.getProvider(e.name);if(t.isComponentSet())throw new Error(`Component ${e.name} has already been registered with ${this.name}`);t.setComponent(e)}addOrOverwriteComponent(e){this.getProvider(e.name).isComponentSet()&&this.providers.delete(e.name),this.addComponent(e)}getProvider(e){if(this.providers.has(e))return this.providers.get(e);const t=new y(e,this);return this.providers.set(e,t),t}getProviders(){return Array.from(this.providers.values())}}const I=[];var S;!function(e){e[e.DEBUG=0]="DEBUG",e[e.VERBOSE=1]="VERBOSE",e[e.INFO=2]="INFO",e[e.WARN=3]="WARN",e[e.ERROR=4]="ERROR",e[e.SILENT=5]="SILENT"}(S||(S={}));const _={debug:S.DEBUG,verbose:S.VERBOSE,info:S.INFO,warn:S.WARN,error:S.ERROR,silent:S.SILENT},E=S.INFO,C={[S.DEBUG]:"log",[S.VERBOSE]:"log",[S.INFO]:"info",[S.WARN]:"warn",[S.ERROR]:"error"},D=(e,t,...n)=>{if(t<e.logLevel)return;const r=(new Date).toISOString(),i=C[t];if(!i)throw new Error(`Attempted to log a message with an invalid logType (value: ${t})`);console[i](`[${r}] ${e.name}:`,...n)},k=(e,t)=>t.some((t=>e instanceof t));let T,A;const O=new WeakMap,P=new WeakMap,N=new WeakMap,j=new WeakMap,M=new WeakMap;let B={get(e,t,n){if(e instanceof IDBTransaction){if("done"===t)return P.get(e);if("objectStoreNames"===t)return e.objectStoreNames||N.get(e);if("store"===t)return n.objectStoreNames[1]?void 0:n.objectStore(n.objectStoreNames[0])}return $(e[t])},set:(e,t,n)=>(e[t]=n,!0),has:(e,t)=>e instanceof IDBTransaction&&("done"===t||"store"===t)||t in e};function L(e){return"function"==typeof e?(t=e)!==IDBDatabase.prototype.transaction||"objectStoreNames"in IDBTransaction.prototype?(A||(A=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])).includes(t)?function(...e){return t.apply(R(this),e),$(O.get(this))}:function(...e){return $(t.apply(R(this),e))}:function(e,...n){const r=t.call(R(this),e,...n);return N.set(r,e.sort?e.sort():[e]),$(r)}:(e instanceof IDBTransaction&&function(e){if(P.has(e))return;const t=new Promise(((t,n)=>{const r=()=>{e.removeEventListener("complete",i),e.removeEventListener("error",a),e.removeEventListener("abort",a)},i=()=>{t(),r()},a=()=>{n(e.error||new DOMException("AbortError","AbortError")),r()};e.addEventListener("complete",i),e.addEventListener("error",a),e.addEventListener("abort",a)}));P.set(e,t)}(e),k(e,T||(T=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction]))?new Proxy(e,B):e);var t}function $(e){if(e instanceof IDBRequest)return function(e){const t=new Promise(((t,n)=>{const r=()=>{e.removeEventListener("success",i),e.removeEventListener("error",a)},i=()=>{t($(e.result)),r()},a=()=>{n(e.error),r()};e.addEventListener("success",i),e.addEventListener("error",a)}));return t.then((t=>{t instanceof IDBCursor&&O.set(t,e)})).catch((()=>{})),M.set(t,e),t}(e);if(j.has(e))return j.get(e);const t=L(e);return t!==e&&(j.set(e,t),M.set(t,e)),t}const R=e=>M.get(e);function H(e,t,{blocked:n,upgrade:r,blocking:i,terminated:a}={}){const o=indexedDB.open(e,t),s=$(o);return r&&o.addEventListener("upgradeneeded",(e=>{r($(o.result),e.oldVersion,e.newVersion,$(o.transaction),e)})),n&&o.addEventListener("blocked",(e=>n(e.oldVersion,e.newVersion,e))),s.then((e=>{a&&e.addEventListener("close",(()=>a())),i&&e.addEventListener("versionchange",(e=>i(e.oldVersion,e.newVersion,e)))})).catch((()=>{})),s}function F(e,{blocked:t}={}){const n=indexedDB.deleteDatabase(e);return t&&n.addEventListener("blocked",(e=>t(e.oldVersion,e))),$(n).then((()=>{}))}const x=["get","getKey","getAll","getAllKeys","count"],V=["put","add","delete","clear"],K=new Map;function W(e,t){if(!(e instanceof IDBDatabase)||t in e||"string"!=typeof t)return;if(K.get(t))return K.get(t);const n=t.replace(/FromIndex$/,""),r=t!==n,i=V.includes(n);if(!(n in(r?IDBIndex:IDBObjectStore).prototype)||!i&&!x.includes(n))return;const a=async function(e,...t){const a=this.transaction(e,i?"readwrite":"readonly");let o=a.store;return r&&(o=o.index(t.shift())),(await Promise.all([o[n](...t),i&&a.done]))[0]};return K.set(t,a),a}var z;z=B,B={...z,get:(e,t,n)=>W(e,t)||z.get(e,t,n),has:(e,t)=>!!W(e,t)||z.has(e,t)};class U{constructor(e){this.container=e}getPlatformInfoString(){return this.container.getProviders().map((e=>{if(function(e){const t=e.getComponent();return"VERSION"===(null==t?void 0:t.type)}(e)){const t=e.getImmediate();return`${t.library}/${t.version}`}return null})).filter((e=>e)).join(" ")}}const q="@firebase/app",G="0.10.15",J=new class{constructor(e){this.name=e,this._logLevel=E,this._logHandler=D,this._userLogHandler=null,I.push(this)}get logLevel(){return this._logLevel}set logLevel(e){if(!(e in S))throw new TypeError(`Invalid value "${e}" assigned to \`logLevel\``);this._logLevel=e}setLogLevel(e){this._logLevel="string"==typeof e?_[e]:e}get logHandler(){return this._logHandler}set logHandler(e){if("function"!=typeof e)throw new TypeError("Value assigned to `logHandler` must be a function");this._logHandler=e}get userLogHandler(){return this._userLogHandler}set userLogHandler(e){this._userLogHandler=e}debug(...e){this._userLogHandler&&this._userLogHandler(this,S.DEBUG,...e),this._logHandler(this,S.DEBUG,...e)}log(...e){this._userLogHandler&&this._userLogHandler(this,S.VERBOSE,...e),this._logHandler(this,S.VERBOSE,...e)}info(...e){this._userLogHandler&&this._userLogHandler(this,S.INFO,...e),this._logHandler(this,S.INFO,...e)}warn(...e){this._userLogHandler&&this._userLogHandler(this,S.WARN,...e),this._logHandler(this,S.WARN,...e)}error(...e){this._userLogHandler&&this._userLogHandler(this,S.ERROR,...e),this._logHandler(this,S.ERROR,...e)}}("@firebase/app"),Y="[DEFAULT]",Q={[q]:"fire-core","@firebase/app-compat":"fire-core-compat","@firebase/analytics":"fire-analytics","@firebase/analytics-compat":"fire-analytics-compat","@firebase/app-check":"fire-app-check","@firebase/app-check-compat":"fire-app-check-compat","@firebase/auth":"fire-auth","@firebase/auth-compat":"fire-auth-compat","@firebase/database":"fire-rtdb","@firebase/data-connect":"fire-data-connect","@firebase/database-compat":"fire-rtdb-compat","@firebase/functions":"fire-fn","@firebase/functions-compat":"fire-fn-compat","@firebase/installations":"fire-iid","@firebase/installations-compat":"fire-iid-compat","@firebase/messaging":"fire-fcm","@firebase/messaging-compat":"fire-fcm-compat","@firebase/performance":"fire-perf","@firebase/performance-compat":"fire-perf-compat","@firebase/remote-config":"fire-rc","@firebase/remote-config-compat":"fire-rc-compat","@firebase/storage":"fire-gcs","@firebase/storage-compat":"fire-gcs-compat","@firebase/firestore":"fire-fst","@firebase/firestore-compat":"fire-fst-compat","@firebase/vertexai":"fire-vertex","fire-js":"fire-js",firebase:"fire-js-all"},X=new Map,Z=new Map,ee=new Map;function te(e,t){try{e.container.addComponent(t)}catch(n){J.debug(`Component ${t.name} failed to register with FirebaseApp ${e.name}`,n)}}function ne(e){const t=e.name;if(ee.has(t))return J.debug(`There were multiple attempts to register component ${t}.`),!1;ee.set(t,e);for(const t of X.values())te(t,e);for(const t of Z.values())te(t,e);return!0}function re(e,t){const n=e.container.getProvider("heartbeat").getImmediate({optional:!0});return n&&n.triggerHeartbeat(),e.container.getProvider(t)}const ie=new p("app","Firebase",{"no-app":"No Firebase App '{$appName}' has been created - call initializeApp() first","bad-app-name":"Illegal App name: '{$appName}'","duplicate-app":"Firebase App named '{$appName}' already exists with different options or config","app-deleted":"Firebase App named '{$appName}' already deleted","server-app-deleted":"Firebase Server App has been deleted","no-options":"Need to provide options, when not being deployed to hosting via source.","invalid-app-argument":"firebase.{$appName}() takes either no argument or a Firebase App instance.","invalid-log-argument":"First argument to `onLog` must be null or a function.","idb-open":"Error thrown when opening IndexedDB. Original error: {$originalErrorMessage}.","idb-get":"Error thrown when reading from IndexedDB. Original error: {$originalErrorMessage}.","idb-set":"Error thrown when writing to IndexedDB. Original error: {$originalErrorMessage}.","idb-delete":"Error thrown when deleting from IndexedDB. Original error: {$originalErrorMessage}.","finalization-registry-not-supported":"FirebaseServerApp deleteOnDeref field defined but the JS runtime does not support FinalizationRegistry.","invalid-server-app-environment":"FirebaseServerApp is not for use in browser environments."});class ae{constructor(e,t,n){this._isDeleted=!1,this._options=Object.assign({},e),this._config=Object.assign({},t),this._name=t.name,this._automaticDataCollectionEnabled=t.automaticDataCollectionEnabled,this._container=n,this.container.addComponent(new b("app",(()=>this),"PUBLIC"))}get automaticDataCollectionEnabled(){return this.checkDestroyed(),this._automaticDataCollectionEnabled}set automaticDataCollectionEnabled(e){this.checkDestroyed(),this._automaticDataCollectionEnabled=e}get name(){return this.checkDestroyed(),this._name}get options(){return this.checkDestroyed(),this._options}get config(){return this.checkDestroyed(),this._config}get container(){return this._container}get isDeleted(){return this._isDeleted}set isDeleted(e){this._isDeleted=e}checkDestroyed(){if(this.isDeleted)throw ie.create("app-deleted",{appName:this._name})}}function oe(e,t={}){let n=e;"object"!=typeof t&&(t={name:t});const r=Object.assign({name:Y,automaticDataCollectionEnabled:!1},t),i=r.name;if("string"!=typeof i||!i)throw ie.create("bad-app-name",{appName:String(i)});if(n||(n=s()),!n)throw ie.create("no-options");const a=X.get(i);if(a){if(f(n,a.options)&&f(r,a.config))return a;throw ie.create("duplicate-app",{appName:i})}const o=new v(i);for(const e of ee.values())o.addComponent(e);const c=new ae(n,r,o);return X.set(i,c),c}function se(e,t,n){var r;let i=null!==(r=Q[e])&&void 0!==r?r:e;n&&(i+=`-${n}`);const a=i.match(/\s|\//),o=t.match(/\s|\//);if(a||o){const e=[`Unable to register library "${i}" with version "${t}":`];return a&&e.push(`library name "${i}" contains illegal characters (whitespace or "/")`),a&&o&&e.push("and"),o&&e.push(`version name "${t}" contains illegal characters (whitespace or "/")`),void J.warn(e.join(" "))}ne(new b(`${i}-version`,(()=>({library:i,version:t})),"VERSION"))}const ce="firebase-heartbeat-database",ue=1,le="firebase-heartbeat-store";let de=null;function pe(){return de||(de=H(ce,ue,{upgrade:(e,t)=>{if(0===t)try{e.createObjectStore(le)}catch(e){console.warn(e)}}}).catch((e=>{throw ie.create("idb-open",{originalErrorMessage:e.message})}))),de}async function he(e,t){try{const n=(await pe()).transaction(le,"readwrite"),r=n.objectStore(le);await r.put(t,fe(e)),await n.done}catch(e){if(e instanceof d)J.warn(e.message);else{const t=ie.create("idb-set",{originalErrorMessage:null==e?void 0:e.message});J.warn(t.message)}}}function fe(e){return`${e.name}!${e.options.appId}`}class ge{constructor(e){this.container=e,this._heartbeatsCache=null;const t=this.container.getProvider("app").getImmediate();this._storage=new be(t),this._heartbeatsCachePromise=this._storage.read().then((e=>(this._heartbeatsCache=e,e)))}async triggerHeartbeat(){var e,t;try{const n=this.container.getProvider("platform-logger").getImmediate().getPlatformInfoString(),r=me();if(null==(null===(e=this._heartbeatsCache)||void 0===e?void 0:e.heartbeats)&&(this._heartbeatsCache=await this._heartbeatsCachePromise,null==(null===(t=this._heartbeatsCache)||void 0===t?void 0:t.heartbeats)))return;if(this._heartbeatsCache.lastSentHeartbeatDate===r||this._heartbeatsCache.heartbeats.some((e=>e.date===r)))return;return this._heartbeatsCache.heartbeats.push({date:r,agent:n}),this._heartbeatsCache.heartbeats=this._heartbeatsCache.heartbeats.filter((e=>{const t=new Date(e.date).valueOf();return Date.now()-t<=2592e6})),this._storage.overwrite(this._heartbeatsCache)}catch(e){J.warn(e)}}async getHeartbeatsHeader(){var e;try{if(null===this._heartbeatsCache&&await this._heartbeatsCachePromise,null==(null===(e=this._heartbeatsCache)||void 0===e?void 0:e.heartbeats)||0===this._heartbeatsCache.heartbeats.length)return"";const t=me(),{heartbeatsToSend:n,unsentEntries:r}=function(e,t=1024){const n=[];let r=e.slice();for(const i of e){const e=n.find((e=>e.agent===i.agent));if(e){if(e.dates.push(i.date),we(n)>t){e.dates.pop();break}}else if(n.push({agent:i.agent,dates:[i.date]}),we(n)>t){n.pop();break}r=r.slice(1)}return{heartbeatsToSend:n,unsentEntries:r}}(this._heartbeatsCache.heartbeats),i=a(JSON.stringify({version:2,heartbeats:n}));return this._heartbeatsCache.lastSentHeartbeatDate=t,r.length>0?(this._heartbeatsCache.heartbeats=r,await this._storage.overwrite(this._heartbeatsCache)):(this._heartbeatsCache.heartbeats=[],this._storage.overwrite(this._heartbeatsCache)),i}catch(e){return J.warn(e),""}}}function me(){return(new Date).toISOString().substring(0,10)}class be{constructor(e){this.app=e,this._canUseIndexedDBPromise=this.runIndexedDBEnvironmentCheck()}async runIndexedDBEnvironmentCheck(){return!!u()&&l().then((()=>!0)).catch((()=>!1))}async read(){if(await this._canUseIndexedDBPromise){const e=await async function(e){try{const t=(await pe()).transaction(le),n=await t.objectStore(le).get(fe(e));return await t.done,n}catch(e){if(e instanceof d)J.warn(e.message);else{const t=ie.create("idb-get",{originalErrorMessage:null==e?void 0:e.message});J.warn(t.message)}}}(this.app);return(null==e?void 0:e.heartbeats)?e:{heartbeats:[]}}return{heartbeats:[]}}async overwrite(e){var t;if(await this._canUseIndexedDBPromise){const n=await this.read();return he(this.app,{lastSentHeartbeatDate:null!==(t=e.lastSentHeartbeatDate)&&void 0!==t?t:n.lastSentHeartbeatDate,heartbeats:e.heartbeats})}}async add(e){var t;if(await this._canUseIndexedDBPromise){const n=await this.read();return he(this.app,{lastSentHeartbeatDate:null!==(t=e.lastSentHeartbeatDate)&&void 0!==t?t:n.lastSentHeartbeatDate,heartbeats:[...n.heartbeats,...e.heartbeats]})}}}function we(e){return a(JSON.stringify({version:2,heartbeats:e})).length}ne(new b("platform-logger",(e=>new U(e)),"PRIVATE")),ne(new b("heartbeat",(e=>new ge(e)),"PRIVATE")),se(q,G,""),se(q,G,"esm2017"),se("fire-js",""),se("firebase","11.0.1","app");const ye="@firebase/installations",ve="0.6.10",Ie=1e4,Se=`w:${ve}`,_e="FIS_v2",Ee="https://firebaseinstallations.googleapis.com/v1",Ce=36e5,De=new p("installations","Installations",{"missing-app-config-values":'Missing App configuration value: "{$valueName}"',"not-registered":"Firebase Installation is not registered.","installation-not-found":"Firebase Installation not found.","request-failed":'{$requestName} request failed with error "{$serverCode} {$serverStatus}: {$serverMessage}"',"app-offline":"Could not process request. Application offline.","delete-pending-registration":"Can't delete installation while there is a pending registration request."});function ke(e){return e instanceof d&&e.code.includes("request-failed")}function Te({projectId:e}){return`${Ee}/projects/${e}/installations`}function Ae(e){return{token:e.token,requestStatus:2,expiresIn:(t=e.expiresIn,Number(t.replace("s","000"))),creationTime:Date.now()};var t}async function Oe(e,t){const n=(await t.json()).error;return De.create("request-failed",{requestName:e,serverCode:n.code,serverMessage:n.message,serverStatus:n.status})}function Pe({apiKey:e}){return new Headers({"Content-Type":"application/json",Accept:"application/json","x-goog-api-key":e})}async function Ne(e){const t=await e();return t.status>=500&&t.status<600?e():t}function je(e){return new Promise((t=>{setTimeout(t,e)}))}const Me=/^[cdef][\w-]{21}$/,Be="";function Le(){try{const e=new Uint8Array(17);(self.crypto||self.msCrypto).getRandomValues(e),e[0]=112+e[0]%16;const t=function(e){var t;return(t=e,btoa(String.fromCharCode(...t)).replace(/\+/g,"-").replace(/\//g,"_")).substr(0,22)}(e);return Me.test(t)?t:Be}catch(e){return Be}}function $e(e){return`${e.appName}!${e.appId}`}const Re=new Map;function He(e,t){const n=$e(e);Fe(n,t),function(e,t){const n=(!xe&&"BroadcastChannel"in self&&(xe=new BroadcastChannel("[Firebase] FID Change"),xe.onmessage=e=>{Fe(e.data.key,e.data.fid)}),xe);n&&n.postMessage({key:e,fid:t}),0===Re.size&&xe&&(xe.close(),xe=null)}(n,t)}function Fe(e,t){const n=Re.get(e);if(n)for(const e of n)e(t)}let xe=null;const Ve="firebase-installations-database",Ke=1,We="firebase-installations-store";let ze=null;function Ue(){return ze||(ze=H(Ve,Ke,{upgrade:(e,t)=>{0===t&&e.createObjectStore(We)}})),ze}async function qe(e,t){const n=$e(e),r=(await Ue()).transaction(We,"readwrite"),i=r.objectStore(We),a=await i.get(n);return await i.put(t,n),await r.done,a&&a.fid===t.fid||He(e,t.fid),t}async function Ge(e){const t=$e(e),n=(await Ue()).transaction(We,"readwrite");await n.objectStore(We).delete(t),await n.done}async function Je(e,t){const n=$e(e),r=(await Ue()).transaction(We,"readwrite"),i=r.objectStore(We),a=await i.get(n),o=t(a);return void 0===o?await i.delete(n):await i.put(o,n),await r.done,!o||a&&a.fid===o.fid||He(e,o.fid),o}async function Ye(e){let t;const n=await Je(e.appConfig,(n=>{const r=function(e){return Ze(e||{fid:Le(),registrationStatus:0})}(n),i=function(e,t){if(0===t.registrationStatus){if(!navigator.onLine)return{installationEntry:t,registrationPromise:Promise.reject(De.create("app-offline"))};const n={fid:t.fid,registrationStatus:1,registrationTime:Date.now()},r=async function(e,t){try{const n=await async function({appConfig:e,heartbeatServiceProvider:t},{fid:n}){const r=Te(e),i=Pe(e),a=t.getImmediate({optional:!0});if(a){const e=await a.getHeartbeatsHeader();e&&i.append("x-firebase-client",e)}const o={fid:n,authVersion:_e,appId:e.appId,sdkVersion:Se},s={method:"POST",headers:i,body:JSON.stringify(o)},c=await Ne((()=>fetch(r,s)));if(c.ok){const e=await c.json();return{fid:e.fid||n,registrationStatus:2,refreshToken:e.refreshToken,authToken:Ae(e.authToken)}}throw await Oe("Create Installation",c)}(e,t);return qe(e.appConfig,n)}catch(n){throw ke(n)&&409===n.customData.serverCode?await Ge(e.appConfig):await qe(e.appConfig,{fid:t.fid,registrationStatus:0}),n}}(e,n);return{installationEntry:n,registrationPromise:r}}return 1===t.registrationStatus?{installationEntry:t,registrationPromise:Qe(e)}:{installationEntry:t}}(e,r);return t=i.registrationPromise,i.installationEntry}));return n.fid===Be?{installationEntry:await t}:{installationEntry:n,registrationPromise:t}}async function Qe(e){let t=await Xe(e.appConfig);for(;1===t.registrationStatus;)await je(100),t=await Xe(e.appConfig);if(0===t.registrationStatus){const{installationEntry:t,registrationPromise:n}=await Ye(e);return n||t}return t}function Xe(e){return Je(e,(e=>{if(!e)throw De.create("installation-not-found");return Ze(e)}))}function Ze(e){return 1===(t=e).registrationStatus&&t.registrationTime+Ie<Date.now()?{fid:e.fid,registrationStatus:0}:e;var t}async function et({appConfig:e,heartbeatServiceProvider:t},n){const r=function(e,{fid:t}){return`${Te(e)}/${t}/authTokens:generate`}(e,n),i=function(e,{refreshToken:t}){const n=Pe(e);return n.append("Authorization",function(e){return`${_e} ${e}`}(t)),n}(e,n),a=t.getImmediate({optional:!0});if(a){const e=await a.getHeartbeatsHeader();e&&i.append("x-firebase-client",e)}const o={installation:{sdkVersion:Se,appId:e.appId}},s={method:"POST",headers:i,body:JSON.stringify(o)},c=await Ne((()=>fetch(r,s)));if(c.ok)return Ae(await c.json());throw await Oe("Generate Auth Token",c)}async function tt(e,t=!1){let n;const r=await Je(e.appConfig,(r=>{if(!rt(r))throw De.create("not-registered");const i=r.authToken;if(!t&&(2===(a=i).requestStatus&&!function(e){const t=Date.now();return t<e.creationTime||e.creationTime+e.expiresIn<t+Ce}(a)))return r;var a;if(1===i.requestStatus)return n=async function(e,t){let n=await nt(e.appConfig);for(;1===n.authToken.requestStatus;)await je(100),n=await nt(e.appConfig);const r=n.authToken;return 0===r.requestStatus?tt(e,t):r}(e,t),r;{if(!navigator.onLine)throw De.create("app-offline");const t=function(e){const t={requestStatus:1,requestTime:Date.now()};return Object.assign(Object.assign({},e),{authToken:t})}(r);return n=async function(e,t){try{const n=await et(e,t),r=Object.assign(Object.assign({},t),{authToken:n});return await qe(e.appConfig,r),n}catch(n){if(!ke(n)||401!==n.customData.serverCode&&404!==n.customData.serverCode){const n=Object.assign(Object.assign({},t),{authToken:{requestStatus:0}});await qe(e.appConfig,n)}else await Ge(e.appConfig);throw n}}(e,t),t}}));return n?await n:r.authToken}function nt(e){return Je(e,(e=>{if(!rt(e))throw De.create("not-registered");return 1===(t=e.authToken).requestStatus&&t.requestTime+Ie<Date.now()?Object.assign(Object.assign({},e),{authToken:{requestStatus:0}}):e;var t}))}function rt(e){return void 0!==e&&2===e.registrationStatus}function it(e){return De.create("missing-app-config-values",{valueName:e})}const at="installations";ne(new b(at,(e=>{const t=e.getProvider("app").getImmediate(),n=function(e){if(!e||!e.options)throw it("App Configuration");if(!e.name)throw it("App Name");const t=["projectId","apiKey","appId"];for(const n of t)if(!e.options[n])throw it(n);return{appName:e.name,projectId:e.options.projectId,apiKey:e.options.apiKey,appId:e.options.appId}}(t);return{app:t,appConfig:n,heartbeatServiceProvider:re(t,"heartbeat"),_delete:()=>Promise.resolve()}}),"PUBLIC")),ne(new b("installations-internal",(e=>{const t=re(e.getProvider("app").getImmediate(),at).getImmediate();return{getId:()=>async function(e){const t=e,{installationEntry:n,registrationPromise:r}=await Ye(t);return r?r.catch(console.error):tt(t).catch(console.error),n.fid}(t),getToken:e=>async function(e,t=!1){const n=e;return await async function(e){const{registrationPromise:t}=await Ye(e);t&&await t}(n),(await tt(n,t)).token}(t,e)}}),"PRIVATE")),se(ye,ve),se(ye,ve,"esm2017");const ot="/firebase-messaging-sw.js",st="/firebase-cloud-messaging-push-scope",ct="BDOU99-h67HcA6JeFXHbSNMu7e2yNNu3RzoMj8TM4W88jITfq7ZmPvIM1Iv-4_l2LxQcYwhqby2xGpWwzjfAnG4",ut="https://fcmregistrations.googleapis.com/v1",lt="google.c.a.c_id",dt="google.c.a.c_l",pt="google.c.a.ts";var ht,ft;function gt(e){const t=new Uint8Array(e);return btoa(String.fromCharCode(...t)).replace(/=/g,"").replace(/\+/g,"-").replace(/\//g,"_")}function mt(e){const t=(e+"=".repeat((4-e.length%4)%4)).replace(/\-/g,"+").replace(/_/g,"/"),n=atob(t),r=new Uint8Array(n.length);for(let e=0;e<n.length;++e)r[e]=n.charCodeAt(e);return r}!function(e){e[e.DATA_MESSAGE=1]="DATA_MESSAGE",e[e.DISPLAY_NOTIFICATION=3]="DISPLAY_NOTIFICATION"}(ht||(ht={})),function(e){e.PUSH_RECEIVED="push-received",e.NOTIFICATION_CLICKED="notification-clicked"}(ft||(ft={}));const bt="fcm_token_details_db",wt=5,yt="fcm_token_object_Store",vt="firebase-messaging-database",It=1,St="firebase-messaging-store";let _t=null;function Et(){return _t||(_t=H(vt,It,{upgrade:(e,t)=>{0===t&&e.createObjectStore(St)}})),_t}async function Ct(e,t){const n=Dt(e),r=(await Et()).transaction(St,"readwrite");return await r.objectStore(St).put(t,n),await r.done,t}function Dt({appConfig:e}){return e.appId}const kt=new p("messaging","Messaging",{"missing-app-config-values":'Missing App configuration value: "{$valueName}"',"only-available-in-window":"This method is available in a Window context.","only-available-in-sw":"This method is available in a service worker context.","permission-default":"The notification permission was not granted and dismissed instead.","permission-blocked":"The notification permission was not granted and blocked instead.","unsupported-browser":"This browser doesn't support the API's required to use the Firebase SDK.","indexed-db-unsupported":"This browser doesn't support indexedDb.open() (ex. Safari iFrame, Firefox Private Browsing, etc)","failed-service-worker-registration":"We are unable to register the default service worker. {$browserErrorMessage}","token-subscribe-failed":"A problem occurred while subscribing the user to FCM: {$errorInfo}","token-subscribe-no-token":"FCM returned no token when subscribing the user to push.","token-unsubscribe-failed":"A problem occurred while unsubscribing the user from FCM: {$errorInfo}","token-update-failed":"A problem occurred while updating the user from FCM: {$errorInfo}","token-update-no-token":"FCM returned no token when updating the user to push.","use-sw-after-get-token":"The useServiceWorker() method may only be called once and must be called before calling getToken() to ensure your service worker is used.","invalid-sw-registration":"The input to useServiceWorker() must be a ServiceWorkerRegistration.","invalid-bg-handler":"The input to setBackgroundMessageHandler() must be a function.","invalid-vapid-key":"The public VAPID key must be a string.","use-vapid-key-after-get-token":"The usePublicVapidKey() method may only be called once and must be called before calling getToken() to ensure your VAPID key is used."});function Tt({projectId:e}){return`${ut}/projects/${e}/registrations`}async function At({appConfig:e,installations:t}){const n=await t.getToken();return new Headers({"Content-Type":"application/json",Accept:"application/json","x-goog-api-key":e.apiKey,"x-goog-firebase-installations-auth":`FIS ${n}`})}function Ot({p256dh:e,auth:t,endpoint:n,vapidKey:r}){const i={web:{endpoint:n,auth:t,p256dh:e}};return r!==ct&&(i.web.applicationPubKey=r),i}const Pt=6048e5;async function Nt(e){const t=await async function(e,t){const n=await e.pushManager.getSubscription();return n||e.pushManager.subscribe({userVisibleOnly:!0,applicationServerKey:mt(t)})}(e.swRegistration,e.vapidKey),n={vapidKey:e.vapidKey,swScope:e.swRegistration.scope,endpoint:t.endpoint,auth:gt(t.getKey("auth")),p256dh:gt(t.getKey("p256dh"))},r=await async function(e){const t=Dt(e),n=await Et(),r=await n.transaction(St).objectStore(St).get(t);if(r)return r;{const t=await async function(e){if("databases"in indexedDB){const e=(await indexedDB.databases()).map((e=>e.name));if(!e.includes(bt))return null}let t=null;return(await H(bt,wt,{upgrade:async(n,r,i,a)=>{var o;if(r<2)return;if(!n.objectStoreNames.contains(yt))return;const s=a.objectStore(yt),c=await s.index("fcmSenderId").get(e);if(await s.clear(),c)if(2===r){const e=c;if(!e.auth||!e.p256dh||!e.endpoint)return;t={token:e.fcmToken,createTime:null!==(o=e.createTime)&&void 0!==o?o:Date.now(),subscriptionOptions:{auth:e.auth,p256dh:e.p256dh,endpoint:e.endpoint,swScope:e.swScope,vapidKey:"string"==typeof e.vapidKey?e.vapidKey:gt(e.vapidKey)}}}else if(3===r){const e=c;t={token:e.fcmToken,createTime:e.createTime,subscriptionOptions:{auth:gt(e.auth),p256dh:gt(e.p256dh),endpoint:e.endpoint,swScope:e.swScope,vapidKey:gt(e.vapidKey)}}}else if(4===r){const e=c;t={token:e.fcmToken,createTime:e.createTime,subscriptionOptions:{auth:gt(e.auth),p256dh:gt(e.p256dh),endpoint:e.endpoint,swScope:e.swScope,vapidKey:gt(e.vapidKey)}}}}})).close(),await F(bt),await F("fcm_vapid_details_db"),await F("undefined"),function(e){if(!e||!e.subscriptionOptions)return!1;const{subscriptionOptions:t}=e;return"number"==typeof e.createTime&&e.createTime>0&&"string"==typeof e.token&&e.token.length>0&&"string"==typeof t.auth&&t.auth.length>0&&"string"==typeof t.p256dh&&t.p256dh.length>0&&"string"==typeof t.endpoint&&t.endpoint.length>0&&"string"==typeof t.swScope&&t.swScope.length>0&&"string"==typeof t.vapidKey&&t.vapidKey.length>0}(t)?t:null}(e.appConfig.senderId);if(t)return await Ct(e,t),t}}(e.firebaseDependencies);if(r){if(function(e,t){const n=t.vapidKey===e.vapidKey,r=t.endpoint===e.endpoint,i=t.auth===e.auth,a=t.p256dh===e.p256dh;return n&&r&&i&&a}(r.subscriptionOptions,n))return Date.now()>=r.createTime+Pt?async function(e,t){try{const n=await async function(e,t){const n=await At(e),r=Ot(t.subscriptionOptions),i={method:"PATCH",headers:n,body:JSON.stringify(r)};let a;try{const n=await fetch(`${Tt(e.appConfig)}/${t.token}`,i);a=await n.json()}catch(e){throw kt.create("token-update-failed",{errorInfo:null==e?void 0:e.toString()})}if(a.error){const e=a.error.message;throw kt.create("token-update-failed",{errorInfo:e})}if(!a.token)throw kt.create("token-update-no-token");return a.token}(e.firebaseDependencies,t),r=Object.assign(Object.assign({},t),{token:n,createTime:Date.now()});return await Ct(e.firebaseDependencies,r),n}catch(e){throw e}}(e,{token:r.token,createTime:Date.now(),subscriptionOptions:n}):r.token;try{await async function(e,t){const n={method:"DELETE",headers:await At(e)};try{const r=await fetch(`${Tt(e.appConfig)}/${t}`,n),i=await r.json();if(i.error){const e=i.error.message;throw kt.create("token-unsubscribe-failed",{errorInfo:e})}}catch(e){throw kt.create("token-unsubscribe-failed",{errorInfo:null==e?void 0:e.toString()})}}(e.firebaseDependencies,r.token)}catch(e){console.warn(e)}return jt(e.firebaseDependencies,n)}return jt(e.firebaseDependencies,n)}async function jt(e,t){const n=await async function(e,t){const n=await At(e),r=Ot(t),i={method:"POST",headers:n,body:JSON.stringify(r)};let a;try{const t=await fetch(Tt(e.appConfig),i);a=await t.json()}catch(e){throw kt.create("token-subscribe-failed",{errorInfo:null==e?void 0:e.toString()})}if(a.error){const e=a.error.message;throw kt.create("token-subscribe-failed",{errorInfo:e})}if(!a.token)throw kt.create("token-subscribe-no-token");return a.token}(e,t),r={token:n,createTime:Date.now(),subscriptionOptions:t};return await Ct(e,r),r.token}function Mt(e){const t={from:e.from,collapseKey:e.collapse_key,messageId:e.fcmMessageId};return function(e,t){if(!t.notification)return;e.notification={};const n=t.notification.title;n&&(e.notification.title=n);const r=t.notification.body;r&&(e.notification.body=r);const i=t.notification.image;i&&(e.notification.image=i);const a=t.notification.icon;a&&(e.notification.icon=a)}(t,e),function(e,t){t.data&&(e.data=t.data)}(t,e),function(e,t){var n,r,i,a,o;if(!t.fcmOptions&&!(null===(n=t.notification)||void 0===n?void 0:n.click_action))return;e.fcmOptions={};const s=null!==(i=null===(r=t.fcmOptions)||void 0===r?void 0:r.link)&&void 0!==i?i:null===(a=t.notification)||void 0===a?void 0:a.click_action;s&&(e.fcmOptions.link=s);const c=null===(o=t.fcmOptions)||void 0===o?void 0:o.analytics_label;c&&(e.fcmOptions.analyticsLabel=c)}(t,e),t}function Bt(e){return kt.create("missing-app-config-values",{valueName:e})}!function(e,t){const n=[];for(let r=0;r<20;r++)n.push(e.charAt(r)),r<19&&n.push(t.charAt(r));n.join("")}("AzSCbw63g1R0nCw85jG8","Iaya3yLKwmgvh7cF0q4");class Lt{constructor(e,t,n){this.deliveryMetricsExportedToBigQueryEnabled=!1,this.onBackgroundMessageHandler=null,this.onMessageHandler=null,this.logEvents=[],this.isLogServiceStarted=!1;const r=function(e){if(!e||!e.options)throw Bt("App Configuration Object");if(!e.name)throw Bt("App Name");const t=["projectId","apiKey","appId","messagingSenderId"],{options:n}=e;for(const e of t)if(!n[e])throw Bt(e);return{appName:e.name,projectId:n.projectId,apiKey:n.apiKey,appId:n.appId,senderId:n.messagingSenderId}}(e);this.firebaseDependencies={app:e,appConfig:r,installations:t,analyticsProvider:n}}_delete(){return Promise.resolve()}}async function $t(e,t){if(!navigator)throw kt.create("only-available-in-window");if("default"===Notification.permission&&await Notification.requestPermission(),"granted"!==Notification.permission)throw kt.create("permission-blocked");return await async function(e,t){t?e.vapidKey=t:e.vapidKey||(e.vapidKey=ct)}(e,null==t?void 0:t.vapidKey),await async function(e,t){if(t||e.swRegistration||await async function(e){try{e.swRegistration=await navigator.serviceWorker.register(ot,{scope:st}),e.swRegistration.update().catch((()=>{}))}catch(e){throw kt.create("failed-service-worker-registration",{browserErrorMessage:null==e?void 0:e.message})}}(e),t||!e.swRegistration){if(!(t instanceof ServiceWorkerRegistration))throw kt.create("invalid-sw-registration");e.swRegistration=t}}(e,null==t?void 0:t.serviceWorkerRegistration),Nt(e)}async function Rt(e,t){const n=t.data;if(!n.isFirebaseMessaging)return;e.onMessageHandler&&n.messageType===ft.PUSH_RECEIVED&&("function"==typeof e.onMessageHandler?e.onMessageHandler(Mt(n)):e.onMessageHandler.next(Mt(n)));const r=n.data;var i;"object"==typeof(i=r)&&i&&lt in i&&"1"===r["google.c.a.e"]&&await async function(e,t,n){const r=function(e){switch(e){case ft.NOTIFICATION_CLICKED:return"notification_open";case ft.PUSH_RECEIVED:return"notification_foreground";default:throw new Error}}(t);(await e.firebaseDependencies.analyticsProvider.get()).logEvent(r,{message_id:n[lt],message_name:n[dt],message_time:n[pt],message_device_time:Math.floor(Date.now()/1e3)})}(e,n.messageType,r)}const Ht="@firebase/messaging",Ft="0.12.13";function xt(e=function(e=Y){const t=X.get(e);if(!t&&e===Y&&s())return oe();if(!t)throw ie.create("no-app",{appName:e});return t}()){return async function(){try{await l()}catch(e){return!1}return"undefined"!=typeof window&&u()&&!("undefined"==typeof navigator||!navigator.cookieEnabled)&&"serviceWorker"in navigator&&"PushManager"in window&&"Notification"in window&&"fetch"in window&&ServiceWorkerRegistration.prototype.hasOwnProperty("showNotification")&&PushSubscription.prototype.hasOwnProperty("getKey")}().then((e=>{if(!e)throw kt.create("unsupported-browser")}),(e=>{throw kt.create("indexed-db-unsupported")})),re(m(e),"messaging").getImmediate()}async function Vt(e,t){return $t(e=m(e),t)}ne(new b("messaging",(e=>{const t=new Lt(e.getProvider("app").getImmediate(),e.getProvider("installations-internal").getImmediate(),e.getProvider("analytics-internal"));return navigator.serviceWorker.addEventListener("message",(e=>Rt(t,e))),t}),"PUBLIC")),ne(new b("messaging-internal",(e=>{const t=e.getProvider("messaging").getImmediate();return{getToken:e=>$t(t,e)}}),"PRIVATE")),se(Ht,Ft),se(Ht,Ft,"esm2017"),module.exports=t})();