@workos-inc/node 3.0.0-user-management.2 → 3.0.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 (217) hide show
  1. package/lib/audit-logs/audit-logs.js +5 -4
  2. package/lib/audit-logs/audit-logs.spec.js +87 -87
  3. package/lib/audit-logs/interfaces/audit-log-export-options.interface.d.ts +13 -3
  4. package/lib/audit-logs/interfaces/audit-log-export.interface.d.ts +8 -0
  5. package/lib/audit-logs/interfaces/create-audit-log-event-options.interface.d.ts +13 -1
  6. package/lib/audit-logs/serializers/audit-log-export-options.serializer.d.ts +2 -0
  7. package/lib/audit-logs/serializers/audit-log-export-options.serializer.js +14 -0
  8. package/lib/audit-logs/serializers/audit-log-export.serializer.d.ts +2 -0
  9. package/lib/audit-logs/serializers/audit-log-export.serializer.js +12 -0
  10. package/lib/audit-logs/serializers/create-audit-log-event-options.serializer.d.ts +2 -0
  11. package/lib/audit-logs/serializers/create-audit-log-event-options.serializer.js +16 -0
  12. package/lib/audit-logs/serializers/index.d.ts +3 -0
  13. package/lib/audit-logs/serializers/index.js +19 -0
  14. package/lib/audit-trail/audit-trail.d.ts +2 -2
  15. package/lib/audit-trail/audit-trail.spec.js +2 -1
  16. package/lib/common/interfaces/at-least-one-property-of.interface.d.ts +7 -0
  17. package/lib/common/interfaces/event.interface.d.ts +142 -0
  18. package/lib/common/interfaces/index.d.ts +5 -0
  19. package/lib/common/interfaces/index.js +5 -0
  20. package/lib/common/interfaces/list.interface.d.ts +9 -1
  21. package/lib/common/interfaces/workos-response-error.interface.d.ts +8 -0
  22. package/lib/common/serializers/event.serializer.d.ts +2 -0
  23. package/lib/common/serializers/event.serializer.js +40 -0
  24. package/lib/common/serializers/index.d.ts +2 -0
  25. package/lib/common/serializers/index.js +18 -0
  26. package/lib/common/serializers/list.serializer.d.ts +2 -0
  27. package/lib/common/serializers/list.serializer.js +9 -0
  28. package/lib/common/utils/fetch-and-deserialize.d.ts +3 -0
  29. package/lib/common/utils/fetch-and-deserialize.js +23 -0
  30. package/lib/common/utils/pagination.d.ts +15 -0
  31. package/lib/common/utils/pagination.js +90 -0
  32. package/lib/common/utils/workos-mock-response.d.ts +7 -0
  33. package/lib/common/utils/workos-mock-response.js +11 -0
  34. package/lib/directory-sync/directory-sync.d.ts +8 -12
  35. package/lib/directory-sync/directory-sync.js +9 -15
  36. package/lib/directory-sync/directory-sync.spec.js +132 -20
  37. package/lib/directory-sync/interfaces/directory-group.interface.d.ts +40 -0
  38. package/lib/directory-sync/interfaces/directory-user.interface.d.ts +50 -0
  39. package/lib/directory-sync/interfaces/directory.interface.d.ts +47 -2
  40. package/lib/directory-sync/interfaces/index.d.ts +6 -6
  41. package/lib/directory-sync/interfaces/index.js +20 -0
  42. package/lib/directory-sync/interfaces/list-directories-options.interface.d.ts +1 -1
  43. package/lib/directory-sync/interfaces/{list-users-options.interface.d.ts → list-directory-users-options.interface.d.ts} +1 -1
  44. package/lib/directory-sync/interfaces/list-groups-options.interface.d.ts +1 -1
  45. package/lib/directory-sync/serializers/directory-group.serializer.d.ts +4 -0
  46. package/lib/directory-sync/serializers/directory-group.serializer.js +37 -0
  47. package/lib/directory-sync/serializers/directory-user.serializer.d.ts +4 -0
  48. package/lib/directory-sync/serializers/directory-user.serializer.js +43 -0
  49. package/lib/directory-sync/serializers/directory.serializer.d.ts +5 -0
  50. package/lib/directory-sync/serializers/directory.serializer.js +50 -0
  51. package/lib/directory-sync/serializers/index.d.ts +3 -0
  52. package/lib/directory-sync/serializers/index.js +19 -0
  53. package/lib/directory-sync/utils/get-primary-email.d.ts +2 -2
  54. package/lib/directory-sync/utils/get-primary-email.spec.js +11 -8
  55. package/lib/events/events.d.ts +1 -2
  56. package/lib/events/events.js +2 -1
  57. package/lib/events/events.spec.js +39 -5
  58. package/lib/events/interfaces/index.d.ts +0 -1
  59. package/lib/events/interfaces/index.js +0 -1
  60. package/lib/events/interfaces/list-events-options.interface.d.ts +4 -4
  61. package/lib/index.d.ts +1 -1
  62. package/lib/index.js +1 -1
  63. package/lib/mfa/interfaces/challenge.interface.d.ts +9 -0
  64. package/lib/mfa/interfaces/factor.interface.d.ts +13 -4
  65. package/lib/mfa/interfaces/index.d.ts +9 -0
  66. package/lib/mfa/interfaces/index.js +25 -0
  67. package/lib/mfa/interfaces/sms.interface.d.ts +3 -0
  68. package/lib/mfa/interfaces/totp.interface.d.ts +7 -0
  69. package/lib/mfa/interfaces/verify-challenge-response.d.ts +5 -1
  70. package/lib/mfa/mfa.d.ts +2 -8
  71. package/lib/mfa/mfa.js +5 -4
  72. package/lib/mfa/mfa.spec.js +134 -115
  73. package/lib/mfa/serializers/challenge.serializer.d.ts +2 -0
  74. package/lib/mfa/serializers/challenge.serializer.js +13 -0
  75. package/lib/mfa/serializers/factor.serializer.d.ts +2 -0
  76. package/lib/mfa/serializers/factor.serializer.js +7 -0
  77. package/lib/mfa/serializers/index.d.ts +3 -0
  78. package/lib/{webhooks/interfaces → mfa/serializers}/index.js +3 -4
  79. package/lib/mfa/serializers/sms.serializer.d.ts +2 -0
  80. package/lib/mfa/serializers/sms.serializer.js +7 -0
  81. package/lib/mfa/serializers/totp.serializer.d.ts +2 -0
  82. package/lib/mfa/serializers/totp.serializer.js +11 -0
  83. package/lib/mfa/serializers/verify-response.serializer.d.ts +2 -0
  84. package/lib/mfa/serializers/verify-response.serializer.js +9 -0
  85. package/lib/organizations/interfaces/create-organization-options.interface.d.ts +5 -0
  86. package/lib/organizations/interfaces/organization.interface.d.ts +9 -0
  87. package/lib/organizations/interfaces/update-organization-options.interface.d.ts +5 -0
  88. package/lib/organizations/organizations.d.ts +2 -2
  89. package/lib/organizations/organizations.js +9 -9
  90. package/lib/organizations/organizations.spec.js +11 -4
  91. package/lib/organizations/serializers/create-organization-options.serializer.d.ts +2 -0
  92. package/lib/organizations/serializers/create-organization-options.serializer.js +9 -0
  93. package/lib/organizations/serializers/index.d.ts +3 -0
  94. package/lib/organizations/serializers/index.js +19 -0
  95. package/lib/organizations/serializers/organization.serializer.d.ts +2 -0
  96. package/lib/organizations/serializers/organization.serializer.js +13 -0
  97. package/lib/organizations/serializers/update-organization-options.serializer.d.ts +2 -0
  98. package/lib/organizations/serializers/update-organization-options.serializer.js +9 -0
  99. package/lib/passwordless/interfaces/create-passwordless-session-options.interface.d.ts +8 -0
  100. package/lib/passwordless/interfaces/index.d.ts +3 -3
  101. package/lib/passwordless/interfaces/index.js +17 -0
  102. package/lib/passwordless/interfaces/passwordless-session.interface.d.ts +7 -0
  103. package/lib/passwordless/passwordless.d.ts +1 -3
  104. package/lib/passwordless/passwordless.js +2 -1
  105. package/lib/passwordless/serializers/index.d.ts +0 -0
  106. package/lib/passwordless/serializers/index.js +1 -0
  107. package/lib/passwordless/serializers/passwordless-session.serializer.d.ts +2 -0
  108. package/lib/passwordless/serializers/passwordless-session.serializer.js +11 -0
  109. package/lib/portal/interfaces/generate-portal-link-intent.interface.js +1 -1
  110. package/lib/sso/interfaces/connection-type.enum.d.ts +1 -0
  111. package/lib/sso/interfaces/connection-type.enum.js +2 -1
  112. package/lib/sso/interfaces/connection.interface.d.ts +16 -5
  113. package/lib/sso/interfaces/index.d.ts +2 -0
  114. package/lib/sso/interfaces/index.js +2 -0
  115. package/lib/sso/interfaces/list-connections-options.interface.d.ts +5 -0
  116. package/lib/sso/interfaces/profile-and-token.interface.d.ts +6 -2
  117. package/lib/sso/interfaces/profile.interface.d.ts +14 -0
  118. package/lib/sso/serializers/connection.serializer.d.ts +2 -0
  119. package/lib/sso/serializers/connection.serializer.js +16 -0
  120. package/lib/sso/serializers/index.d.ts +3 -0
  121. package/lib/sso/serializers/index.js +19 -0
  122. package/lib/sso/serializers/profile-and-token.serializer.d.ts +2 -0
  123. package/lib/sso/serializers/profile-and-token.serializer.js +9 -0
  124. package/lib/sso/serializers/profile.serializer.d.ts +2 -0
  125. package/lib/sso/serializers/profile.serializer.js +16 -0
  126. package/lib/sso/sso.d.ts +3 -9
  127. package/lib/sso/sso.js +23 -16
  128. package/lib/sso/sso.spec.js +26 -9
  129. package/lib/users/exceptions/index.d.ts +4 -0
  130. package/lib/users/exceptions/index.js +10 -0
  131. package/lib/users/fixtures/list-users.json +0 -1
  132. package/lib/users/fixtures/session.json +2 -0
  133. package/lib/users/fixtures/user.json +0 -1
  134. package/lib/users/interfaces/add-user-to-organization-options.interface.d.ts +4 -1
  135. package/lib/users/interfaces/authenticate-user-with-magic-auth-options.interface.d.ts +21 -0
  136. package/lib/users/interfaces/authenticate-user-with-password-options.interface.d.ts +14 -1
  137. package/lib/users/interfaces/authenticate-user-with-token-options.interface.d.ts +10 -1
  138. package/lib/users/interfaces/authentication-response.interface.d.ts +7 -3
  139. package/lib/users/interfaces/complete-password-reset-options.interface.d.ts +4 -0
  140. package/lib/users/interfaces/create-email-verification-challenge-options.interface.d.ts +9 -2
  141. package/lib/users/interfaces/create-password-reset-challenge-options.interface.d.ts +9 -1
  142. package/lib/users/interfaces/create-user-options.interface.d.ts +8 -1
  143. package/lib/users/interfaces/index.d.ts +7 -0
  144. package/lib/users/interfaces/index.js +7 -0
  145. package/lib/users/interfaces/magic-auth-challenge.interface.d.ts +3 -0
  146. package/lib/users/interfaces/remove-user-from-organization-options.interface.d.ts +2 -2
  147. package/lib/users/interfaces/revoke-all-sessions-for-user-options.interface.d.ts +3 -0
  148. package/lib/users/interfaces/revoke-all-sessions-for-user-options.interface.js +2 -0
  149. package/lib/users/interfaces/revoke-session-options.interface.d.ts +7 -0
  150. package/lib/users/interfaces/send-magic-auth-code-options.interface.d.ts +6 -0
  151. package/lib/users/interfaces/send-magic-auth-code-options.interface.js +2 -0
  152. package/lib/users/interfaces/session.interface.d.ts +35 -0
  153. package/lib/users/interfaces/update-user-options.interface.d.ts +14 -0
  154. package/lib/users/interfaces/update-user-options.interface.js +2 -0
  155. package/lib/users/interfaces/update-user-password-options.interface.d.ts +7 -0
  156. package/lib/users/interfaces/update-user-password-options.interface.js +2 -0
  157. package/lib/users/interfaces/user.interface.d.ts +28 -18
  158. package/lib/users/interfaces/verify-session.interface.d.ts +10 -2
  159. package/lib/users/serializers/authenticate-user-with-magic-auth-options.serializer.d.ts +2 -0
  160. package/lib/users/serializers/authenticate-user-with-magic-auth-options.serializer.js +14 -0
  161. package/lib/users/serializers/authenticate-user-with-password-options.serializer.d.ts +2 -0
  162. package/lib/users/serializers/authenticate-user-with-password-options.serializer.js +14 -0
  163. package/lib/users/serializers/authenticate-user-with-token-options.serializer.d.ts +2 -0
  164. package/lib/users/serializers/authenticate-user-with-token-options.serializer.js +11 -0
  165. package/lib/users/serializers/authentication-response.serializer.d.ts +2 -0
  166. package/lib/users/serializers/authentication-response.serializer.js +10 -0
  167. package/lib/users/serializers/complete-password-reset-options.serializer.d.ts +2 -0
  168. package/lib/users/serializers/complete-password-reset-options.serializer.js +8 -0
  169. package/lib/users/serializers/create-email-verification-challenge.serializer.d.ts +2 -0
  170. package/lib/users/serializers/create-email-verification-challenge.serializer.js +9 -0
  171. package/lib/users/serializers/create-password-reset-challenge.serializer.d.ts +3 -0
  172. package/lib/users/serializers/create-password-reset-challenge.serializer.js +14 -0
  173. package/lib/users/serializers/create-user-options.serializer.d.ts +2 -0
  174. package/lib/users/serializers/create-user-options.serializer.js +11 -0
  175. package/lib/users/serializers/index.d.ts +15 -0
  176. package/lib/users/serializers/index.js +31 -0
  177. package/lib/users/serializers/revoke-session-options.serializer.d.ts +2 -0
  178. package/lib/users/serializers/revoke-session-options.serializer.js +14 -0
  179. package/lib/users/serializers/send-magic-auth-code-options.serializer.d.ts +2 -0
  180. package/lib/users/serializers/send-magic-auth-code-options.serializer.js +7 -0
  181. package/lib/users/serializers/session.serializer.d.ts +4 -0
  182. package/lib/users/serializers/session.serializer.js +22 -0
  183. package/lib/users/serializers/update-user-options.serializer.d.ts +2 -0
  184. package/lib/users/serializers/update-user-options.serializer.js +8 -0
  185. package/lib/users/serializers/update-user-password-options.serializer.d.ts +2 -0
  186. package/lib/users/serializers/update-user-password-options.serializer.js +7 -0
  187. package/lib/users/serializers/user.serializer.d.ts +2 -0
  188. package/lib/users/serializers/user.serializer.js +24 -0
  189. package/lib/users/serializers/verify-session.serializer.d.ts +3 -0
  190. package/lib/users/serializers/verify-session.serializer.js +15 -0
  191. package/lib/users/users.d.ts +11 -7
  192. package/lib/users/users.js +54 -30
  193. package/lib/users/users.spec.js +133 -49
  194. package/lib/webhooks/fixtures/webhook.json +67 -1
  195. package/lib/webhooks/webhooks.d.ts +2 -2
  196. package/lib/webhooks/webhooks.js +2 -1
  197. package/lib/webhooks/webhooks.spec.js +8 -6
  198. package/lib/workos.d.ts +5 -4
  199. package/lib/workos.js +4 -1
  200. package/lib/workos.spec.js +11 -1
  201. package/package.json +14 -15
  202. package/lib/directory-sync/interfaces/group.interface.d.ts +0 -10
  203. package/lib/directory-sync/interfaces/user.interface.d.ts +0 -23
  204. package/lib/events/interfaces/event.interface.d.ts +0 -63
  205. package/lib/webhooks/interfaces/index.d.ts +0 -4
  206. package/lib/webhooks/interfaces/webhook-directory-group.interface.d.ts +0 -10
  207. package/lib/webhooks/interfaces/webhook-directory-user.interface.d.ts +0 -5
  208. package/lib/webhooks/interfaces/webhook-directory.interface.d.ts +0 -20
  209. package/lib/webhooks/interfaces/webhook.interface.d.ts +0 -73
  210. /package/lib/{directory-sync/interfaces/group.interface.js → common/interfaces/at-least-one-property-of.interface.js} +0 -0
  211. /package/lib/{events → common}/interfaces/event.interface.js +0 -0
  212. /package/lib/{directory-sync/interfaces/list-users-options.interface.js → common/interfaces/workos-response-error.interface.js} +0 -0
  213. /package/lib/directory-sync/interfaces/{user.interface.js → directory-group.interface.js} +0 -0
  214. /package/lib/{webhooks/interfaces/webhook-directory-group.interface.js → directory-sync/interfaces/directory-user.interface.js} +0 -0
  215. /package/lib/{webhooks/interfaces/webhook-directory-user.interface.js → directory-sync/interfaces/list-directory-users-options.interface.js} +0 -0
  216. /package/lib/{webhooks/interfaces/webhook-directory.interface.js → users/interfaces/authenticate-user-with-magic-auth-options.interface.js} +0 -0
  217. /package/lib/{webhooks/interfaces/webhook.interface.js → users/interfaces/magic-auth-challenge.interface.js} +0 -0
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.deserializeCreateEmailVerificationChallengeResponse = void 0;
4
+ const user_serializer_1 = require("./user.serializer");
5
+ const deserializeCreateEmailVerificationChallengeResponse = (createEmailVerificationChallengeResponse) => ({
6
+ token: createEmailVerificationChallengeResponse.token,
7
+ user: (0, user_serializer_1.deserializeUser)(createEmailVerificationChallengeResponse.user),
8
+ });
9
+ exports.deserializeCreateEmailVerificationChallengeResponse = deserializeCreateEmailVerificationChallengeResponse;
@@ -0,0 +1,3 @@
1
+ import { CreatePasswordResetChallengeOptions, CreatePasswordResetChallengeResponse, CreatePasswordResetChallengeResponseResponse, SerializedCreatePasswordResetChallengeOptions } from '../interfaces';
2
+ export declare const deserializeCreatePasswordResetChallengeResponse: (createPasswordResetChallengeResponse: CreatePasswordResetChallengeResponseResponse) => CreatePasswordResetChallengeResponse;
3
+ export declare const serializeCreatePasswordResetChallengeOptions: (options: CreatePasswordResetChallengeOptions) => SerializedCreatePasswordResetChallengeOptions;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.serializeCreatePasswordResetChallengeOptions = exports.deserializeCreatePasswordResetChallengeResponse = void 0;
4
+ const user_serializer_1 = require("./user.serializer");
5
+ const deserializeCreatePasswordResetChallengeResponse = (createPasswordResetChallengeResponse) => ({
6
+ token: createPasswordResetChallengeResponse.token,
7
+ user: (0, user_serializer_1.deserializeUser)(createPasswordResetChallengeResponse.user),
8
+ });
9
+ exports.deserializeCreatePasswordResetChallengeResponse = deserializeCreatePasswordResetChallengeResponse;
10
+ const serializeCreatePasswordResetChallengeOptions = (options) => ({
11
+ email: options.email,
12
+ password_reset_url: options.passwordResetUrl,
13
+ });
14
+ exports.serializeCreatePasswordResetChallengeOptions = serializeCreatePasswordResetChallengeOptions;
@@ -0,0 +1,2 @@
1
+ import { CreateUserOptions, SerializedCreateUserOptions } from '../interfaces';
2
+ export declare const serializeCreateUserOptions: (options: CreateUserOptions) => SerializedCreateUserOptions;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.serializeCreateUserOptions = void 0;
4
+ const serializeCreateUserOptions = (options) => ({
5
+ email: options.email,
6
+ password: options.password,
7
+ first_name: options.firstName,
8
+ last_name: options.lastName,
9
+ email_verified: options.emailVerified,
10
+ });
11
+ exports.serializeCreateUserOptions = serializeCreateUserOptions;
@@ -0,0 +1,15 @@
1
+ export * from './authenticate-user-with-magic-auth-options.serializer';
2
+ export * from './authenticate-user-with-password-options.serializer';
3
+ export * from './authenticate-user-with-token-options.serializer';
4
+ export * from './authentication-response.serializer';
5
+ export * from './complete-password-reset-options.serializer';
6
+ export * from './create-email-verification-challenge.serializer';
7
+ export * from './create-password-reset-challenge.serializer';
8
+ export * from './create-user-options.serializer';
9
+ export * from './revoke-session-options.serializer';
10
+ export * from './send-magic-auth-code-options.serializer';
11
+ export * from './session.serializer';
12
+ export * from './update-user-password-options.serializer';
13
+ export * from './update-user-options.serializer';
14
+ export * from './user.serializer';
15
+ export * from './verify-session.serializer';
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./authenticate-user-with-magic-auth-options.serializer"), exports);
18
+ __exportStar(require("./authenticate-user-with-password-options.serializer"), exports);
19
+ __exportStar(require("./authenticate-user-with-token-options.serializer"), exports);
20
+ __exportStar(require("./authentication-response.serializer"), exports);
21
+ __exportStar(require("./complete-password-reset-options.serializer"), exports);
22
+ __exportStar(require("./create-email-verification-challenge.serializer"), exports);
23
+ __exportStar(require("./create-password-reset-challenge.serializer"), exports);
24
+ __exportStar(require("./create-user-options.serializer"), exports);
25
+ __exportStar(require("./revoke-session-options.serializer"), exports);
26
+ __exportStar(require("./send-magic-auth-code-options.serializer"), exports);
27
+ __exportStar(require("./session.serializer"), exports);
28
+ __exportStar(require("./update-user-password-options.serializer"), exports);
29
+ __exportStar(require("./update-user-options.serializer"), exports);
30
+ __exportStar(require("./user.serializer"), exports);
31
+ __exportStar(require("./verify-session.serializer"), exports);
@@ -0,0 +1,2 @@
1
+ import { RevokeSessionOptions, SerializedRevokeSessionOptions } from '../interfaces';
2
+ export declare const serializeRevokeSessionOptions: (options: RevokeSessionOptions) => SerializedRevokeSessionOptions;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.serializeRevokeSessionOptions = void 0;
4
+ const serializeRevokeSessionOptions = (options) => {
5
+ if ('sessionId' in options) {
6
+ return {
7
+ session_id: options.sessionId,
8
+ };
9
+ }
10
+ return {
11
+ session_token: options.sessionToken,
12
+ };
13
+ };
14
+ exports.serializeRevokeSessionOptions = serializeRevokeSessionOptions;
@@ -0,0 +1,2 @@
1
+ import { SendMagicAuthCodeOptions, SerializedSendMagicAuthCodeOptions } from '../interfaces';
2
+ export declare const serializeSendMagicAuthCodeOptions: (options: SendMagicAuthCodeOptions) => SerializedSendMagicAuthCodeOptions;
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.serializeSendMagicAuthCodeOptions = void 0;
4
+ const serializeSendMagicAuthCodeOptions = (options) => ({
5
+ email_address: options.emailAddress,
6
+ });
7
+ exports.serializeSendMagicAuthCodeOptions = serializeSendMagicAuthCodeOptions;
@@ -0,0 +1,4 @@
1
+ import { Session, SessionResponse, UnauthorizedOrganization, UnauthorizedOrganizationReason, UnauthorizedOrganizationReasonResponse, UnauthorizedOrganizationResponse } from '../interfaces/session.interface';
2
+ export declare const deserializeSession: (session: SessionResponse) => Session;
3
+ export declare const deserializeUnauthorizedOrganization: (unauthorizedOrganization: UnauthorizedOrganizationResponse) => UnauthorizedOrganization;
4
+ export declare const deserializeUnauthorizedOrganizationReason: (unauthorizedOrganizationReason: UnauthorizedOrganizationReasonResponse) => UnauthorizedOrganizationReason;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.deserializeUnauthorizedOrganizationReason = exports.deserializeUnauthorizedOrganization = exports.deserializeSession = void 0;
4
+ const deserializeSession = (session) => ({
5
+ id: session.id,
6
+ createdAt: session.created_at,
7
+ expiresAt: session.expires_at,
8
+ authorizedOrganizations: session.authorized_organizations,
9
+ unauthorizedOrganizations: session.unauthorized_organizations.map(exports.deserializeUnauthorizedOrganization),
10
+ token: session.token,
11
+ });
12
+ exports.deserializeSession = deserializeSession;
13
+ const deserializeUnauthorizedOrganization = (unauthorizedOrganization) => ({
14
+ organization: unauthorizedOrganization.organization,
15
+ reasons: unauthorizedOrganization.reasons.map(exports.deserializeUnauthorizedOrganizationReason),
16
+ });
17
+ exports.deserializeUnauthorizedOrganization = deserializeUnauthorizedOrganization;
18
+ const deserializeUnauthorizedOrganizationReason = (unauthorizedOrganizationReason) => ({
19
+ type: unauthorizedOrganizationReason.type,
20
+ allowedAuthenticationMethods: unauthorizedOrganizationReason.allowed_authentication_methods,
21
+ });
22
+ exports.deserializeUnauthorizedOrganizationReason = deserializeUnauthorizedOrganizationReason;
@@ -0,0 +1,2 @@
1
+ import { SerializedUpdateUserOptions, UpdateUserOptions } from '../interfaces';
2
+ export declare const serializeUpdateUserOptions: (options: UpdateUserOptions) => SerializedUpdateUserOptions;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.serializeUpdateUserOptions = void 0;
4
+ const serializeUpdateUserOptions = (options) => ({
5
+ first_name: options.firstName,
6
+ last_name: options.lastName,
7
+ });
8
+ exports.serializeUpdateUserOptions = serializeUpdateUserOptions;
@@ -0,0 +1,2 @@
1
+ import { SerializedUpdateUserPasswordOptions, UpdateUserPasswordOptions } from '../interfaces';
2
+ export declare const serializeUpdateUserPasswordOptions: (options: UpdateUserPasswordOptions) => SerializedUpdateUserPasswordOptions;
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.serializeUpdateUserPasswordOptions = void 0;
4
+ const serializeUpdateUserPasswordOptions = (options) => ({
5
+ password: options.password,
6
+ });
7
+ exports.serializeUpdateUserPasswordOptions = serializeUpdateUserPasswordOptions;
@@ -0,0 +1,2 @@
1
+ import { User, UserResponse } from '../interfaces';
2
+ export declare const deserializeUser: (user: UserResponse) => User;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.deserializeUser = void 0;
4
+ const exceptions_1 = require("../exceptions");
5
+ const deserializeUser = (user) => {
6
+ const baseUser = {
7
+ object: user.object,
8
+ id: user.id,
9
+ email: user.email,
10
+ firstName: user.first_name,
11
+ lastName: user.last_name,
12
+ createdAt: user.created_at,
13
+ updatedAt: user.updated_at,
14
+ };
15
+ switch (user.user_type) {
16
+ case 'managed':
17
+ return Object.assign(Object.assign({}, baseUser), { userType: user.user_type, ssoProfileId: user.sso_profile_id });
18
+ case 'unmanaged':
19
+ return Object.assign(Object.assign({}, baseUser), { userType: user.user_type, emailVerifiedAt: user.email_verified_at, googleOauthProfileId: user.google_oauth_profile_id, microsoftOauthProfileId: user.microsoft_oauth_profile_id });
20
+ default:
21
+ throw new exceptions_1.UnexpectedUserTypeException(user);
22
+ }
23
+ };
24
+ exports.deserializeUser = deserializeUser;
@@ -0,0 +1,3 @@
1
+ import { SerializedVerifySessionOptions, VerifySessionOptions, VerifySessionResponse, VerifySessionResponseResponse } from '../interfaces';
2
+ export declare const deserializeVerifySessionResponse: (verifySessionResponse: VerifySessionResponseResponse) => VerifySessionResponse;
3
+ export declare const serializeVerifySessionOptions: (options: VerifySessionOptions) => SerializedVerifySessionOptions;
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.serializeVerifySessionOptions = exports.deserializeVerifySessionResponse = void 0;
4
+ const session_serializer_1 = require("./session.serializer");
5
+ const user_serializer_1 = require("./user.serializer");
6
+ const deserializeVerifySessionResponse = (verifySessionResponse) => ({
7
+ session: (0, session_serializer_1.deserializeSession)(verifySessionResponse.session),
8
+ user: (0, user_serializer_1.deserializeUser)(verifySessionResponse.user),
9
+ });
10
+ exports.deserializeVerifySessionResponse = deserializeVerifySessionResponse;
11
+ const serializeVerifySessionOptions = (options) => ({
12
+ token: options.token,
13
+ client_id: options.clientId,
14
+ });
15
+ exports.serializeVerifySessionOptions = serializeVerifySessionOptions;
@@ -1,21 +1,25 @@
1
1
  import { WorkOS } from '../workos';
2
- import { AddUserToOrganizationOptions, AuthenticateUserWithPasswordOptions, AuthenticateUserWithTokenOptions, AuthenticationResponse, CompletePasswordResetOptions, CreateEmailVerificationChallengeOptions, CreateEmailVerificationChallengeResponse, CreatePasswordResetChallengeOptions, CreatePasswordResetChallengeResponse, CreateUserOptions, ListUsersOptions, RemoveUserFromOrganizationOptions, RevokeSessionOptions, User, VerifySessionOptions, VerifySessionResponse } from './interfaces';
3
- import { List } from '../common/interfaces/list.interface';
2
+ import { AutoPaginatable } from '../common/utils/pagination';
3
+ import { AddUserToOrganizationOptions, AuthenticateUserWithMagicAuthOptions, AuthenticateUserWithPasswordOptions, AuthenticateUserWithTokenOptions, AuthenticationResponse, CompletePasswordResetOptions, CreateEmailVerificationChallengeOptions, CreateEmailVerificationChallengeResponse, CreatePasswordResetChallengeOptions, CreatePasswordResetChallengeResponse, CreateUserOptions, ListUsersOptions, MagicAuthChallenge, RemoveUserFromOrganizationOptions, RevokeAllSessionsForUserOptions, RevokeSessionOptions, SendMagicAuthCodeOptions, UpdateUserOptions, UpdateUserPasswordOptions, User, VerifySessionOptions, VerifySessionResponse } from './interfaces';
4
4
  export declare class Users {
5
5
  private readonly workos;
6
6
  constructor(workos: WorkOS);
7
7
  getUser(userId: string): Promise<User>;
8
- listUsers(options?: ListUsersOptions): Promise<List<User>>;
8
+ listUsers(options?: ListUsersOptions): Promise<AutoPaginatable<User>>;
9
9
  createUser(payload: CreateUserOptions): Promise<User>;
10
+ authenticateUserWithMagicAuth(payload: AuthenticateUserWithMagicAuthOptions): Promise<AuthenticationResponse>;
10
11
  authenticateUserWithPassword(payload: AuthenticateUserWithPasswordOptions): Promise<AuthenticationResponse>;
11
12
  authenticateUserWithToken(payload: AuthenticateUserWithTokenOptions): Promise<AuthenticationResponse>;
12
13
  verifySession(payload: VerifySessionOptions): Promise<VerifySessionResponse>;
13
14
  revokeSession(payload: RevokeSessionOptions): Promise<boolean>;
14
- revokeAllSessionsForUser(userId: string): Promise<boolean>;
15
- createEmailVerificationChallenge({ user_id, verification_url, }: CreateEmailVerificationChallengeOptions): Promise<CreateEmailVerificationChallengeResponse>;
15
+ revokeAllSessionsForUser({ userId, }: RevokeAllSessionsForUserOptions): Promise<boolean>;
16
+ createEmailVerificationChallenge({ userId, verificationUrl, }: CreateEmailVerificationChallengeOptions): Promise<CreateEmailVerificationChallengeResponse>;
17
+ sendMagicAuthCode(options: SendMagicAuthCodeOptions): Promise<MagicAuthChallenge>;
16
18
  completeEmailVerification(token: string): Promise<User>;
17
19
  createPasswordResetChallenge(payload: CreatePasswordResetChallengeOptions): Promise<CreatePasswordResetChallengeResponse>;
18
20
  completePasswordReset(payload: CompletePasswordResetOptions): Promise<User>;
19
- addUserToOrganization({ user_id, organization_id, }: AddUserToOrganizationOptions): Promise<User>;
20
- removeUserFromOrganization({ user_id, organization_id, }: RemoveUserFromOrganizationOptions): Promise<User>;
21
+ addUserToOrganization({ userId, organizationId, }: AddUserToOrganizationOptions): Promise<User>;
22
+ removeUserFromOrganization({ userId, organizationId, }: RemoveUserFromOrganizationOptions): Promise<User>;
23
+ updateUser(payload: UpdateUserOptions): Promise<User>;
24
+ updateUserPassword(payload: UpdateUserPasswordOptions): Promise<User>;
21
25
  }
@@ -10,6 +10,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.Users = void 0;
13
+ const pagination_1 = require("../common/utils/pagination");
14
+ const serializers_1 = require("./serializers");
15
+ const fetch_and_deserialize_1 = require("../common/utils/fetch-and-deserialize");
13
16
  class Users {
14
17
  constructor(workos) {
15
18
  this.workos = workos;
@@ -17,58 +20,67 @@ class Users {
17
20
  getUser(userId) {
18
21
  return __awaiter(this, void 0, void 0, function* () {
19
22
  const { data } = yield this.workos.get(`/users/${userId}`);
20
- return data;
23
+ return (0, serializers_1.deserializeUser)(data);
21
24
  });
22
25
  }
23
26
  listUsers(options) {
24
27
  return __awaiter(this, void 0, void 0, function* () {
25
- const { data } = yield this.workos.get('/users', {
26
- query: options,
27
- });
28
- return data;
28
+ return new pagination_1.AutoPaginatable(yield (0, fetch_and_deserialize_1.fetchAndDeserialize)(this.workos, '/users', serializers_1.deserializeUser, options), (params) => (0, fetch_and_deserialize_1.fetchAndDeserialize)(this.workos, '/users', serializers_1.deserializeUser, params), options);
29
29
  });
30
30
  }
31
31
  createUser(payload) {
32
32
  return __awaiter(this, void 0, void 0, function* () {
33
- const { data } = yield this.workos.post('/users', payload);
34
- return data;
33
+ const { data } = yield this.workos.post('/users', (0, serializers_1.serializeCreateUserOptions)(payload));
34
+ return (0, serializers_1.deserializeUser)(data);
35
+ });
36
+ }
37
+ authenticateUserWithMagicAuth(payload) {
38
+ return __awaiter(this, void 0, void 0, function* () {
39
+ const { data } = yield this.workos.post('/users/sessions/token', (0, serializers_1.serializeAuthenticateUserWithMagicAuthOptions)(Object.assign(Object.assign({}, payload), { clientSecret: this.workos.key })));
40
+ return (0, serializers_1.deserializeAuthenticationResponse)(data);
35
41
  });
36
42
  }
37
43
  authenticateUserWithPassword(payload) {
38
44
  return __awaiter(this, void 0, void 0, function* () {
39
- const { data } = yield this.workos.post('/users/authentications', payload);
40
- return data;
45
+ const { data } = yield this.workos.post('/users/sessions/token', (0, serializers_1.serializeAuthenticateUserWithPasswordOptions)(Object.assign(Object.assign({}, payload), { clientSecret: this.workos.key })));
46
+ return (0, serializers_1.deserializeAuthenticationResponse)(data);
41
47
  });
42
48
  }
43
49
  authenticateUserWithToken(payload) {
44
50
  return __awaiter(this, void 0, void 0, function* () {
45
- const { data } = yield this.workos.post('/users/sessions/token', Object.assign(Object.assign({}, payload), { client_secret: this.workos.key, grant_type: 'authorization_code' }));
46
- return data;
51
+ const { data } = yield this.workos.post('/users/sessions/token', (0, serializers_1.serializeAuthenticateUserWithTokenOptions)(Object.assign(Object.assign({}, payload), { clientSecret: this.workos.key })));
52
+ return (0, serializers_1.deserializeAuthenticationResponse)(data);
47
53
  });
48
54
  }
49
55
  verifySession(payload) {
50
56
  return __awaiter(this, void 0, void 0, function* () {
51
- const { data } = yield this.workos.post('/users/sessions/verify', payload);
52
- return data;
57
+ const { data } = yield this.workos.post('/users/sessions/verify', (0, serializers_1.serializeVerifySessionOptions)(payload));
58
+ return (0, serializers_1.deserializeVerifySessionResponse)(data);
53
59
  });
54
60
  }
55
61
  revokeSession(payload) {
56
62
  return __awaiter(this, void 0, void 0, function* () {
57
- const { data } = yield this.workos.post('/users/sessions/revocations', payload);
63
+ const { data } = yield this.workos.post('/users/sessions/revocations', (0, serializers_1.serializeRevokeSessionOptions)(payload));
58
64
  return data;
59
65
  });
60
66
  }
61
- revokeAllSessionsForUser(userId) {
67
+ revokeAllSessionsForUser({ userId, }) {
62
68
  return __awaiter(this, void 0, void 0, function* () {
63
69
  const { data } = yield this.workos.delete(`/users/${userId}/sessions`);
64
70
  return data;
65
71
  });
66
72
  }
67
- createEmailVerificationChallenge({ user_id, verification_url, }) {
73
+ createEmailVerificationChallenge({ userId, verificationUrl, }) {
68
74
  return __awaiter(this, void 0, void 0, function* () {
69
- const { data } = yield this.workos.post(`/users/${user_id}/email_verification_challenge`, {
70
- verification_url,
75
+ const { data } = yield this.workos.post(`/users/${userId}/email_verification_challenge`, {
76
+ verification_url: verificationUrl,
71
77
  });
78
+ return (0, serializers_1.deserializeCreateEmailVerificationChallengeResponse)(data);
79
+ });
80
+ }
81
+ sendMagicAuthCode(options) {
82
+ return __awaiter(this, void 0, void 0, function* () {
83
+ const { data } = yield this.workos.post('/users/magic_auth/send', (0, serializers_1.serializeSendMagicAuthCodeOptions)(options));
72
84
  return data;
73
85
  });
74
86
  }
@@ -77,33 +89,45 @@ class Users {
77
89
  const { data } = yield this.workos.post('/users/email_verification', {
78
90
  token,
79
91
  });
80
- return data;
92
+ return (0, serializers_1.deserializeUser)(data);
81
93
  });
82
94
  }
83
95
  createPasswordResetChallenge(payload) {
84
96
  return __awaiter(this, void 0, void 0, function* () {
85
- const { data } = yield this.workos.post('/users/password_reset_challenge', payload);
86
- return data;
97
+ const { data } = yield this.workos.post('/users/password_reset_challenge', (0, serializers_1.serializeCreatePasswordResetChallengeOptions)(payload));
98
+ return (0, serializers_1.deserializeCreatePasswordResetChallengeResponse)(data);
87
99
  });
88
100
  }
89
101
  completePasswordReset(payload) {
90
102
  return __awaiter(this, void 0, void 0, function* () {
91
- const { data } = yield this.workos.post('/users/password_reset', payload);
92
- return data;
103
+ const { data } = yield this.workos.post('/users/password_reset', (0, serializers_1.serializeCompletePasswordResetOptions)(payload));
104
+ return (0, serializers_1.deserializeUser)(data);
93
105
  });
94
106
  }
95
- addUserToOrganization({ user_id, organization_id, }) {
107
+ addUserToOrganization({ userId, organizationId, }) {
96
108
  return __awaiter(this, void 0, void 0, function* () {
97
- const { data } = yield this.workos.post(`/users/${user_id}/organizations`, {
98
- organization_id,
109
+ const { data } = yield this.workos.post(`/users/${userId}/organizations`, {
110
+ organization_id: organizationId,
99
111
  });
100
- return data;
112
+ return (0, serializers_1.deserializeUser)(data);
101
113
  });
102
114
  }
103
- removeUserFromOrganization({ user_id, organization_id, }) {
115
+ removeUserFromOrganization({ userId, organizationId, }) {
104
116
  return __awaiter(this, void 0, void 0, function* () {
105
- const { data } = yield this.workos.delete(`/users/${user_id}/organizations/${organization_id}`);
106
- return data;
117
+ const { data } = yield this.workos.delete(`/users/${userId}/organizations/${organizationId}`);
118
+ return (0, serializers_1.deserializeUser)(data);
119
+ });
120
+ }
121
+ updateUser(payload) {
122
+ return __awaiter(this, void 0, void 0, function* () {
123
+ const { data } = yield this.workos.put(`/users/${payload.userId}`, (0, serializers_1.serializeUpdateUserOptions)(payload));
124
+ return (0, serializers_1.deserializeUser)(data);
125
+ });
126
+ }
127
+ updateUserPassword(payload) {
128
+ return __awaiter(this, void 0, void 0, function* () {
129
+ const { data } = yield this.workos.put(`/users/${payload.userId}/password`, (0, serializers_1.serializeUpdateUserPasswordOptions)(payload));
130
+ return (0, serializers_1.deserializeUser)(data);
107
131
  });
108
132
  }
109
133
  }