@descope/react-sdk 1.0.3 → 1.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.ts CHANGED
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import React, { FC, DOMAttributes } from 'react';
3
2
  import DescopeWc, { ThemeOptions, AutoFocusOptions } from '@descope/web-component';
4
3
  import * as _descope_core_js_sdk from '@descope/core-js-sdk';
@@ -66,7 +65,12 @@ declare const createSdkWrapper: <P extends Omit<{
66
65
  name?: string;
67
66
  loginId?: string;
68
67
  };
69
- }, "tenant" | "redirectUrl"> & {
68
+ redirectAuth?: {
69
+ callbackUrl: string;
70
+ codeChallenge: string;
71
+ };
72
+ oidcIdpStateId?: string;
73
+ }, "tenant" | "redirectUrl" | "redirectAuth" | "oidcIdpStateId"> & {
70
74
  lastAuth?: Omit<{
71
75
  authMethod?: "webauthn" | "otp" | "oauth" | "saml" | "totp" | "magiclink" | "enchantedlink";
72
76
  oauthProvider?: string;
@@ -75,10 +79,10 @@ declare const createSdkWrapper: <P extends Omit<{
75
79
  }, "loginId" | "name">;
76
80
  }, conditionInteractionId?: string, interactionId?: string, input?: {
77
81
  [x: string]: string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | any[])[])[])[])[])[])[])[])[])[])[];
78
- }) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.FlowResponse>>;
82
+ }, version?: number) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.FlowResponse>>;
79
83
  next: (executionId: string, stepId: string, interactionId: string, input?: {
80
84
  [x: string]: string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | any[])[])[])[])[])[])[])[])[])[])[];
81
- }) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.FlowResponse>>;
85
+ }, version?: number) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.FlowResponse>>;
82
86
  };
83
87
  webauthn: {
84
88
  signUp: ((identifier: string, name: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>) & {
@@ -128,67 +132,73 @@ declare const createSdkWrapper: <P extends Omit<{
128
132
  };
129
133
  otp: {
130
134
  verify: {
131
- email: (loginId: string, code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
132
135
  sms: (loginId: string, code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
133
136
  whatsapp: (loginId: string, code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
137
+ email: (loginId: string, code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
134
138
  };
135
139
  signIn: {
136
- email: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
137
- maskedEmail: string;
138
- }>>;
139
140
  sms: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
140
141
  maskedPhone: string;
141
142
  }>>;
142
143
  whatsapp: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
143
144
  maskedPhone: string;
144
145
  }>>;
146
+ email: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
147
+ maskedEmail: string;
148
+ }>>;
145
149
  };
146
150
  signUp: {
147
- email: (loginId: string, user?: {
151
+ sms: (loginId: string, user?: {
148
152
  email?: string;
149
153
  name?: string;
150
154
  phone?: string;
151
155
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
152
- maskedEmail: string;
156
+ maskedPhone: string;
153
157
  }>>;
154
- sms: (loginId: string, user?: {
158
+ whatsapp: (loginId: string, user?: {
155
159
  email?: string;
156
160
  name?: string;
157
161
  phone?: string;
158
162
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
159
163
  maskedPhone: string;
160
164
  }>>;
161
- whatsapp: (loginId: string, user?: {
165
+ email: (loginId: string, user?: {
162
166
  email?: string;
163
167
  name?: string;
164
168
  phone?: string;
165
169
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
166
- maskedPhone: string;
170
+ maskedEmail: string;
167
171
  }>>;
168
172
  };
169
173
  signUpOrIn: {
170
- email: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
171
- maskedEmail: string;
172
- }>>;
173
174
  sms: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
174
175
  maskedPhone: string;
175
176
  }>>;
176
177
  whatsapp: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
177
178
  maskedPhone: string;
178
179
  }>>;
180
+ email: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
181
+ maskedEmail: string;
182
+ }>>;
179
183
  };
180
184
  update: {
181
- email: (loginId: string, email: string, token?: string) => Promise<_descope_core_js_sdk.SdkResponse<{
185
+ email: <T extends boolean>(loginId: string, email: string, token?: string, updateOptions?: {
186
+ addToLoginIDs?: T;
187
+ onMergeUseExisting?: T extends true ? boolean : never;
188
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
182
189
  maskedEmail: string;
183
190
  }>>;
184
191
  phone: {
185
- email: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
192
+ sms: <T_1 extends boolean>(loginId: string, phone: string, token?: string, updateOptions?: {
193
+ addToLoginIDs?: T_1;
194
+ onMergeUseExisting?: T_1 extends true ? boolean : never;
195
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
186
196
  maskedPhone: string;
187
197
  }>>;
188
- sms: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
189
- maskedPhone: string;
190
- }>>;
191
- whatsapp: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
198
+ whatsapp: <T_1_1 extends boolean>(loginId: string, phone: string, token?: string, updateOptions?: {
199
+ addToLoginIDs?: T_1_1;
200
+ onMergeUseExisting?: T_1_1 extends true ? boolean : never;
201
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
192
202
  maskedPhone: string;
193
203
  }>>;
194
204
  };
@@ -197,60 +207,68 @@ declare const createSdkWrapper: <P extends Omit<{
197
207
  magicLink: {
198
208
  verify: (token: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
199
209
  signIn: {
200
- email: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
201
- maskedEmail: string;
202
- }>>;
203
210
  sms: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
204
211
  maskedPhone: string;
205
212
  }>>;
206
213
  whatsapp: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
207
214
  maskedPhone: string;
208
215
  }>>;
216
+ email: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
217
+ maskedEmail: string;
218
+ }>>;
209
219
  };
210
220
  signUp: {
211
- email: (loginId: string, uri: string, user?: {
221
+ sms: (loginId: string, uri: string, user?: {
212
222
  email?: string;
213
223
  name?: string;
214
224
  phone?: string;
215
225
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
216
- maskedEmail: string;
226
+ maskedPhone: string;
217
227
  }>>;
218
- sms: (loginId: string, uri: string, user?: {
228
+ whatsapp: (loginId: string, uri: string, user?: {
219
229
  email?: string;
220
230
  name?: string;
221
231
  phone?: string;
222
232
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
223
233
  maskedPhone: string;
224
234
  }>>;
225
- whatsapp: (loginId: string, uri: string, user?: {
235
+ email: (loginId: string, uri: string, user?: {
226
236
  email?: string;
227
237
  name?: string;
228
238
  phone?: string;
229
239
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
230
- maskedPhone: string;
240
+ maskedEmail: string;
231
241
  }>>;
232
242
  };
233
243
  signUpOrIn: {
234
- email: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
235
- maskedEmail: string;
236
- }>>;
237
244
  sms: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
238
245
  maskedPhone: string;
239
246
  }>>;
240
247
  whatsapp: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
241
248
  maskedPhone: string;
242
249
  }>>;
250
+ email: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
251
+ maskedEmail: string;
252
+ }>>;
243
253
  };
244
254
  update: {
245
- email: (loginId: string, email: string, URI?: string, token?: string) => Promise<_descope_core_js_sdk.SdkResponse<never>>;
255
+ email: <T_2 extends boolean>(loginId: string, email: string, URI?: string, token?: string, updateOptions?: {
256
+ addToLoginIDs?: T_2;
257
+ onMergeUseExisting?: T_2 extends true ? boolean : never;
258
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
259
+ maskedEmail: string;
260
+ }>>;
246
261
  phone: {
247
- email: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
248
- maskedPhone: string;
249
- }>>;
250
- sms: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
262
+ sms: <T_3 extends boolean>(loginId: string, phone: string, URI?: string, token?: string, updateOptions?: {
263
+ addToLoginIDs?: T_3;
264
+ onMergeUseExisting?: T_3 extends true ? boolean : never;
265
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
251
266
  maskedPhone: string;
252
267
  }>>;
253
- whatsapp: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
268
+ whatsapp: <T_3_1 extends boolean>(loginId: string, phone: string, URI?: string, token?: string, updateOptions?: {
269
+ addToLoginIDs?: T_3_1;
270
+ onMergeUseExisting?: T_3_1 extends true ? boolean : never;
271
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
254
272
  maskedPhone: string;
255
273
  }>>;
256
274
  };
@@ -270,60 +288,47 @@ declare const createSdkWrapper: <P extends Omit<{
270
288
  timeoutMs: number;
271
289
  }) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
272
290
  update: {
273
- email: (loginId: string, email: string, URI?: string, token?: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.EnchantedLinkResponse>>;
291
+ email: <T_4 extends boolean>(loginId: string, email: string, URI?: string, token?: string, updateOptions?: {
292
+ addToLoginIDs?: T_4;
293
+ onMergeUseExisting?: T_4 extends true ? boolean : never;
294
+ }) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.EnchantedLinkResponse>>;
274
295
  };
275
296
  };
276
297
  oauth: {
277
298
  start: {
278
299
  facebook: <B extends {
279
300
  redirect: boolean;
280
- }>(redirectURL?: string, config?: B) => Promise<B extends {
281
- redirect: true;
282
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
301
+ }>(redirectURL?: string, config?: B) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
283
302
  github: <B_1 extends {
284
303
  redirect: boolean;
285
- }>(redirectURL?: string, config?: B_1) => Promise<B_1 extends {
286
- redirect: true;
287
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
304
+ }>(redirectURL?: string, config?: B_1) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
288
305
  google: <B_2 extends {
289
306
  redirect: boolean;
290
- }>(redirectURL?: string, config?: B_2) => Promise<B_2 extends {
291
- redirect: true;
292
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
307
+ }>(redirectURL?: string, config?: B_2) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
293
308
  microsoft: <B_3 extends {
294
309
  redirect: boolean;
295
- }>(redirectURL?: string, config?: B_3) => Promise<B_3 extends {
296
- redirect: true;
297
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
310
+ }>(redirectURL?: string, config?: B_3) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
298
311
  gitlab: <B_4 extends {
299
312
  redirect: boolean;
300
- }>(redirectURL?: string, config?: B_4) => Promise<B_4 extends {
301
- redirect: true;
302
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
313
+ }>(redirectURL?: string, config?: B_4) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
303
314
  apple: <B_5 extends {
304
315
  redirect: boolean;
305
- }>(redirectURL?: string, config?: B_5) => Promise<B_5 extends {
306
- redirect: true;
307
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
316
+ }>(redirectURL?: string, config?: B_5) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
308
317
  discord: <B_6 extends {
309
318
  redirect: boolean;
310
- }>(redirectURL?: string, config?: B_6) => Promise<B_6 extends {
311
- redirect: true;
312
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
319
+ }>(redirectURL?: string, config?: B_6) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
313
320
  linkedin: <B_7 extends {
314
321
  redirect: boolean;
315
- }>(redirectURL?: string, config?: B_7) => Promise<B_7 extends {
316
- redirect: true;
317
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
322
+ }>(redirectURL?: string, config?: B_7) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
318
323
  };
319
324
  exchange: (code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
320
325
  };
321
326
  saml: {
322
- start: <B_1_1 extends {
323
- redirect: boolean;
324
- }>(tenantNameOrEmail: string, config?: B_1_1) => Promise<B_1_1 extends {
325
- redirect: true;
326
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
327
+ start: (tenantIdOrEmail: string, redirectUrl?: string, loginOptions?: {
328
+ stepup?: boolean;
329
+ mfa?: boolean;
330
+ customClaims?: Record<string, any>;
331
+ }, token?: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
327
332
  exchange: (code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
328
333
  };
329
334
  totp: {
@@ -391,7 +396,7 @@ declare const createSdkWrapper: <P extends Omit<{
391
396
  };
392
397
  token?: string;
393
398
  }) => Promise<Response>;
394
- delete: (path: string, body?: any, config?: {
399
+ delete: (path: string, config?: {
395
400
  headers?: HeadersInit;
396
401
  queryParams?: {
397
402
  [key: string]: string;
@@ -417,7 +422,12 @@ declare const createSdkWrapper: <P extends Omit<{
417
422
  name?: string;
418
423
  loginId?: string;
419
424
  };
420
- }, "tenant" | "redirectUrl"> & {
425
+ redirectAuth?: {
426
+ callbackUrl: string;
427
+ codeChallenge: string;
428
+ };
429
+ oidcIdpStateId?: string;
430
+ }, "tenant" | "redirectUrl" | "redirectAuth" | "oidcIdpStateId"> & {
421
431
  lastAuth?: Omit<{
422
432
  authMethod?: "webauthn" | "otp" | "oauth" | "saml" | "totp" | "magiclink" | "enchantedlink";
423
433
  oauthProvider?: string;
@@ -426,10 +436,10 @@ declare const createSdkWrapper: <P extends Omit<{
426
436
  }, "loginId" | "name">;
427
437
  }, conditionInteractionId?: string, interactionId?: string, input?: {
428
438
  [x: string]: string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | any[])[])[])[])[])[])[])[])[])[])[];
429
- }) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.FlowResponse>>;
439
+ }, version?: number) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.FlowResponse>>;
430
440
  next: (executionId: string, stepId: string, interactionId: string, input?: {
431
441
  [x: string]: string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | (string | number | boolean | any[])[])[])[])[])[])[])[])[])[])[];
432
- }) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.FlowResponse>>;
442
+ }, version?: number) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.FlowResponse>>;
433
443
  };
434
444
  webauthn: {
435
445
  signUp: ((identifier: string, name: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>) & {
@@ -479,67 +489,73 @@ declare const createSdkWrapper: <P extends Omit<{
479
489
  };
480
490
  otp: {
481
491
  verify: {
482
- email: (loginId: string, code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
483
492
  sms: (loginId: string, code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
484
493
  whatsapp: (loginId: string, code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
494
+ email: (loginId: string, code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
485
495
  };
486
496
  signIn: {
487
- email: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
488
- maskedEmail: string;
489
- }>>;
490
497
  sms: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
491
498
  maskedPhone: string;
492
499
  }>>;
493
500
  whatsapp: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
494
501
  maskedPhone: string;
495
502
  }>>;
503
+ email: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
504
+ maskedEmail: string;
505
+ }>>;
496
506
  };
497
507
  signUp: {
498
- email: (loginId: string, user?: {
508
+ sms: (loginId: string, user?: {
499
509
  email?: string;
500
510
  name?: string;
501
511
  phone?: string;
502
512
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
503
- maskedEmail: string;
513
+ maskedPhone: string;
504
514
  }>>;
505
- sms: (loginId: string, user?: {
515
+ whatsapp: (loginId: string, user?: {
506
516
  email?: string;
507
517
  name?: string;
508
518
  phone?: string;
509
519
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
510
520
  maskedPhone: string;
511
521
  }>>;
512
- whatsapp: (loginId: string, user?: {
522
+ email: (loginId: string, user?: {
513
523
  email?: string;
514
524
  name?: string;
515
525
  phone?: string;
516
526
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
517
- maskedPhone: string;
527
+ maskedEmail: string;
518
528
  }>>;
519
529
  };
520
530
  signUpOrIn: {
521
- email: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
522
- maskedEmail: string;
523
- }>>;
524
531
  sms: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
525
532
  maskedPhone: string;
526
533
  }>>;
527
534
  whatsapp: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
528
535
  maskedPhone: string;
529
536
  }>>;
537
+ email: (loginId: string) => Promise<_descope_core_js_sdk.SdkResponse<{
538
+ maskedEmail: string;
539
+ }>>;
530
540
  };
531
541
  update: {
532
- email: (loginId: string, email: string, token?: string) => Promise<_descope_core_js_sdk.SdkResponse<{
542
+ email: <T_5 extends boolean>(loginId: string, email: string, token?: string, updateOptions?: {
543
+ addToLoginIDs?: T_5;
544
+ onMergeUseExisting?: T_5 extends true ? boolean : never;
545
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
533
546
  maskedEmail: string;
534
547
  }>>;
535
548
  phone: {
536
- email: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
549
+ sms: <T_1_2 extends boolean>(loginId: string, phone: string, token?: string, updateOptions?: {
550
+ addToLoginIDs?: T_1_2;
551
+ onMergeUseExisting?: T_1_2 extends true ? boolean : never;
552
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
537
553
  maskedPhone: string;
538
554
  }>>;
539
- sms: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
540
- maskedPhone: string;
541
- }>>;
542
- whatsapp: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
555
+ whatsapp: <T_1_3 extends boolean>(loginId: string, phone: string, token?: string, updateOptions?: {
556
+ addToLoginIDs?: T_1_3;
557
+ onMergeUseExisting?: T_1_3 extends true ? boolean : never;
558
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
543
559
  maskedPhone: string;
544
560
  }>>;
545
561
  };
@@ -548,60 +564,68 @@ declare const createSdkWrapper: <P extends Omit<{
548
564
  magicLink: {
549
565
  verify: (token: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
550
566
  signIn: {
551
- email: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
552
- maskedEmail: string;
553
- }>>;
554
567
  sms: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
555
568
  maskedPhone: string;
556
569
  }>>;
557
570
  whatsapp: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
558
571
  maskedPhone: string;
559
572
  }>>;
573
+ email: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
574
+ maskedEmail: string;
575
+ }>>;
560
576
  };
561
577
  signUp: {
562
- email: (loginId: string, uri: string, user?: {
578
+ sms: (loginId: string, uri: string, user?: {
563
579
  email?: string;
564
580
  name?: string;
565
581
  phone?: string;
566
582
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
567
- maskedEmail: string;
583
+ maskedPhone: string;
568
584
  }>>;
569
- sms: (loginId: string, uri: string, user?: {
585
+ whatsapp: (loginId: string, uri: string, user?: {
570
586
  email?: string;
571
587
  name?: string;
572
588
  phone?: string;
573
589
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
574
590
  maskedPhone: string;
575
591
  }>>;
576
- whatsapp: (loginId: string, uri: string, user?: {
592
+ email: (loginId: string, uri: string, user?: {
577
593
  email?: string;
578
594
  name?: string;
579
595
  phone?: string;
580
596
  }) => Promise<_descope_core_js_sdk.SdkResponse<{
581
- maskedPhone: string;
597
+ maskedEmail: string;
582
598
  }>>;
583
599
  };
584
600
  signUpOrIn: {
585
- email: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
586
- maskedEmail: string;
587
- }>>;
588
601
  sms: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
589
602
  maskedPhone: string;
590
603
  }>>;
591
604
  whatsapp: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
592
605
  maskedPhone: string;
593
606
  }>>;
607
+ email: (loginId: string, uri: string) => Promise<_descope_core_js_sdk.SdkResponse<{
608
+ maskedEmail: string;
609
+ }>>;
594
610
  };
595
611
  update: {
596
- email: (loginId: string, email: string, URI?: string, token?: string) => Promise<_descope_core_js_sdk.SdkResponse<never>>;
612
+ email: <T_2_1 extends boolean>(loginId: string, email: string, URI?: string, token?: string, updateOptions?: {
613
+ addToLoginIDs?: T_2_1;
614
+ onMergeUseExisting?: T_2_1 extends true ? boolean : never;
615
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
616
+ maskedEmail: string;
617
+ }>>;
597
618
  phone: {
598
- email: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
599
- maskedPhone: string;
600
- }>>;
601
- sms: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
619
+ sms: <T_3_2 extends boolean>(loginId: string, phone: string, URI?: string, token?: string, updateOptions?: {
620
+ addToLoginIDs?: T_3_2;
621
+ onMergeUseExisting?: T_3_2 extends true ? boolean : never;
622
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
602
623
  maskedPhone: string;
603
624
  }>>;
604
- whatsapp: (loginId: string, phone: string) => Promise<_descope_core_js_sdk.SdkResponse<{
625
+ whatsapp: <T_3_3 extends boolean>(loginId: string, phone: string, URI?: string, token?: string, updateOptions?: {
626
+ addToLoginIDs?: T_3_3;
627
+ onMergeUseExisting?: T_3_3 extends true ? boolean : never;
628
+ }) => Promise<_descope_core_js_sdk.SdkResponse<{
605
629
  maskedPhone: string;
606
630
  }>>;
607
631
  };
@@ -621,60 +645,47 @@ declare const createSdkWrapper: <P extends Omit<{
621
645
  timeoutMs: number;
622
646
  }) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
623
647
  update: {
624
- email: (loginId: string, email: string, URI?: string, token?: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.EnchantedLinkResponse>>;
648
+ email: <T_4_1 extends boolean>(loginId: string, email: string, URI?: string, token?: string, updateOptions?: {
649
+ addToLoginIDs?: T_4_1;
650
+ onMergeUseExisting?: T_4_1 extends true ? boolean : never;
651
+ }) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.EnchantedLinkResponse>>;
625
652
  };
626
653
  };
627
654
  oauth: {
628
655
  start: {
629
656
  facebook: <B_8 extends {
630
657
  redirect: boolean;
631
- }>(redirectURL?: string, config?: B_8) => Promise<B_8 extends {
632
- redirect: true;
633
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
634
- github: <B_1_2 extends {
658
+ }>(redirectURL?: string, config?: B_8) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
659
+ github: <B_1_1 extends {
635
660
  redirect: boolean;
636
- }>(redirectURL?: string, config?: B_1_2) => Promise<B_1_2 extends {
637
- redirect: true;
638
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
661
+ }>(redirectURL?: string, config?: B_1_1) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
639
662
  google: <B_2_1 extends {
640
663
  redirect: boolean;
641
- }>(redirectURL?: string, config?: B_2_1) => Promise<B_2_1 extends {
642
- redirect: true;
643
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
664
+ }>(redirectURL?: string, config?: B_2_1) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
644
665
  microsoft: <B_3_1 extends {
645
666
  redirect: boolean;
646
- }>(redirectURL?: string, config?: B_3_1) => Promise<B_3_1 extends {
647
- redirect: true;
648
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
667
+ }>(redirectURL?: string, config?: B_3_1) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
649
668
  gitlab: <B_4_1 extends {
650
669
  redirect: boolean;
651
- }>(redirectURL?: string, config?: B_4_1) => Promise<B_4_1 extends {
652
- redirect: true;
653
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
670
+ }>(redirectURL?: string, config?: B_4_1) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
654
671
  apple: <B_5_1 extends {
655
672
  redirect: boolean;
656
- }>(redirectURL?: string, config?: B_5_1) => Promise<B_5_1 extends {
657
- redirect: true;
658
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
673
+ }>(redirectURL?: string, config?: B_5_1) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
659
674
  discord: <B_6_1 extends {
660
675
  redirect: boolean;
661
- }>(redirectURL?: string, config?: B_6_1) => Promise<B_6_1 extends {
662
- redirect: true;
663
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
676
+ }>(redirectURL?: string, config?: B_6_1) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
664
677
  linkedin: <B_7_1 extends {
665
678
  redirect: boolean;
666
- }>(redirectURL?: string, config?: B_7_1) => Promise<B_7_1 extends {
667
- redirect: true;
668
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
679
+ }>(redirectURL?: string, config?: B_7_1) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
669
680
  };
670
681
  exchange: (code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
671
682
  };
672
683
  saml: {
673
- start: <B_1_3 extends {
674
- redirect: boolean;
675
- }>(tenantNameOrEmail: string, config?: B_1_3) => Promise<B_1_3 extends {
676
- redirect: true;
677
- } ? undefined : _descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
684
+ start: (tenantIdOrEmail: string, redirectUrl?: string, loginOptions?: {
685
+ stepup?: boolean;
686
+ mfa?: boolean;
687
+ customClaims?: Record<string, any>;
688
+ }, token?: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.URLResponse>>;
678
689
  exchange: (code: string) => Promise<_descope_core_js_sdk.SdkResponse<_descope_core_js_sdk.JWTResponse>>;
679
690
  };
680
691
  totp: {
@@ -742,7 +753,7 @@ declare const createSdkWrapper: <P extends Omit<{
742
753
  };
743
754
  token?: string;
744
755
  }) => Promise<Response>;
745
- delete: (path: string, body?: any, config?: {
756
+ delete: (path: string, config?: {
746
757
  headers?: HeadersInit;
747
758
  queryParams?: {
748
759
  [key: string]: string;
@@ -799,9 +810,9 @@ interface DescopeProps {
799
810
  }
800
811
  type DefaultFlowProps = Omit<DescopeProps, 'flowId'>;
801
812
 
802
- declare const SignInFlow: (props: DefaultFlowProps) => JSX.Element;
803
- declare const SignUpFlow: (props: DefaultFlowProps) => JSX.Element;
804
- declare const SignUpOrInFlow: (props: DefaultFlowProps) => JSX.Element;
813
+ declare const SignInFlow: (props: DefaultFlowProps) => React.JSX.Element;
814
+ declare const SignUpFlow: (props: DefaultFlowProps) => React.JSX.Element;
815
+ declare const SignUpOrInFlow: (props: DefaultFlowProps) => React.JSX.Element;
805
816
 
806
817
  declare const Descope: React.ForwardRefExoticComponent<DescopeProps & React.RefAttributes<HTMLElement>>;
807
818
 
package/dist/index.esm.js CHANGED
@@ -1,2 +1,2 @@
1
- import e,{useMemo as t,useState as r,useEffect as o,useCallback as s,lazy as n,useImperativeHandle as i,Suspense as c,useContext as a,useRef as d}from"react";import u from"@descope/web-js-sdk";const l=e.createContext(void 0),f=e=>(...t)=>{if(!e)throw Error("You can only use this function after sdk initialization. Make sure to supply 'projectId' to <AuthProvider /> component");return e(...t)},p=e=>(...t)=>{let r;try{r=e(...t)}catch(e){console.error(e)}return r},h={"x-descope-sdk-name":"react","x-descope-sdk-version":"1.0.3"},m="undefined"!=typeof window;let k;const w=e=>{const t=u({...e,persistTokens:m,autoRefresh:m});return k=t,t};k=w({projectId:"temp pid"});const y=()=>m?k?.getSessionToken():(console.warn("Get session token is not supported in SSR"),""),g=()=>m?k?.getRefreshToken():(console.warn("Get refresh token is not supported in SSR"),""),b=p(((e=y(),t)=>k?.getJwtPermissions(e,t))),U=p(((e=y(),t)=>k?.getJwtRoles(e,t))),v=(e=g())=>k?.refresh(e);const E=({projectId:n,baseUrl:i,sessionTokenViaCookie:c,children:a})=>{const[d,u]=r(),[p,m]=r(),[k,y]=r(!1),[g,b]=r(!1),U=(({projectId:e,baseUrl:r,sessionTokenViaCookie:o})=>t((()=>{if(e)return w({projectId:e,baseUrl:r,sessionTokenViaCookie:o,baseHeaders:h,persistToken:!0,autoRefresh:!0})}),[e,r,o]))({projectId:n,baseUrl:i,sessionTokenViaCookie:c});o((()=>{if(U){const e=U.onSessionTokenChange(m),t=U.onUserChange(u);return()=>{e(),t()}}}),[U]);const v=s((()=>{b(!0),f(U?.refresh)().then((()=>{b(!1)}))}),[U]),E=s((()=>{y(!0),f(U.me)().then((()=>{y(!1)}))}),[U]),I=t((()=>({fetchUser:E,user:d,isUserLoading:k,fetchSession:v,session:p,isSessionLoading:g,projectId:n,baseUrl:i,setUser:u,setSession:m,sdk:U})),[E,d,k,v,p,g,n,i,u,m,U]);return e.createElement(l.Provider,{value:I},a)};E.defaultProps={baseUrl:"",children:void 0,sessionTokenViaCookie:!1};const I=n((async()=>((await import("@descope/web-component")).default.sdkConfigOverrides={baseHeaders:h},{default:({projectId:t,flowId:r,baseUrl:o,innerRef:s,tenant:n,theme:i,debug:c,telemetryKey:a,redirectUrl:d,autoFocus:u})=>e.createElement("descope-wc",{"project-id":t,"flow-id":r,"base-url":o,ref:s,tenant:n,theme:i,debug:c,telemetryKey:a,"redirect-url":d,"auto-focus":u})}))),j=e.forwardRef((({flowId:t,onSuccess:n,onError:a,tenant:d,theme:u,debug:f,telemetryKey:p,redirectUrl:h,autoFocus:m},k)=>{const[w,y]=r(null);i(k,(()=>w));const{projectId:g,baseUrl:b,sdk:U}=e.useContext(l),v=s((async e=>{await U.httpClient.hooks.afterRequest({},new Response(JSON.stringify(e.detail))),n&&n(e)}),[n]);return o((()=>{const e=w;return e?.addEventListener("success",v),a&&e?.addEventListener("error",a),()=>{a&&e?.removeEventListener("error",a),e?.removeEventListener("success",v)}}),[w,a,v]),e.createElement("form",null,e.createElement(c,{fallback:null},e.createElement(I,{projectId:g,flowId:t,baseUrl:b,innerRef:y,tenant:d,theme:u,debug:f,telemetryKey:p,redirectUrl:h,autoFocus:m})))}));j.defaultProps={onError:void 0,onSuccess:void 0};const S=t=>e.createElement(j,{...t,flowId:"sign-in"}),C=t=>e.createElement(j,{...t,flowId:"sign-up"}),R=t=>e.createElement(j,{...t,flowId:"sign-up-or-in"});var T=()=>{const e=a(l);if(!e)throw Error("You can only use this hook in the context of <AuthProvider />");return e};const L=e=>`You can only use this ${e} after sdk initialization. Make sure to supply 'projectId' to <AuthProvider /> component`,x={get(e,t){if("object"==typeof e[t]&&null!==e[t])return new Proxy(e[t],x);if("function"==typeof e[t])return()=>{throw Error(L("function"))};throw Error(L("attribute"))}},P=()=>{const{sdk:e}=T();return t((()=>e||new Proxy(w({projectId:"dummy"}),x)),[e])},V=()=>{const{session:e,isSessionLoading:r,fetchSession:s}=T(),n=d(r);return t((()=>{n.current=r}),[r]),t((()=>{e||r||(n.current=!0)}),[s]),o((()=>{e||r||s()}),[s]),{isSessionLoading:n.current,sessionToken:e,isAuthenticated:!!e}},A=()=>{const{user:e,fetchUser:s,isUserLoading:n,session:i}=T(),[c,a]=r(!1),u=d(n),l=t((()=>!e&&!n&&i&&!c),[s,i,c]);return t((()=>{u.current=n}),[n]),t((()=>{l&&(u.current=!0)}),[l]),o((()=>{l&&(a(!0),s())}),[l]),{isUserLoading:u.current,user:e}};export{E as AuthProvider,j as Descope,S as SignInFlow,C as SignUpFlow,R as SignUpOrInFlow,b as getJwtPermissions,U as getJwtRoles,g as getRefreshToken,y as getSessionToken,v as refresh,P as useDescope,V as useSession,A as useUser};
1
+ import e,{useMemo as t,useState as r,useEffect as o,useRef as s,useCallback as n,lazy as i,useImperativeHandle as c,Suspense as a,useContext as u}from"react";import d from"@descope/web-js-sdk";const l=e.createContext(void 0),f=e=>(...t)=>{if(!e)throw Error("You can only use this function after sdk initialization. Make sure to supply 'projectId' to <AuthProvider /> component");return e(...t)},p=e=>(...t)=>{let r;try{r=e(...t)}catch(e){console.error(e)}return r},h={"x-descope-sdk-name":"react","x-descope-sdk-version":"1.0.5"},m="undefined"!=typeof window;let k;const w=e=>{const t=d({...e,persistTokens:m,autoRefresh:m});return k=t,t};k=w({projectId:"temp pid"});const y=()=>m?k?.getSessionToken():(console.warn("Get session token is not supported in SSR"),""),g=()=>m?k?.getRefreshToken():(console.warn("Get refresh token is not supported in SSR"),""),b=p(((e=y(),t)=>k?.getJwtPermissions(e,t))),U=p(((e=y(),t)=>k?.getJwtRoles(e,t))),v=(e=g())=>k?.refresh(e);const E=({projectId:i,baseUrl:c,sessionTokenViaCookie:a,children:u})=>{const[d,p]=r(),[m,k]=r(),[y,g]=r(!1),[b,U]=r(!1),v=(({projectId:e,baseUrl:r,sessionTokenViaCookie:o})=>t((()=>{if(e)return w({projectId:e,baseUrl:r,sessionTokenViaCookie:o,baseHeaders:h,persistToken:!0,autoRefresh:!0})}),[e,r,o]))({projectId:i,baseUrl:c,sessionTokenViaCookie:a});o((()=>{if(v){const e=v.onSessionTokenChange(k),t=v.onUserChange(p);return()=>{e(),t()}}}),[v]);const E=s(!1),I=n((()=>{E.current||(E.current=!0,U(!0),f(v?.refresh)().then((()=>{U(!1)})))}),[v]),j=n((()=>{g(!0),f(v.me)().then((()=>{g(!1)}))}),[v]),S=t((()=>({fetchUser:j,user:d,isUserLoading:y,fetchSession:I,session:m,isSessionLoading:b,projectId:i,baseUrl:c,setUser:p,setSession:k,sdk:v})),[j,d,y,I,m,b,i,c,p,k,v]);return e.createElement(l.Provider,{value:S},u)};E.defaultProps={baseUrl:"",children:void 0,sessionTokenViaCookie:!1};const I=i((async()=>((await import("@descope/web-component")).default.sdkConfigOverrides={baseHeaders:h},{default:({projectId:t,flowId:r,baseUrl:o,innerRef:s,tenant:n,theme:i,debug:c,telemetryKey:a,redirectUrl:u,autoFocus:d})=>e.createElement("descope-wc",{"project-id":t,"flow-id":r,"base-url":o,ref:s,tenant:n,theme:i,debug:c,telemetryKey:a,"redirect-url":u,"auto-focus":d})}))),j=e.forwardRef((({flowId:t,onSuccess:s,onError:i,tenant:u,theme:d,debug:f,telemetryKey:p,redirectUrl:h,autoFocus:m},k)=>{const[w,y]=r(null);c(k,(()=>w));const{projectId:g,baseUrl:b,sdk:U}=e.useContext(l),v=n((async e=>{await U.httpClient.hooks.afterRequest({},new Response(JSON.stringify(e.detail))),s&&s(e)}),[s]);return o((()=>{const e=w;return e?.addEventListener("success",v),i&&e?.addEventListener("error",i),()=>{i&&e?.removeEventListener("error",i),e?.removeEventListener("success",v)}}),[w,i,v]),e.createElement("form",null,e.createElement(a,{fallback:null},e.createElement(I,{projectId:g,flowId:t,baseUrl:b,innerRef:y,tenant:u,theme:d,debug:f,telemetryKey:p,redirectUrl:h,autoFocus:m})))}));j.defaultProps={onError:void 0,onSuccess:void 0};const S=t=>e.createElement(j,{...t,flowId:"sign-in"}),C=t=>e.createElement(j,{...t,flowId:"sign-up"}),R=t=>e.createElement(j,{...t,flowId:"sign-up-or-in"});var T=()=>{const e=u(l);if(!e)throw Error("You can only use this hook in the context of <AuthProvider />");return e};const L=e=>`You can only use this ${e} after sdk initialization. Make sure to supply 'projectId' to <AuthProvider /> component`,x={get(e,t){if("object"==typeof e[t]&&null!==e[t])return new Proxy(e[t],x);if("function"==typeof e[t])return()=>{throw Error(L("function"))};throw Error(L("attribute"))}},P=()=>{const{sdk:e}=T();return t((()=>e||new Proxy(w({projectId:"dummy"}),x)),[e])},V=()=>{const{session:e,isSessionLoading:r,fetchSession:n}=T(),i=s(r);return t((()=>{i.current=r}),[r]),t((()=>{e||r||(i.current=!0)}),[n]),o((()=>{e||r||n()}),[n]),{isSessionLoading:i.current,sessionToken:e,isAuthenticated:!!e}},A=()=>{const{user:e,fetchUser:n,isUserLoading:i,session:c}=T(),[a,u]=r(!1),d=s(i),l=t((()=>!e&&!i&&c&&!a),[n,c,a]);return t((()=>{d.current=i}),[i]),t((()=>{l&&(d.current=!0)}),[l]),o((()=>{l&&(u(!0),n())}),[l]),{isUserLoading:d.current,user:e}};export{E as AuthProvider,j as Descope,S as SignInFlow,C as SignUpFlow,R as SignUpOrInFlow,b as getJwtPermissions,U as getJwtRoles,g as getRefreshToken,y as getSessionToken,v as refresh,P as useDescope,V as useSession,A as useUser};
2
2
  //# sourceMappingURL=index.esm.js.map