@stackframe/stack 2.7.20 → 2.7.22

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 (250) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/admin-app-impl-CTQhv9tV.d.ts +395 -0
  3. package/dist/admin-app-impl-DpyRKp1e.d.mts +395 -0
  4. package/dist/components/credential-sign-in.js.map +1 -1
  5. package/dist/components/credential-sign-up.js.map +1 -1
  6. package/dist/components/elements/form-warning.js.map +1 -1
  7. package/dist/components/elements/maybe-full-page.js.map +1 -1
  8. package/dist/components/elements/separator-with-text.js.map +1 -1
  9. package/dist/components/elements/sidebar-layout.js.map +1 -1
  10. package/dist/components/elements/ssr-layout-effect.js.map +1 -1
  11. package/dist/components/elements/user-avatar.js.map +1 -1
  12. package/dist/components/iframe-preventer.js.map +1 -1
  13. package/dist/components/link.js.map +1 -1
  14. package/dist/components/magic-link-sign-in.js.map +1 -1
  15. package/dist/components/message-cards/known-error-message-card.js.map +1 -1
  16. package/dist/components/message-cards/message-card.js.map +1 -1
  17. package/dist/components/message-cards/predefined-message-card.js.map +1 -1
  18. package/dist/components/oauth-button-group.js.map +1 -1
  19. package/dist/components/oauth-button.js.map +1 -1
  20. package/dist/components/passkey-button.js.map +1 -1
  21. package/dist/components/profile-image-editor.js.map +1 -1
  22. package/dist/components/selected-team-switcher.d.mts +18 -6
  23. package/dist/components/selected-team-switcher.d.ts +18 -6
  24. package/dist/components/selected-team-switcher.js.map +1 -1
  25. package/dist/components/team-icon.d.mts +18 -6
  26. package/dist/components/team-icon.d.ts +18 -6
  27. package/dist/components/team-icon.js.map +1 -1
  28. package/dist/components/user-button.js.map +1 -1
  29. package/dist/components-page/account-settings.js.map +1 -1
  30. package/dist/components-page/auth-page.js.map +1 -1
  31. package/dist/components-page/email-verification.js.map +1 -1
  32. package/dist/components-page/error-page.js.map +1 -1
  33. package/dist/components-page/forgot-password.js.map +1 -1
  34. package/dist/components-page/magic-link-callback.js.map +1 -1
  35. package/dist/components-page/oauth-callback.js.map +1 -1
  36. package/dist/components-page/password-reset.js.map +1 -1
  37. package/dist/components-page/sign-in.js.map +1 -1
  38. package/dist/components-page/sign-out.js.map +1 -1
  39. package/dist/components-page/sign-up.js.map +1 -1
  40. package/dist/components-page/stack-handler.d.mts +18 -6
  41. package/dist/components-page/stack-handler.d.ts +18 -6
  42. package/dist/components-page/stack-handler.js.map +1 -1
  43. package/dist/components-page/team-creation.js.map +1 -1
  44. package/dist/components-page/team-invitation.js.map +1 -1
  45. package/dist/esm/components/credential-sign-in.js.map +1 -1
  46. package/dist/esm/components/credential-sign-up.js.map +1 -1
  47. package/dist/esm/components/elements/form-warning.js.map +1 -1
  48. package/dist/esm/components/elements/maybe-full-page.js.map +1 -1
  49. package/dist/esm/components/elements/separator-with-text.js.map +1 -1
  50. package/dist/esm/components/elements/sidebar-layout.js.map +1 -1
  51. package/dist/esm/components/elements/ssr-layout-effect.js.map +1 -1
  52. package/dist/esm/components/elements/user-avatar.js.map +1 -1
  53. package/dist/esm/components/iframe-preventer.js.map +1 -1
  54. package/dist/esm/components/link.js.map +1 -1
  55. package/dist/esm/components/magic-link-sign-in.js.map +1 -1
  56. package/dist/esm/components/message-cards/known-error-message-card.js.map +1 -1
  57. package/dist/esm/components/message-cards/message-card.js.map +1 -1
  58. package/dist/esm/components/message-cards/predefined-message-card.js.map +1 -1
  59. package/dist/esm/components/oauth-button-group.js.map +1 -1
  60. package/dist/esm/components/oauth-button.js.map +1 -1
  61. package/dist/esm/components/passkey-button.js.map +1 -1
  62. package/dist/esm/components/profile-image-editor.js.map +1 -1
  63. package/dist/esm/components/selected-team-switcher.js.map +1 -1
  64. package/dist/esm/components/team-icon.js.map +1 -1
  65. package/dist/esm/components/user-button.js.map +1 -1
  66. package/dist/esm/components-page/account-settings.js.map +1 -1
  67. package/dist/esm/components-page/auth-page.js.map +1 -1
  68. package/dist/esm/components-page/email-verification.js.map +1 -1
  69. package/dist/esm/components-page/error-page.js.map +1 -1
  70. package/dist/esm/components-page/forgot-password.js.map +1 -1
  71. package/dist/esm/components-page/magic-link-callback.js.map +1 -1
  72. package/dist/esm/components-page/oauth-callback.js.map +1 -1
  73. package/dist/esm/components-page/password-reset.js.map +1 -1
  74. package/dist/esm/components-page/sign-in.js.map +1 -1
  75. package/dist/esm/components-page/sign-out.js.map +1 -1
  76. package/dist/esm/components-page/sign-up.js.map +1 -1
  77. package/dist/esm/components-page/stack-handler.js.map +1 -1
  78. package/dist/esm/components-page/team-creation.js.map +1 -1
  79. package/dist/esm/components-page/team-invitation.js.map +1 -1
  80. package/dist/esm/generated/quetzal-translations.js.map +1 -1
  81. package/dist/esm/index.js.map +1 -1
  82. package/dist/esm/lib/auth.js.map +1 -1
  83. package/dist/esm/lib/cookie.js +4 -7
  84. package/dist/esm/lib/cookie.js.map +1 -1
  85. package/dist/esm/lib/hooks.js.map +1 -1
  86. package/dist/esm/lib/stack-app/api-keys/index.js +14 -0
  87. package/dist/esm/lib/stack-app/api-keys/index.js.map +1 -0
  88. package/dist/esm/lib/stack-app/apps/implementations/admin-app-impl.js +291 -0
  89. package/dist/esm/lib/stack-app/apps/implementations/admin-app-impl.js.map +1 -0
  90. package/dist/esm/lib/{stack-app.js → stack-app/apps/implementations/client-app-impl.js} +39 -1111
  91. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.js.map +1 -0
  92. package/dist/esm/lib/stack-app/apps/implementations/common.js +142 -0
  93. package/dist/esm/lib/stack-app/apps/implementations/common.js.map +1 -0
  94. package/dist/esm/lib/stack-app/apps/implementations/index.js +24 -0
  95. package/dist/esm/lib/stack-app/apps/implementations/index.js.map +1 -0
  96. package/dist/esm/lib/stack-app/apps/implementations/server-app-impl.js +527 -0
  97. package/dist/esm/lib/stack-app/apps/implementations/server-app-impl.js.map +1 -0
  98. package/dist/esm/lib/stack-app/apps/index.js +16 -0
  99. package/dist/esm/lib/stack-app/apps/index.js.map +1 -0
  100. package/dist/esm/lib/stack-app/apps/interfaces/admin-app.js +7 -0
  101. package/dist/esm/lib/stack-app/apps/interfaces/admin-app.js.map +1 -0
  102. package/dist/esm/lib/stack-app/apps/interfaces/client-app.js +7 -0
  103. package/dist/esm/lib/stack-app/apps/interfaces/client-app.js.map +1 -0
  104. package/dist/esm/lib/stack-app/apps/interfaces/server-app.js +7 -0
  105. package/dist/esm/lib/stack-app/apps/interfaces/server-app.js.map +1 -0
  106. package/dist/esm/lib/stack-app/common.js +6 -0
  107. package/dist/esm/lib/stack-app/common.js.map +1 -0
  108. package/dist/esm/lib/stack-app/connected-accounts/index.js +1 -0
  109. package/dist/esm/lib/stack-app/connected-accounts/index.js.map +1 -0
  110. package/dist/esm/lib/stack-app/contact-channels/index.js +39 -0
  111. package/dist/esm/lib/stack-app/contact-channels/index.js.map +1 -0
  112. package/dist/esm/lib/stack-app/email-templates/index.js +11 -0
  113. package/dist/esm/lib/stack-app/email-templates/index.js.map +1 -0
  114. package/dist/esm/lib/stack-app/index.js +16 -0
  115. package/dist/esm/lib/stack-app/index.js.map +1 -0
  116. package/dist/esm/lib/stack-app/permissions/index.js +20 -0
  117. package/dist/esm/lib/stack-app/permissions/index.js.map +1 -0
  118. package/dist/esm/lib/stack-app/project-configs/index.js +1 -0
  119. package/dist/esm/lib/stack-app/project-configs/index.js.map +1 -0
  120. package/dist/esm/lib/stack-app/projects/index.js +57 -0
  121. package/dist/esm/lib/stack-app/projects/index.js.map +1 -0
  122. package/dist/esm/lib/stack-app/teams/index.js +38 -0
  123. package/dist/esm/lib/stack-app/teams/index.js.map +1 -0
  124. package/dist/esm/lib/stack-app/users/index.js +47 -0
  125. package/dist/esm/lib/stack-app/users/index.js.map +1 -0
  126. package/dist/esm/lib/translations.js.map +1 -1
  127. package/dist/esm/providers/stack-provider-client.js.map +1 -1
  128. package/dist/esm/providers/stack-provider.js.map +1 -1
  129. package/dist/esm/providers/theme-provider.js.map +1 -1
  130. package/dist/esm/providers/translation-provider-client.js.map +1 -1
  131. package/dist/esm/providers/translation-provider.js.map +1 -1
  132. package/dist/esm/utils/browser-script.js.map +1 -1
  133. package/dist/esm/utils/constants.js.map +1 -1
  134. package/dist/esm/utils/url.js +4 -13
  135. package/dist/esm/utils/url.js.map +1 -1
  136. package/dist/generated/quetzal-translations.d.mts +2 -2
  137. package/dist/generated/quetzal-translations.d.ts +2 -2
  138. package/dist/generated/quetzal-translations.js.map +1 -1
  139. package/dist/{lib/stack-app.d.mts → index-C7D6Vt7X.d.mts} +139 -354
  140. package/dist/{lib/stack-app.d.ts → index-DQk7XJpU.d.ts} +139 -354
  141. package/dist/index.d.mts +17 -5
  142. package/dist/index.d.ts +17 -5
  143. package/dist/index.js.map +1 -1
  144. package/dist/lib/auth.js.map +1 -1
  145. package/dist/lib/cookie.d.mts +2 -2
  146. package/dist/lib/cookie.d.ts +2 -2
  147. package/dist/lib/cookie.js +5 -8
  148. package/dist/lib/cookie.js.map +1 -1
  149. package/dist/lib/hooks.d.mts +17 -5
  150. package/dist/lib/hooks.d.ts +17 -5
  151. package/dist/lib/hooks.js.map +1 -1
  152. package/dist/lib/stack-app/api-keys/index.d.mts +40 -0
  153. package/dist/lib/stack-app/api-keys/index.d.ts +40 -0
  154. package/dist/lib/stack-app/api-keys/index.js +39 -0
  155. package/dist/lib/stack-app/api-keys/index.js.map +1 -0
  156. package/dist/lib/stack-app/apps/implementations/admin-app-impl.d.mts +30 -0
  157. package/dist/lib/stack-app/apps/implementations/admin-app-impl.d.ts +30 -0
  158. package/dist/lib/stack-app/apps/implementations/admin-app-impl.js +316 -0
  159. package/dist/lib/stack-app/apps/implementations/admin-app-impl.js.map +1 -0
  160. package/dist/lib/stack-app/apps/implementations/client-app-impl.d.mts +30 -0
  161. package/dist/lib/stack-app/apps/implementations/client-app-impl.d.ts +30 -0
  162. package/dist/lib/{stack-app.js → stack-app/apps/implementations/client-app-impl.js} +77 -1154
  163. package/dist/lib/stack-app/apps/implementations/client-app-impl.js.map +1 -0
  164. package/dist/lib/stack-app/apps/implementations/common.d.mts +45 -0
  165. package/dist/lib/stack-app/apps/implementations/common.d.ts +45 -0
  166. package/dist/lib/stack-app/apps/implementations/common.js +187 -0
  167. package/dist/lib/stack-app/apps/implementations/common.js.map +1 -0
  168. package/dist/lib/stack-app/apps/implementations/index.d.mts +36 -0
  169. package/dist/lib/stack-app/apps/implementations/index.d.ts +36 -0
  170. package/dist/lib/stack-app/apps/implementations/index.js +51 -0
  171. package/dist/lib/stack-app/apps/implementations/index.js.map +1 -0
  172. package/dist/lib/stack-app/apps/implementations/server-app-impl.d.mts +30 -0
  173. package/dist/lib/stack-app/apps/implementations/server-app-impl.d.ts +30 -0
  174. package/dist/lib/stack-app/apps/implementations/server-app-impl.js +552 -0
  175. package/dist/lib/stack-app/apps/implementations/server-app-impl.js.map +1 -0
  176. package/dist/lib/stack-app/apps/index.d.mts +23 -0
  177. package/dist/lib/stack-app/apps/index.d.ts +23 -0
  178. package/dist/lib/stack-app/apps/index.js +37 -0
  179. package/dist/lib/stack-app/apps/index.js.map +1 -0
  180. package/dist/lib/stack-app/apps/interfaces/admin-app.d.mts +23 -0
  181. package/dist/lib/stack-app/apps/interfaces/admin-app.d.ts +23 -0
  182. package/dist/lib/stack-app/apps/interfaces/admin-app.js +32 -0
  183. package/dist/lib/stack-app/apps/interfaces/admin-app.js.map +1 -0
  184. package/dist/lib/stack-app/apps/interfaces/client-app.d.mts +23 -0
  185. package/dist/lib/stack-app/apps/interfaces/client-app.d.ts +23 -0
  186. package/dist/lib/stack-app/apps/interfaces/client-app.js +32 -0
  187. package/dist/lib/stack-app/apps/interfaces/client-app.js.map +1 -0
  188. package/dist/lib/stack-app/apps/interfaces/server-app.d.mts +23 -0
  189. package/dist/lib/stack-app/apps/interfaces/server-app.d.ts +23 -0
  190. package/dist/lib/stack-app/apps/interfaces/server-app.js +32 -0
  191. package/dist/lib/stack-app/apps/interfaces/server-app.js.map +1 -0
  192. package/dist/lib/stack-app/common.d.mts +63 -0
  193. package/dist/lib/stack-app/common.d.ts +63 -0
  194. package/dist/lib/stack-app/common.js +31 -0
  195. package/dist/lib/stack-app/common.js.map +1 -0
  196. package/dist/lib/stack-app/connected-accounts/index.d.mts +13 -0
  197. package/dist/lib/stack-app/connected-accounts/index.d.ts +13 -0
  198. package/dist/lib/stack-app/connected-accounts/index.js +19 -0
  199. package/dist/lib/stack-app/connected-accounts/index.js.map +1 -0
  200. package/dist/lib/stack-app/contact-channels/index.d.mts +38 -0
  201. package/dist/lib/stack-app/contact-channels/index.d.ts +38 -0
  202. package/dist/lib/stack-app/contact-channels/index.js +67 -0
  203. package/dist/lib/stack-app/contact-channels/index.js.map +1 -0
  204. package/dist/lib/stack-app/email-templates/index.d.mts +15 -0
  205. package/dist/lib/stack-app/email-templates/index.d.ts +15 -0
  206. package/dist/lib/stack-app/email-templates/index.js +36 -0
  207. package/dist/lib/stack-app/email-templates/index.js.map +1 -0
  208. package/dist/lib/stack-app/index.d.mts +23 -0
  209. package/dist/lib/stack-app/index.d.ts +23 -0
  210. package/dist/lib/stack-app/index.js +38 -0
  211. package/dist/lib/stack-app/index.js.map +1 -0
  212. package/dist/lib/stack-app/permissions/index.d.mts +21 -0
  213. package/dist/lib/stack-app/permissions/index.d.ts +21 -0
  214. package/dist/lib/stack-app/permissions/index.js +46 -0
  215. package/dist/lib/stack-app/permissions/index.js.map +1 -0
  216. package/dist/lib/stack-app/project-configs/index.d.mts +82 -0
  217. package/dist/lib/stack-app/project-configs/index.d.ts +82 -0
  218. package/dist/lib/stack-app/project-configs/index.js +19 -0
  219. package/dist/lib/stack-app/project-configs/index.js.map +1 -0
  220. package/dist/lib/stack-app/projects/index.d.mts +23 -0
  221. package/dist/lib/stack-app/projects/index.d.ts +23 -0
  222. package/dist/lib/stack-app/projects/index.js +83 -0
  223. package/dist/lib/stack-app/projects/index.js.map +1 -0
  224. package/dist/lib/stack-app/teams/index.d.mts +23 -0
  225. package/dist/lib/stack-app/teams/index.d.ts +23 -0
  226. package/dist/lib/stack-app/teams/index.js +66 -0
  227. package/dist/lib/stack-app/teams/index.js.map +1 -0
  228. package/dist/lib/stack-app/users/index.d.mts +23 -0
  229. package/dist/lib/stack-app/users/index.d.ts +23 -0
  230. package/dist/lib/stack-app/users/index.js +74 -0
  231. package/dist/lib/stack-app/users/index.js.map +1 -0
  232. package/dist/lib/translations.js.map +1 -1
  233. package/dist/providers/stack-provider-client.d.mts +17 -5
  234. package/dist/providers/stack-provider-client.d.ts +17 -5
  235. package/dist/providers/stack-provider-client.js.map +1 -1
  236. package/dist/providers/stack-provider.d.mts +18 -6
  237. package/dist/providers/stack-provider.d.ts +18 -6
  238. package/dist/providers/stack-provider.js.map +1 -1
  239. package/dist/providers/theme-provider.js.map +1 -1
  240. package/dist/providers/translation-provider-client.js.map +1 -1
  241. package/dist/providers/translation-provider.js.map +1 -1
  242. package/dist/utils/browser-script.js.map +1 -1
  243. package/dist/utils/constants.js.map +1 -1
  244. package/dist/utils/url.d.mts +1 -2
  245. package/dist/utils/url.d.ts +1 -2
  246. package/dist/utils/url.js +4 -14
  247. package/dist/utils/url.js.map +1 -1
  248. package/package.json +4 -4
  249. package/dist/esm/lib/stack-app.js.map +0 -1
  250. package/dist/lib/stack-app.js.map +0 -1
package/CHANGELOG.md CHANGED
@@ -1,5 +1,25 @@
1
1
  # @stackframe/stack
2
2
 
3
+ ## 2.7.22
4
+
5
+ ### Patch Changes
6
+
7
+ - Various changes
8
+ - Updated dependencies
9
+ - @stackframe/stack-shared@2.7.22
10
+ - @stackframe/stack-ui@2.7.22
11
+ - @stackframe/stack-sc@2.7.22
12
+
13
+ ## 2.7.21
14
+
15
+ ### Patch Changes
16
+
17
+ - Various changes
18
+ - Updated dependencies
19
+ - @stackframe/stack-shared@2.7.21
20
+ - @stackframe/stack-ui@2.7.21
21
+ - @stackframe/stack-sc@2.7.21
22
+
3
23
  ## 2.7.20
4
24
 
5
25
  ### Patch Changes
@@ -0,0 +1,395 @@
1
+ import * as _stackframe_stack_shared_dist_sessions from '@stackframe/stack-shared/dist/sessions';
2
+ import { InternalSession } from '@stackframe/stack-shared/dist/sessions';
3
+ import * as _stackframe_stack_shared_dist_interface_crud_current_user from '@stackframe/stack-shared/dist/interface/crud/current-user';
4
+ import { CurrentUserCrud } from '@stackframe/stack-shared/dist/interface/crud/current-user';
5
+ import { f as StackClientAppConstructorOptions, a as StackClientApp, P as Project, w as TeamUser, t as TeamInvitation, T as Team, x as Auth, E as EditableTeamMemberProfile, G as BaseUser, H as UserExtra, I as InternalUserExtra, J as ProjectCurrentUser, K as UserUpdateOptions, A as AdminOwnedProject, l as AdminProjectUpdateOptions, g as StackClientAppJson, i as StackServerAppConstructorOptions, D as ServerUser, r as ServerTeamUser, L as ProjectCurrentServerUser, n as ServerTeam, M as ServerUserCreateOptions, m as ServerListUsersOptions, o as ServerTeamCreateOptions, d as StackAdminAppConstructorOptions, j as AdminProject } from './index-DQk7XJpU.js';
6
+ import { TokenStoreInit, RedirectMethod, HandlerUrls, OAuthScopesOnSignIn, RequestLike, RedirectToOptions, GetUserOptions, stackAppInternalsSymbol, EmailConfig } from './lib/stack-app/common.js';
7
+ import { StackClientInterface, KnownErrors, StackServerInterface, StackAdminInterface } from '@stackframe/stack-shared';
8
+ import { Result } from '@stackframe/stack-shared/dist/utils/results';
9
+ import { TeamPermission, AdminTeamPermission, AdminTeamPermissionDefinition, AdminTeamPermissionDefinitionCreateOptions, AdminTeamPermissionDefinitionUpdateOptions } from './lib/stack-app/permissions/index.js';
10
+ import { ApiKeyCreateCrudResponse } from '@stackframe/stack-shared/dist/interface/adminInterface';
11
+ import { ApiKeysCrud } from '@stackframe/stack-shared/dist/interface/crud/api-keys';
12
+ import { EmailTemplateCrud, EmailTemplateType } from '@stackframe/stack-shared/dist/interface/crud/email-templates';
13
+ import { ProjectsCrud, InternalProjectsCrud } from '@stackframe/stack-shared/dist/interface/crud/projects';
14
+ import { ApiKeyBaseCrudRead, ApiKeyBase, ApiKey, ApiKeyFirstView, ApiKeyCreateOptions } from './lib/stack-app/api-keys/index.js';
15
+ import { AdminEmailTemplate, AdminEmailTemplateUpdateOptions } from './lib/stack-app/email-templates/index.js';
16
+ import { ContactChannelsCrud } from '@stackframe/stack-shared/dist/interface/crud/contact-channels';
17
+ import { TeamInvitationCrud } from '@stackframe/stack-shared/dist/interface/crud/team-invitation';
18
+ import { TeamMemberProfilesCrud } from '@stackframe/stack-shared/dist/interface/crud/team-member-profiles';
19
+ import { TeamPermissionsCrud, TeamPermissionDefinitionsCrud } from '@stackframe/stack-shared/dist/interface/crud/team-permissions';
20
+ import { TeamsCrud } from '@stackframe/stack-shared/dist/interface/crud/teams';
21
+ import { UsersCrud } from '@stackframe/stack-shared/dist/interface/crud/users';
22
+ import { ContactChannel, ServerContactChannel } from './lib/stack-app/contact-channels/index.js';
23
+ import { ProviderType } from '@stackframe/stack-shared/dist/utils/oauth';
24
+ import { Store } from '@stackframe/stack-shared/dist/utils/stores';
25
+ import { CookieHelper } from './lib/cookie.js';
26
+ import { TokenObject } from './lib/stack-app/apps/implementations/common.js';
27
+
28
+ declare class _StackClientAppImplIncomplete<HasTokenStore extends boolean, ProjectId extends string = string> {
29
+ protected readonly _options: {
30
+ uniqueIdentifier?: string;
31
+ checkString?: string;
32
+ } & (StackClientAppConstructorOptions<HasTokenStore, ProjectId> | Exclude<StackClientAppConstructorOptions<HasTokenStore, ProjectId>, "baseUrl" | "projectId" | "publishableClientKey"> & {
33
+ interface: StackClientInterface;
34
+ });
35
+ /**
36
+ * There is a circular dependency between the admin app and the client app, as the former inherits from the latter and
37
+ * the latter needs to use the former when creating a new instance of an internal project.
38
+ *
39
+ * To break it, we set the admin app here lazily instead of importing it directly. This variable is set by ./index.ts,
40
+ * which imports both this file and ./admin-app-impl.ts.
41
+ */
42
+ static readonly LazyStackAdminAppImpl: {
43
+ value: typeof _StackAdminAppImplIncomplete | undefined;
44
+ };
45
+ protected _uniqueIdentifier: string | undefined;
46
+ protected _interface: StackClientInterface;
47
+ protected readonly _tokenStoreInit: TokenStoreInit<HasTokenStore>;
48
+ protected readonly _redirectMethod: RedirectMethod | undefined;
49
+ protected readonly _urlOptions: Partial<HandlerUrls>;
50
+ protected readonly _oauthScopesOnSignIn: Partial<OAuthScopesOnSignIn>;
51
+ private __DEMO_ENABLE_SLIGHT_FETCH_DELAY;
52
+ private readonly _ownedAdminApps;
53
+ private readonly _currentUserCache;
54
+ private readonly _currentProjectCache;
55
+ private readonly _ownedProjectsCache;
56
+ private readonly _currentUserPermissionsCache;
57
+ private readonly _currentUserTeamsCache;
58
+ private readonly _currentUserOAuthConnectionAccessTokensCache;
59
+ private readonly _currentUserOAuthConnectionCache;
60
+ private readonly _teamMemberProfilesCache;
61
+ private readonly _teamInvitationsCache;
62
+ private readonly _currentUserTeamProfileCache;
63
+ private readonly _clientContactChannelsCache;
64
+ protected _createCookieHelper(): Promise<CookieHelper>;
65
+ protected _getUserOAuthConnectionCacheFn(options: {
66
+ getUser: () => Promise<CurrentUserCrud['Client']['Read'] | null>;
67
+ getOrWaitOAuthToken: () => Promise<{
68
+ accessToken: string;
69
+ } | null>;
70
+ useOAuthToken: () => {
71
+ accessToken: string;
72
+ } | null;
73
+ providerId: ProviderType;
74
+ scope: string | null;
75
+ } & ({
76
+ redirect: true;
77
+ session: InternalSession | null;
78
+ } | {
79
+ redirect: false;
80
+ })): Promise<{
81
+ id: "google" | "github" | "microsoft" | "spotify" | "facebook" | "discord" | "gitlab" | "bitbucket" | "linkedin" | "apple" | "x";
82
+ getAccessToken(): Promise<{
83
+ accessToken: string;
84
+ }>;
85
+ useAccessToken(): {
86
+ accessToken: string;
87
+ };
88
+ } | null>;
89
+ constructor(_options: {
90
+ uniqueIdentifier?: string;
91
+ checkString?: string;
92
+ } & (StackClientAppConstructorOptions<HasTokenStore, ProjectId> | Exclude<StackClientAppConstructorOptions<HasTokenStore, ProjectId>, "baseUrl" | "projectId" | "publishableClientKey"> & {
93
+ interface: StackClientInterface;
94
+ }));
95
+ protected _initUniqueIdentifier(): void;
96
+ /**
97
+ * Cloudflare workers does not allow use of randomness on the global scope (on which the Stack app is probably
98
+ * initialized). For that reason, we generate the unique identifier lazily when it is first needed instead of in the
99
+ * constructor.
100
+ */
101
+ protected _getUniqueIdentifier(): string;
102
+ protected _checkFeatureSupport(name: string, options: any): Promise<never>;
103
+ protected _useCheckFeatureSupport(name: string, options: any): never;
104
+ protected _memoryTokenStore: Store<TokenObject>;
105
+ protected _nextServerCookiesTokenStores: WeakMap<object, Store<TokenObject>>;
106
+ protected _requestTokenStores: WeakMap<RequestLike, Store<TokenObject>>;
107
+ protected _storedBrowserCookieTokenStore: Store<TokenObject> | null;
108
+ protected get _refreshTokenCookieName(): string;
109
+ protected _getTokensFromCookies(cookies: {
110
+ refreshTokenCookie: string | null;
111
+ accessTokenCookie: string | null;
112
+ }): TokenObject;
113
+ protected get _accessTokenCookieName(): string;
114
+ protected _getBrowserCookieTokenStore(): Store<TokenObject>;
115
+ protected _getOrCreateTokenStore(cookieHelper: CookieHelper, overrideTokenStoreInit?: TokenStoreInit): Store<TokenObject>;
116
+ protected _useTokenStore(overrideTokenStoreInit?: TokenStoreInit): Store<TokenObject>;
117
+ /**
118
+ * A map from token stores and session keys to sessions.
119
+ *
120
+ * This isn't just a map from session keys to sessions for two reasons:
121
+ *
122
+ * - So we can garbage-collect Session objects when the token store is garbage-collected
123
+ * - So different token stores are separated and don't leak information between each other, eg. if the same user sends two requests to the same server they should get a different session object
124
+ */
125
+ private _sessionsByTokenStoreAndSessionKey;
126
+ protected _getSessionFromTokenStore(tokenStore: Store<TokenObject>): InternalSession;
127
+ protected _getSession(overrideTokenStoreInit?: TokenStoreInit): Promise<InternalSession>;
128
+ protected _useSession(overrideTokenStoreInit?: TokenStoreInit): InternalSession;
129
+ protected _signInToAccountWithTokens(tokens: {
130
+ accessToken: string | null;
131
+ refreshToken: string;
132
+ }): Promise<void>;
133
+ protected _hasPersistentTokenStore(overrideTokenStoreInit?: TokenStoreInit): this is StackClientApp<true, ProjectId>;
134
+ protected _ensurePersistentTokenStore(overrideTokenStoreInit?: TokenStoreInit): asserts this is StackClientApp<true, ProjectId>;
135
+ protected _isInternalProject(): this is {
136
+ projectId: "internal";
137
+ };
138
+ protected _ensureInternalProject(): asserts this is {
139
+ projectId: "internal";
140
+ };
141
+ protected _clientProjectFromCrud(crud: ProjectsCrud['Client']['Read']): Project;
142
+ protected _clientTeamPermissionFromCrud(crud: TeamPermissionsCrud['Client']['Read']): TeamPermission;
143
+ protected _clientTeamUserFromCrud(crud: TeamMemberProfilesCrud['Client']['Read']): TeamUser;
144
+ protected _clientTeamInvitationFromCrud(session: InternalSession, crud: TeamInvitationCrud['Client']['Read']): TeamInvitation;
145
+ protected _clientTeamFromCrud(crud: TeamsCrud['Client']['Read'], session: InternalSession): Team;
146
+ protected _clientContactChannelFromCrud(crud: ContactChannelsCrud['Client']['Read'], session: InternalSession): ContactChannel;
147
+ protected _createAuth(session: InternalSession): Auth;
148
+ protected _editableTeamProfileFromCrud(crud: TeamMemberProfilesCrud['Client']['Read'], session: InternalSession): EditableTeamMemberProfile;
149
+ protected _createBaseUser(crud: NonNullable<CurrentUserCrud['Client']['Read']> | UsersCrud['Server']['Read']): BaseUser;
150
+ protected _createUserExtraFromCurrent(crud: NonNullable<CurrentUserCrud['Client']['Read']>, session: InternalSession): UserExtra;
151
+ protected _createInternalUserExtra(session: InternalSession): InternalUserExtra;
152
+ protected _currentUserFromCrud(crud: NonNullable<CurrentUserCrud['Client']['Read']>, session: InternalSession): ProjectCurrentUser<ProjectId>;
153
+ protected _getOwnedAdminApp(forProjectId: string, session: InternalSession): _StackAdminAppImplIncomplete<false, string>;
154
+ get projectId(): ProjectId;
155
+ protected _isTrusted(url: string): Promise<boolean>;
156
+ get urls(): Readonly<HandlerUrls>;
157
+ protected _getCurrentUrl(): Promise<URL | null>;
158
+ protected _redirectTo(options: {
159
+ url: URL | string;
160
+ replace?: boolean;
161
+ }): Promise<void>;
162
+ useNavigate(): (to: string) => void;
163
+ protected _redirectIfTrusted(url: string, options?: RedirectToOptions): Promise<void>;
164
+ protected _redirectToHandler(handlerName: keyof HandlerUrls, options?: RedirectToOptions): Promise<void>;
165
+ redirectToSignIn(options?: RedirectToOptions): Promise<void>;
166
+ redirectToSignUp(options?: RedirectToOptions): Promise<void>;
167
+ redirectToSignOut(options?: RedirectToOptions): Promise<void>;
168
+ redirectToEmailVerification(options?: RedirectToOptions): Promise<void>;
169
+ redirectToPasswordReset(options?: RedirectToOptions): Promise<void>;
170
+ redirectToForgotPassword(options?: RedirectToOptions): Promise<void>;
171
+ redirectToHome(options?: RedirectToOptions): Promise<void>;
172
+ redirectToOAuthCallback(options?: RedirectToOptions): Promise<void>;
173
+ redirectToMagicLinkCallback(options?: RedirectToOptions): Promise<void>;
174
+ redirectToAfterSignIn(options?: RedirectToOptions): Promise<void>;
175
+ redirectToAfterSignUp(options?: RedirectToOptions): Promise<void>;
176
+ redirectToAfterSignOut(options?: RedirectToOptions): Promise<void>;
177
+ redirectToAccountSettings(options?: RedirectToOptions): Promise<void>;
178
+ redirectToError(options?: RedirectToOptions): Promise<void>;
179
+ redirectToTeamInvitation(options?: RedirectToOptions): Promise<void>;
180
+ sendForgotPasswordEmail(email: string, options?: {
181
+ callbackUrl?: string;
182
+ }): Promise<Result<undefined, KnownErrors["UserNotFound"]>>;
183
+ sendMagicLinkEmail(email: string, options?: {
184
+ callbackUrl?: string;
185
+ }): Promise<Result<{
186
+ nonce: string;
187
+ }, KnownErrors["RedirectUrlNotWhitelisted"]>>;
188
+ resetPassword(options: {
189
+ password: string;
190
+ code: string;
191
+ }): Promise<Result<undefined, KnownErrors["VerificationCodeError"]>>;
192
+ verifyPasswordResetCode(code: string): Promise<Result<undefined, KnownErrors["VerificationCodeError"]>>;
193
+ verifyTeamInvitationCode(code: string): Promise<Result<undefined, KnownErrors["VerificationCodeError"]>>;
194
+ acceptTeamInvitation(code: string): Promise<Result<undefined, KnownErrors["VerificationCodeError"]>>;
195
+ getTeamInvitationDetails(code: string): Promise<Result<{
196
+ teamDisplayName: string;
197
+ }, KnownErrors["VerificationCodeError"]>>;
198
+ verifyEmail(code: string): Promise<Result<undefined, KnownErrors["VerificationCodeError"]>>;
199
+ getUser(options: GetUserOptions<HasTokenStore> & {
200
+ or: 'redirect';
201
+ }): Promise<ProjectCurrentUser<ProjectId>>;
202
+ getUser(options: GetUserOptions<HasTokenStore> & {
203
+ or: 'throw';
204
+ }): Promise<ProjectCurrentUser<ProjectId>>;
205
+ getUser(options?: GetUserOptions<HasTokenStore>): Promise<ProjectCurrentUser<ProjectId> | null>;
206
+ useUser(options: GetUserOptions<HasTokenStore> & {
207
+ or: 'redirect';
208
+ }): ProjectCurrentUser<ProjectId>;
209
+ useUser(options: GetUserOptions<HasTokenStore> & {
210
+ or: 'throw';
211
+ }): ProjectCurrentUser<ProjectId>;
212
+ useUser(options?: GetUserOptions<HasTokenStore>): ProjectCurrentUser<ProjectId> | null;
213
+ protected _updateClientUser(update: UserUpdateOptions, session: InternalSession): Promise<void>;
214
+ signInWithOAuth(provider: ProviderType): Promise<void>;
215
+ /**
216
+ * @deprecated
217
+ * TODO remove
218
+ */
219
+ protected _experimentalMfa(error: KnownErrors['MultiFactorAuthenticationRequired'], session: InternalSession): Promise<{
220
+ accessToken: any;
221
+ refreshToken: any;
222
+ newUser: any;
223
+ }>;
224
+ /**
225
+ * @deprecated
226
+ * TODO remove
227
+ */
228
+ protected _catchMfaRequiredError<T, E>(callback: () => Promise<Result<T, E>>): Promise<Result<T | {
229
+ accessToken: string;
230
+ refreshToken: string;
231
+ newUser: boolean;
232
+ }, E>>;
233
+ signInWithCredential(options: {
234
+ email: string;
235
+ password: string;
236
+ noRedirect?: boolean;
237
+ }): Promise<Result<undefined, KnownErrors["EmailPasswordMismatch"] | KnownErrors["InvalidTotpCode"]>>;
238
+ signUpWithCredential(options: {
239
+ email: string;
240
+ password: string;
241
+ noRedirect?: boolean;
242
+ verificationCallbackUrl?: string;
243
+ }): Promise<Result<undefined, KnownErrors["UserEmailAlreadyExists"] | KnownErrors['PasswordRequirementsNotMet']>>;
244
+ signInWithMagicLink(code: string): Promise<Result<undefined, KnownErrors["VerificationCodeError"] | KnownErrors["InvalidTotpCode"]>>;
245
+ signInWithPasskey(): Promise<Result<undefined, KnownErrors["PasskeyAuthenticationFailed"] | KnownErrors["InvalidTotpCode"] | KnownErrors["PasskeyWebAuthnError"]>>;
246
+ callOAuthCallback(): Promise<boolean>;
247
+ protected _signOut(session: InternalSession, options?: {
248
+ redirectUrl?: URL | string;
249
+ }): Promise<void>;
250
+ signOut(options?: {
251
+ redirectUrl?: URL | string;
252
+ }): Promise<void>;
253
+ getProject(): Promise<Project>;
254
+ useProject(): Project;
255
+ protected _listOwnedProjects(session: InternalSession): Promise<AdminOwnedProject[]>;
256
+ protected _useOwnedProjects(session: InternalSession): AdminOwnedProject[];
257
+ protected _createProject(session: InternalSession, newProject: AdminProjectUpdateOptions & {
258
+ displayName: string;
259
+ }): Promise<AdminOwnedProject>;
260
+ protected _refreshUser(session: InternalSession): Promise<void>;
261
+ protected _refreshSession(session: InternalSession): Promise<void>;
262
+ protected _refreshUsers(): Promise<void>;
263
+ protected _refreshProject(): Promise<void>;
264
+ protected _refreshOwnedProjects(session: InternalSession): Promise<void>;
265
+ static get [stackAppInternalsSymbol](): {
266
+ fromClientJson: <HasTokenStore extends boolean, ProjectId extends string>(json: StackClientAppJson<HasTokenStore, ProjectId>) => StackClientApp<HasTokenStore, ProjectId>;
267
+ };
268
+ get [stackAppInternalsSymbol](): {
269
+ toClientJson: () => StackClientAppJson<HasTokenStore, ProjectId>;
270
+ setCurrentUser: (userJsonPromise: Promise<CurrentUserCrud["Client"]["Read"] | null>) => void;
271
+ sendRequest: (path: string, requestOptions: RequestInit, requestType?: "client" | "server" | "admin") => Promise<Response & {
272
+ usedTokens: {
273
+ accessToken: _stackframe_stack_shared_dist_sessions.AccessToken;
274
+ refreshToken: _stackframe_stack_shared_dist_sessions.RefreshToken | null;
275
+ } | null;
276
+ }>;
277
+ };
278
+ }
279
+
280
+ declare class _StackServerAppImplIncomplete<HasTokenStore extends boolean, ProjectId extends string> extends _StackClientAppImplIncomplete<HasTokenStore, ProjectId> {
281
+ protected _interface: StackServerInterface;
282
+ private readonly _currentServerUserCache;
283
+ private readonly _serverUsersCache;
284
+ private readonly _serverUserCache;
285
+ private readonly _serverTeamsCache;
286
+ private readonly _serverTeamUserPermissionsCache;
287
+ private readonly _serverUserOAuthConnectionAccessTokensCache;
288
+ private readonly _serverUserOAuthConnectionCache;
289
+ private readonly _serverTeamMemberProfilesCache;
290
+ private readonly _serverTeamInvitationsCache;
291
+ private readonly _serverUserTeamProfileCache;
292
+ private readonly _serverContactChannelsCache;
293
+ private _updateServerUser;
294
+ protected _serverEditableTeamProfileFromCrud(crud: TeamMemberProfilesCrud['Client']['Read']): EditableTeamMemberProfile;
295
+ protected _serverContactChannelFromCrud(userId: string, crud: ContactChannelsCrud['Server']['Read']): ServerContactChannel;
296
+ constructor(options: StackServerAppConstructorOptions<HasTokenStore, ProjectId> | {
297
+ interface: StackServerInterface;
298
+ tokenStore: TokenStoreInit<HasTokenStore>;
299
+ urls: Partial<HandlerUrls> | undefined;
300
+ oauthScopesOnSignIn?: Partial<OAuthScopesOnSignIn> | undefined;
301
+ });
302
+ protected _serverUserFromCrud(crud: UsersCrud['Server']['Read']): ServerUser;
303
+ protected _serverTeamUserFromCrud(crud: TeamMemberProfilesCrud["Server"]["Read"]): ServerTeamUser;
304
+ protected _serverTeamInvitationFromCrud(crud: TeamInvitationCrud['Server']['Read']): TeamInvitation;
305
+ protected _currentUserFromCrud(crud: UsersCrud['Server']['Read'], session: InternalSession): ProjectCurrentServerUser<ProjectId>;
306
+ protected _serverTeamFromCrud(crud: TeamsCrud['Server']['Read']): ServerTeam;
307
+ createUser(options: ServerUserCreateOptions): Promise<ServerUser>;
308
+ getUser(options: GetUserOptions<HasTokenStore> & {
309
+ or: 'redirect';
310
+ }): Promise<ProjectCurrentServerUser<ProjectId>>;
311
+ getUser(options: GetUserOptions<HasTokenStore> & {
312
+ or: 'throw';
313
+ }): Promise<ProjectCurrentServerUser<ProjectId>>;
314
+ getUser(options?: GetUserOptions<HasTokenStore>): Promise<ProjectCurrentServerUser<ProjectId> | null>;
315
+ getUser(id: string): Promise<ServerUser | null>;
316
+ getServerUser(): Promise<ProjectCurrentServerUser<ProjectId> | null>;
317
+ getServerUserById(userId: string): Promise<ServerUser | null>;
318
+ useUser(options: GetUserOptions<HasTokenStore> & {
319
+ or: 'redirect';
320
+ }): ProjectCurrentServerUser<ProjectId>;
321
+ useUser(options: GetUserOptions<HasTokenStore> & {
322
+ or: 'throw';
323
+ }): ProjectCurrentServerUser<ProjectId>;
324
+ useUser(options?: GetUserOptions<HasTokenStore>): ProjectCurrentServerUser<ProjectId> | null;
325
+ useUser(id: string): ServerUser | null;
326
+ useUserById(userId: string): ServerUser | null;
327
+ listUsers(options?: ServerListUsersOptions): Promise<ServerUser[] & {
328
+ nextCursor: string | null;
329
+ }>;
330
+ useUsers(options?: ServerListUsersOptions): ServerUser[] & {
331
+ nextCursor: string | null;
332
+ };
333
+ _serverPermissionFromCrud(crud: TeamPermissionsCrud['Server']['Read']): AdminTeamPermission;
334
+ _serverTeamPermissionDefinitionFromCrud(crud: TeamPermissionDefinitionsCrud['Admin']['Read']): AdminTeamPermissionDefinition;
335
+ listTeams(): Promise<ServerTeam[]>;
336
+ createTeam(data: ServerTeamCreateOptions): Promise<ServerTeam>;
337
+ useTeams(): ServerTeam[];
338
+ getTeam(teamId: string): Promise<ServerTeam | null>;
339
+ useTeam(teamId: string): ServerTeam | null;
340
+ protected _refreshSession(session: InternalSession): Promise<void>;
341
+ protected _refreshUsers(): Promise<void>;
342
+ }
343
+
344
+ declare class _StackAdminAppImplIncomplete<HasTokenStore extends boolean, ProjectId extends string> extends _StackServerAppImplIncomplete<HasTokenStore, ProjectId> {
345
+ protected _interface: StackAdminInterface;
346
+ private readonly _adminProjectCache;
347
+ private readonly _apiKeysCache;
348
+ private readonly _adminEmailTemplatesCache;
349
+ private readonly _adminTeamPermissionDefinitionsCache;
350
+ private readonly _svixTokenCache;
351
+ private readonly _metricsCache;
352
+ constructor(options: StackAdminAppConstructorOptions<HasTokenStore, ProjectId>);
353
+ _adminOwnedProjectFromCrud(data: InternalProjectsCrud['Admin']['Read'], onRefresh: () => Promise<void>): AdminOwnedProject;
354
+ _adminProjectFromCrud(data: InternalProjectsCrud['Admin']['Read'], onRefresh: () => Promise<void>): AdminProject;
355
+ _adminEmailTemplateFromCrud(data: EmailTemplateCrud['Admin']['Read']): AdminEmailTemplate;
356
+ getProject(): Promise<AdminProject>;
357
+ useProject(): AdminProject;
358
+ protected _createApiKeyBaseFromCrud(data: ApiKeyBaseCrudRead): ApiKeyBase;
359
+ protected _createApiKeyFromCrud(data: ApiKeysCrud["Admin"]["Read"]): ApiKey;
360
+ protected _createApiKeyFirstViewFromCrud(data: ApiKeyCreateCrudResponse): ApiKeyFirstView;
361
+ listApiKeys(): Promise<ApiKey[]>;
362
+ useApiKeys(): ApiKey[];
363
+ createApiKey(options: ApiKeyCreateOptions): Promise<ApiKeyFirstView>;
364
+ useEmailTemplates(): AdminEmailTemplate[];
365
+ listEmailTemplates(): Promise<AdminEmailTemplate[]>;
366
+ updateEmailTemplate(type: EmailTemplateType, data: AdminEmailTemplateUpdateOptions): Promise<void>;
367
+ resetEmailTemplate(type: EmailTemplateType): Promise<void>;
368
+ createTeamPermissionDefinition(data: AdminTeamPermissionDefinitionCreateOptions): Promise<AdminTeamPermission>;
369
+ updateTeamPermissionDefinition(permissionId: string, data: AdminTeamPermissionDefinitionUpdateOptions): Promise<void>;
370
+ deleteTeamPermissionDefinition(permissionId: string): Promise<void>;
371
+ listTeamPermissionDefinitions(): Promise<AdminTeamPermissionDefinition[]>;
372
+ useTeamPermissionDefinitions(): AdminTeamPermissionDefinition[];
373
+ useSvixToken(): string;
374
+ protected _refreshProject(): Promise<void>;
375
+ protected _refreshApiKeys(): Promise<void>;
376
+ get [stackAppInternalsSymbol](): {
377
+ useMetrics: () => any;
378
+ toClientJson: () => StackClientAppJson<HasTokenStore, ProjectId>;
379
+ setCurrentUser: (userJsonPromise: Promise<_stackframe_stack_shared_dist_interface_crud_current_user.CurrentUserCrud["Client"]["Read"] | null>) => void;
380
+ sendRequest: (path: string, requestOptions: RequestInit, requestType?: "client" | "server" | "admin") => Promise<Response & {
381
+ usedTokens: {
382
+ accessToken: _stackframe_stack_shared_dist_sessions.AccessToken;
383
+ refreshToken: _stackframe_stack_shared_dist_sessions.RefreshToken | null;
384
+ } | null;
385
+ }>;
386
+ };
387
+ sendTestEmail(options: {
388
+ recipientEmail: string;
389
+ emailConfig: EmailConfig;
390
+ }): Promise<Result<undefined, {
391
+ errorMessage: string;
392
+ }>>;
393
+ }
394
+
395
+ export { _StackAdminAppImplIncomplete as _, _StackClientAppImplIncomplete as a, _StackServerAppImplIncomplete as b };