workos 0.11.1 → 0.12.0-beta.1

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 (172) hide show
  1. package/README.md +163 -6
  2. package/dist/bin.js +22 -2
  3. package/dist/bin.js.map +1 -1
  4. package/dist/check-coverage.ts +237 -0
  5. package/dist/commands/dev.d.ts +23 -0
  6. package/dist/commands/dev.js +139 -0
  7. package/dist/commands/dev.js.map +1 -0
  8. package/dist/commands/emulate.d.ts +6 -0
  9. package/dist/commands/emulate.js +64 -0
  10. package/dist/commands/emulate.js.map +1 -0
  11. package/dist/commands/seed.d.ts +2 -0
  12. package/dist/commands/seed.js +60 -1
  13. package/dist/commands/seed.js.map +1 -1
  14. package/dist/emulate/core/id.d.ts +33 -0
  15. package/dist/emulate/core/id.js +58 -0
  16. package/dist/emulate/core/id.js.map +1 -0
  17. package/dist/emulate/core/index.d.ts +8 -0
  18. package/dist/emulate/core/index.js +8 -0
  19. package/dist/emulate/core/index.js.map +1 -0
  20. package/dist/emulate/core/jwt.d.ts +28 -0
  21. package/dist/emulate/core/jwt.js +78 -0
  22. package/dist/emulate/core/jwt.js.map +1 -0
  23. package/dist/emulate/core/middleware/auth.d.ts +18 -0
  24. package/dist/emulate/core/middleware/auth.js +28 -0
  25. package/dist/emulate/core/middleware/auth.js.map +1 -0
  26. package/dist/emulate/core/middleware/error-handler.d.ts +22 -0
  27. package/dist/emulate/core/middleware/error-handler.js +72 -0
  28. package/dist/emulate/core/middleware/error-handler.js.map +1 -0
  29. package/dist/emulate/core/pagination.d.ts +21 -0
  30. package/dist/emulate/core/pagination.js +35 -0
  31. package/dist/emulate/core/pagination.js.map +1 -0
  32. package/dist/emulate/core/plugin.d.ts +15 -0
  33. package/dist/emulate/core/plugin.js +2 -0
  34. package/dist/emulate/core/plugin.js.map +1 -0
  35. package/dist/emulate/core/server.d.ts +17 -0
  36. package/dist/emulate/core/server.js +116 -0
  37. package/dist/emulate/core/server.js.map +1 -0
  38. package/dist/emulate/core/store.d.ts +42 -0
  39. package/dist/emulate/core/store.js +148 -0
  40. package/dist/emulate/core/store.js.map +1 -0
  41. package/dist/emulate/index.d.ts +25 -0
  42. package/dist/emulate/index.js +47 -0
  43. package/dist/emulate/index.js.map +1 -0
  44. package/dist/emulate/workos/entities.d.ts +360 -0
  45. package/dist/emulate/workos/entities.js +2 -0
  46. package/dist/emulate/workos/entities.js.map +1 -0
  47. package/dist/emulate/workos/event-bus.d.ts +12 -0
  48. package/dist/emulate/workos/event-bus.js +45 -0
  49. package/dist/emulate/workos/event-bus.js.map +1 -0
  50. package/dist/emulate/workos/helpers.d.ts +63 -0
  51. package/dist/emulate/workos/helpers.js +518 -0
  52. package/dist/emulate/workos/helpers.js.map +1 -0
  53. package/dist/emulate/workos/index.d.ts +91 -0
  54. package/dist/emulate/workos/index.js +319 -0
  55. package/dist/emulate/workos/index.js.map +1 -0
  56. package/dist/emulate/workos/routes/api-keys.d.ts +2 -0
  57. package/dist/emulate/workos/routes/api-keys.js +35 -0
  58. package/dist/emulate/workos/routes/api-keys.js.map +1 -0
  59. package/dist/emulate/workos/routes/audit-logs.d.ts +2 -0
  60. package/dist/emulate/workos/routes/audit-logs.js +107 -0
  61. package/dist/emulate/workos/routes/audit-logs.js.map +1 -0
  62. package/dist/emulate/workos/routes/auth-challenges.d.ts +2 -0
  63. package/dist/emulate/workos/routes/auth-challenges.js +51 -0
  64. package/dist/emulate/workos/routes/auth-challenges.js.map +1 -0
  65. package/dist/emulate/workos/routes/auth-factors.d.ts +2 -0
  66. package/dist/emulate/workos/routes/auth-factors.js +51 -0
  67. package/dist/emulate/workos/routes/auth-factors.js.map +1 -0
  68. package/dist/emulate/workos/routes/auth.d.ts +2 -0
  69. package/dist/emulate/workos/routes/auth.js +349 -0
  70. package/dist/emulate/workos/routes/auth.js.map +1 -0
  71. package/dist/emulate/workos/routes/authorization-checks.d.ts +10 -0
  72. package/dist/emulate/workos/routes/authorization-checks.js +135 -0
  73. package/dist/emulate/workos/routes/authorization-checks.js.map +1 -0
  74. package/dist/emulate/workos/routes/authorization-org-roles.d.ts +2 -0
  75. package/dist/emulate/workos/routes/authorization-org-roles.js +206 -0
  76. package/dist/emulate/workos/routes/authorization-org-roles.js.map +1 -0
  77. package/dist/emulate/workos/routes/authorization-permissions.d.ts +2 -0
  78. package/dist/emulate/workos/routes/authorization-permissions.js +78 -0
  79. package/dist/emulate/workos/routes/authorization-permissions.js.map +1 -0
  80. package/dist/emulate/workos/routes/authorization-resources.d.ts +2 -0
  81. package/dist/emulate/workos/routes/authorization-resources.js +128 -0
  82. package/dist/emulate/workos/routes/authorization-resources.js.map +1 -0
  83. package/dist/emulate/workos/routes/authorization-roles.d.ts +2 -0
  84. package/dist/emulate/workos/routes/authorization-roles.js +136 -0
  85. package/dist/emulate/workos/routes/authorization-roles.js.map +1 -0
  86. package/dist/emulate/workos/routes/config.d.ts +2 -0
  87. package/dist/emulate/workos/routes/config.js +56 -0
  88. package/dist/emulate/workos/routes/config.js.map +1 -0
  89. package/dist/emulate/workos/routes/connect.d.ts +2 -0
  90. package/dist/emulate/workos/routes/connect.js +69 -0
  91. package/dist/emulate/workos/routes/connect.js.map +1 -0
  92. package/dist/emulate/workos/routes/connections.d.ts +2 -0
  93. package/dist/emulate/workos/routes/connections.js +77 -0
  94. package/dist/emulate/workos/routes/connections.js.map +1 -0
  95. package/dist/emulate/workos/routes/data-integrations.d.ts +2 -0
  96. package/dist/emulate/workos/routes/data-integrations.js +55 -0
  97. package/dist/emulate/workos/routes/data-integrations.js.map +1 -0
  98. package/dist/emulate/workos/routes/directories.d.ts +2 -0
  99. package/dist/emulate/workos/routes/directories.js +106 -0
  100. package/dist/emulate/workos/routes/directories.js.map +1 -0
  101. package/dist/emulate/workos/routes/email-verification.d.ts +2 -0
  102. package/dist/emulate/workos/routes/email-verification.js +49 -0
  103. package/dist/emulate/workos/routes/email-verification.js.map +1 -0
  104. package/dist/emulate/workos/routes/events.d.ts +2 -0
  105. package/dist/emulate/workos/routes/events.js +21 -0
  106. package/dist/emulate/workos/routes/events.js.map +1 -0
  107. package/dist/emulate/workos/routes/feature-flags.d.ts +2 -0
  108. package/dist/emulate/workos/routes/feature-flags.js +131 -0
  109. package/dist/emulate/workos/routes/feature-flags.js.map +1 -0
  110. package/dist/emulate/workos/routes/invitations.d.ts +2 -0
  111. package/dist/emulate/workos/routes/invitations.js +125 -0
  112. package/dist/emulate/workos/routes/invitations.js.map +1 -0
  113. package/dist/emulate/workos/routes/legacy-mfa.d.ts +2 -0
  114. package/dist/emulate/workos/routes/legacy-mfa.js +75 -0
  115. package/dist/emulate/workos/routes/legacy-mfa.js.map +1 -0
  116. package/dist/emulate/workos/routes/magic-auth.d.ts +2 -0
  117. package/dist/emulate/workos/routes/magic-auth.js +32 -0
  118. package/dist/emulate/workos/routes/magic-auth.js.map +1 -0
  119. package/dist/emulate/workos/routes/memberships.d.ts +2 -0
  120. package/dist/emulate/workos/routes/memberships.js +118 -0
  121. package/dist/emulate/workos/routes/memberships.js.map +1 -0
  122. package/dist/emulate/workos/routes/organization-domains.d.ts +2 -0
  123. package/dist/emulate/workos/routes/organization-domains.js +58 -0
  124. package/dist/emulate/workos/routes/organization-domains.js.map +1 -0
  125. package/dist/emulate/workos/routes/organizations.d.ts +2 -0
  126. package/dist/emulate/workos/routes/organizations.js +133 -0
  127. package/dist/emulate/workos/routes/organizations.js.map +1 -0
  128. package/dist/emulate/workos/routes/password-reset.d.ts +2 -0
  129. package/dist/emulate/workos/routes/password-reset.js +61 -0
  130. package/dist/emulate/workos/routes/password-reset.js.map +1 -0
  131. package/dist/emulate/workos/routes/pipes.d.ts +2 -0
  132. package/dist/emulate/workos/routes/pipes.js +86 -0
  133. package/dist/emulate/workos/routes/pipes.js.map +1 -0
  134. package/dist/emulate/workos/routes/portal.d.ts +2 -0
  135. package/dist/emulate/workos/routes/portal.js +18 -0
  136. package/dist/emulate/workos/routes/portal.js.map +1 -0
  137. package/dist/emulate/workos/routes/radar.d.ts +2 -0
  138. package/dist/emulate/workos/routes/radar.js +45 -0
  139. package/dist/emulate/workos/routes/radar.js.map +1 -0
  140. package/dist/emulate/workos/routes/sessions.d.ts +2 -0
  141. package/dist/emulate/workos/routes/sessions.js +51 -0
  142. package/dist/emulate/workos/routes/sessions.js.map +1 -0
  143. package/dist/emulate/workos/routes/sso.d.ts +2 -0
  144. package/dist/emulate/workos/routes/sso.js +160 -0
  145. package/dist/emulate/workos/routes/sso.js.map +1 -0
  146. package/dist/emulate/workos/routes/user-features.d.ts +2 -0
  147. package/dist/emulate/workos/routes/user-features.js +50 -0
  148. package/dist/emulate/workos/routes/user-features.js.map +1 -0
  149. package/dist/emulate/workos/routes/users.d.ts +2 -0
  150. package/dist/emulate/workos/routes/users.js +133 -0
  151. package/dist/emulate/workos/routes/users.js.map +1 -0
  152. package/dist/emulate/workos/routes/webhook-endpoints.d.ts +2 -0
  153. package/dist/emulate/workos/routes/webhook-endpoints.js +70 -0
  154. package/dist/emulate/workos/routes/webhook-endpoints.js.map +1 -0
  155. package/dist/emulate/workos/routes/widgets.d.ts +2 -0
  156. package/dist/emulate/workos/routes/widgets.js +27 -0
  157. package/dist/emulate/workos/routes/widgets.js.map +1 -0
  158. package/dist/emulate/workos/store.d.ts +48 -0
  159. package/dist/emulate/workos/store.js +93 -0
  160. package/dist/emulate/workos/store.js.map +1 -0
  161. package/dist/emulate/workos/webhook-signer.d.ts +1 -0
  162. package/dist/emulate/workos/webhook-signer.js +8 -0
  163. package/dist/emulate/workos/webhook-signer.js.map +1 -0
  164. package/dist/gen-routes-lib.spec.ts +659 -0
  165. package/dist/gen-routes-lib.ts +647 -0
  166. package/dist/gen-routes.ts +96 -0
  167. package/dist/lib/dev-command.d.ts +26 -0
  168. package/dist/lib/dev-command.js +122 -0
  169. package/dist/lib/dev-command.js.map +1 -0
  170. package/dist/utils/help-json.js +31 -0
  171. package/dist/utils/help-json.js.map +1 -1
  172. package/package.json +20 -7
@@ -0,0 +1,518 @@
1
+ import { randomBytes, createHash, createCipheriv } from 'node:crypto';
2
+ import { WorkOSApiError } from '../core/index.js';
3
+ export function formatOrganization(org, ws) {
4
+ const domains = ws.organizationDomains.findBy('organization_id', org.id).map(formatDomain);
5
+ return {
6
+ object: 'organization',
7
+ id: org.id,
8
+ name: org.name,
9
+ external_id: org.external_id,
10
+ metadata: org.metadata,
11
+ domains,
12
+ stripe_customer_id: org.stripe_customer_id,
13
+ created_at: org.created_at,
14
+ updated_at: org.updated_at,
15
+ };
16
+ }
17
+ export function formatDomain(domain) {
18
+ return {
19
+ object: 'organization_domain',
20
+ id: domain.id,
21
+ organization_id: domain.organization_id,
22
+ domain: domain.domain,
23
+ state: domain.state,
24
+ verification_strategy: domain.verification_strategy,
25
+ verification_token: domain.verification_token,
26
+ verification_prefix: domain.verification_prefix,
27
+ created_at: domain.created_at,
28
+ updated_at: domain.updated_at,
29
+ };
30
+ }
31
+ export function formatMembership(m) {
32
+ return {
33
+ object: 'organization_membership',
34
+ id: m.id,
35
+ organization_id: m.organization_id,
36
+ user_id: m.user_id,
37
+ role: m.role,
38
+ status: m.status,
39
+ external_id: m.external_id,
40
+ metadata: m.metadata,
41
+ created_at: m.created_at,
42
+ updated_at: m.updated_at,
43
+ };
44
+ }
45
+ export function formatUser(user) {
46
+ return {
47
+ object: 'user',
48
+ id: user.id,
49
+ email: user.email,
50
+ first_name: user.first_name,
51
+ last_name: user.last_name,
52
+ email_verified: user.email_verified,
53
+ profile_picture_url: user.profile_picture_url,
54
+ last_sign_in_at: user.last_sign_in_at,
55
+ external_id: user.external_id,
56
+ metadata: user.metadata,
57
+ locale: user.locale,
58
+ created_at: user.created_at,
59
+ updated_at: user.updated_at,
60
+ };
61
+ }
62
+ export function formatSession(s) {
63
+ return {
64
+ object: 'session',
65
+ id: s.id,
66
+ user_id: s.user_id,
67
+ organization_id: s.organization_id,
68
+ ip_address: s.ip_address,
69
+ user_agent: s.user_agent,
70
+ created_at: s.created_at,
71
+ updated_at: s.updated_at,
72
+ };
73
+ }
74
+ export function formatEmailVerification(ev) {
75
+ return {
76
+ object: 'email_verification',
77
+ id: ev.id,
78
+ user_id: ev.user_id,
79
+ email: ev.email,
80
+ code: ev.code,
81
+ expires_at: ev.expires_at,
82
+ created_at: ev.created_at,
83
+ updated_at: ev.updated_at,
84
+ };
85
+ }
86
+ export function formatPasswordReset(pr) {
87
+ return {
88
+ object: 'password_reset',
89
+ id: pr.id,
90
+ user_id: pr.user_id,
91
+ email: pr.email,
92
+ token: pr.token,
93
+ expires_at: pr.expires_at,
94
+ created_at: pr.created_at,
95
+ updated_at: pr.updated_at,
96
+ };
97
+ }
98
+ export function formatMagicAuth(ma) {
99
+ return {
100
+ object: 'magic_auth',
101
+ id: ma.id,
102
+ user_id: ma.user_id,
103
+ email: ma.email,
104
+ code: ma.code,
105
+ expires_at: ma.expires_at,
106
+ created_at: ma.created_at,
107
+ updated_at: ma.updated_at,
108
+ };
109
+ }
110
+ export function formatAuthFactor(f) {
111
+ return {
112
+ object: 'authentication_factor',
113
+ id: f.id,
114
+ user_id: f.user_id,
115
+ type: f.type,
116
+ totp: f.totp,
117
+ created_at: f.created_at,
118
+ updated_at: f.updated_at,
119
+ };
120
+ }
121
+ export function formatIdentity(i) {
122
+ return {
123
+ object: 'identity',
124
+ id: i.id,
125
+ user_id: i.user_id,
126
+ provider: i.provider,
127
+ provider_id: i.provider_id,
128
+ type: i.type,
129
+ created_at: i.created_at,
130
+ updated_at: i.updated_at,
131
+ };
132
+ }
133
+ export function generateVerificationToken() {
134
+ return randomBytes(16).toString('hex');
135
+ }
136
+ export function generateCode() {
137
+ return String(Math.floor(100000 + Math.random() * 900000));
138
+ }
139
+ export function hashPassword(password) {
140
+ return createHash('sha256').update(password).digest('hex');
141
+ }
142
+ export function verifyPassword(password, hash) {
143
+ return hashPassword(password) === hash;
144
+ }
145
+ export function expiresIn(minutes) {
146
+ return new Date(Date.now() + minutes * 60 * 1000).toISOString();
147
+ }
148
+ export function isExpired(expiresAt) {
149
+ return new Date(expiresAt).getTime() < Date.now();
150
+ }
151
+ export function formatConnection(conn) {
152
+ return {
153
+ object: 'connection',
154
+ id: conn.id,
155
+ organization_id: conn.organization_id,
156
+ connection_type: conn.connection_type,
157
+ name: conn.name,
158
+ state: conn.state,
159
+ domains: conn.domains,
160
+ created_at: conn.created_at,
161
+ updated_at: conn.updated_at,
162
+ };
163
+ }
164
+ export function formatSSOProfile(p) {
165
+ return {
166
+ object: 'profile',
167
+ id: p.id,
168
+ connection_id: p.connection_id,
169
+ connection_type: p.connection_type,
170
+ organization_id: p.organization_id,
171
+ idp_id: p.idp_id,
172
+ email: p.email,
173
+ first_name: p.first_name,
174
+ last_name: p.last_name,
175
+ groups: p.groups,
176
+ raw_attributes: p.raw_attributes,
177
+ created_at: p.created_at,
178
+ updated_at: p.updated_at,
179
+ };
180
+ }
181
+ export function formatPipeConnection(pc) {
182
+ return {
183
+ object: 'pipe_connection',
184
+ id: pc.id,
185
+ user_id: pc.user_id,
186
+ provider: pc.provider,
187
+ scopes: pc.scopes,
188
+ status: pc.status,
189
+ external_account_id: pc.external_account_id,
190
+ created_at: pc.created_at,
191
+ updated_at: pc.updated_at,
192
+ };
193
+ }
194
+ export function formatInvitation(inv) {
195
+ return {
196
+ object: 'invitation',
197
+ id: inv.id,
198
+ email: inv.email,
199
+ state: inv.state,
200
+ token: inv.token,
201
+ accept_invitation_url: inv.accept_invitation_url,
202
+ organization_id: inv.organization_id,
203
+ inviter_user_id: inv.inviter_user_id,
204
+ role_slug: inv.role_slug,
205
+ expires_at: inv.expires_at,
206
+ created_at: inv.created_at,
207
+ updated_at: inv.updated_at,
208
+ };
209
+ }
210
+ export function formatRedirectUri(r) {
211
+ return {
212
+ object: 'redirect_uri',
213
+ id: r.id,
214
+ uri: r.uri,
215
+ created_at: r.created_at,
216
+ updated_at: r.updated_at,
217
+ };
218
+ }
219
+ export function formatCorsOrigin(o) {
220
+ return {
221
+ object: 'cors_origin',
222
+ id: o.id,
223
+ origin: o.origin,
224
+ created_at: o.created_at,
225
+ updated_at: o.updated_at,
226
+ };
227
+ }
228
+ export function formatAuthorizedApplication(a) {
229
+ return {
230
+ object: 'authorized_application',
231
+ id: a.id,
232
+ user_id: a.user_id,
233
+ name: a.name,
234
+ redirect_uri: a.redirect_uri,
235
+ created_at: a.created_at,
236
+ updated_at: a.updated_at,
237
+ };
238
+ }
239
+ export function formatConnectedAccount(a) {
240
+ return {
241
+ object: 'connected_account',
242
+ id: a.id,
243
+ user_id: a.user_id,
244
+ provider: a.provider,
245
+ provider_id: a.provider_id,
246
+ created_at: a.created_at,
247
+ updated_at: a.updated_at,
248
+ };
249
+ }
250
+ export function parseListParams(url) {
251
+ const limit = Math.max(1, Math.min(parseInt(url.searchParams.get('limit') ?? '10'), 100));
252
+ const order = url.searchParams.get('order') ?? 'desc';
253
+ const before = url.searchParams.get('before') ?? undefined;
254
+ const after = url.searchParams.get('after') ?? undefined;
255
+ return { limit, order, before, after };
256
+ }
257
+ /** Allowed redirect URI hosts for the emulator's authorize endpoints. */
258
+ const ALLOWED_REDIRECT_HOSTS = new Set(['localhost', '127.0.0.1', '[::1]']);
259
+ /**
260
+ * Validate that a redirect_uri points to a localhost origin.
261
+ * Prevents the emulator from being used as an open redirect.
262
+ */
263
+ export function assertLocalRedirectUri(uri) {
264
+ let parsed;
265
+ try {
266
+ parsed = new URL(uri);
267
+ }
268
+ catch {
269
+ throw new WorkOSApiError(400, 'Invalid redirect_uri', 'invalid_redirect_uri');
270
+ }
271
+ if (!ALLOWED_REDIRECT_HOSTS.has(parsed.hostname)) {
272
+ throw new WorkOSApiError(400, `redirect_uri must point to localhost, got ${parsed.hostname}`, 'invalid_redirect_uri');
273
+ }
274
+ }
275
+ export function formatAuthChallenge(c) {
276
+ return {
277
+ object: 'authentication_challenge',
278
+ id: c.id,
279
+ user_id: c.user_id,
280
+ factor_id: c.factor_id,
281
+ expires_at: c.expires_at,
282
+ created_at: c.created_at,
283
+ updated_at: c.updated_at,
284
+ };
285
+ }
286
+ export function formatRole(role) {
287
+ return {
288
+ object: 'role',
289
+ id: role.id,
290
+ slug: role.slug,
291
+ name: role.name,
292
+ description: role.description,
293
+ type: role.type,
294
+ organization_id: role.organization_id,
295
+ is_default_role: role.is_default_role,
296
+ priority: role.priority,
297
+ created_at: role.created_at,
298
+ updated_at: role.updated_at,
299
+ };
300
+ }
301
+ export function formatPermission(p) {
302
+ return {
303
+ object: 'permission',
304
+ id: p.id,
305
+ slug: p.slug,
306
+ name: p.name,
307
+ description: p.description,
308
+ created_at: p.created_at,
309
+ updated_at: p.updated_at,
310
+ };
311
+ }
312
+ export function formatAuthorizationResource(r) {
313
+ return {
314
+ object: 'authorization_resource',
315
+ id: r.id,
316
+ resource_type_slug: r.resource_type_slug,
317
+ external_id: r.external_id,
318
+ organization_id: r.organization_id,
319
+ metadata: r.metadata,
320
+ created_at: r.created_at,
321
+ updated_at: r.updated_at,
322
+ };
323
+ }
324
+ export function formatRoleAssignment(ra) {
325
+ return {
326
+ object: 'role_assignment',
327
+ id: ra.id,
328
+ organization_membership_id: ra.organization_membership_id,
329
+ role_id: ra.role_id,
330
+ created_at: ra.created_at,
331
+ updated_at: ra.updated_at,
332
+ };
333
+ }
334
+ export function formatDeviceAuthorization(d) {
335
+ return {
336
+ device_code: d.device_code,
337
+ user_code: d.user_code,
338
+ verification_uri: 'http://localhost:0/user_management/authorize/device/verify',
339
+ expires_in: Math.max(0, Math.floor((new Date(d.expires_at).getTime() - Date.now()) / 1000)),
340
+ interval: d.interval,
341
+ };
342
+ }
343
+ // --- Phase 4: CRUD Domain formatters ---
344
+ export function formatDirectory(d) {
345
+ return {
346
+ object: 'directory',
347
+ id: d.id,
348
+ name: d.name,
349
+ organization_id: d.organization_id,
350
+ domain: d.domain,
351
+ type: d.type,
352
+ state: d.state,
353
+ external_key: d.external_key,
354
+ created_at: d.created_at,
355
+ updated_at: d.updated_at,
356
+ };
357
+ }
358
+ export function formatDirectoryUser(u) {
359
+ return {
360
+ object: 'directory_user',
361
+ id: u.id,
362
+ directory_id: u.directory_id,
363
+ organization_id: u.organization_id,
364
+ idp_id: u.idp_id,
365
+ first_name: u.first_name,
366
+ last_name: u.last_name,
367
+ email: u.email,
368
+ username: u.username,
369
+ state: u.state,
370
+ role: u.role,
371
+ custom_attributes: u.custom_attributes,
372
+ raw_attributes: u.raw_attributes,
373
+ groups: u.groups,
374
+ created_at: u.created_at,
375
+ updated_at: u.updated_at,
376
+ };
377
+ }
378
+ export function formatDirectoryGroup(g) {
379
+ return {
380
+ object: 'directory_group',
381
+ id: g.id,
382
+ directory_id: g.directory_id,
383
+ organization_id: g.organization_id,
384
+ idp_id: g.idp_id,
385
+ name: g.name,
386
+ raw_attributes: g.raw_attributes,
387
+ created_at: g.created_at,
388
+ updated_at: g.updated_at,
389
+ };
390
+ }
391
+ export function formatAuditLogAction(a) {
392
+ return {
393
+ object: 'audit_log_action',
394
+ id: a.id,
395
+ name: a.name,
396
+ description: a.description,
397
+ condition: a.condition,
398
+ created_at: a.created_at,
399
+ updated_at: a.updated_at,
400
+ };
401
+ }
402
+ export function formatAuditLogEvent(e) {
403
+ return {
404
+ object: 'audit_log_event',
405
+ id: e.id,
406
+ organization_id: e.organization_id,
407
+ action: e.action,
408
+ actor: e.actor,
409
+ targets: e.targets,
410
+ metadata: e.metadata,
411
+ occurred_at: e.occurred_at,
412
+ created_at: e.created_at,
413
+ updated_at: e.updated_at,
414
+ };
415
+ }
416
+ export function formatAuditLogExport(ex) {
417
+ return {
418
+ object: 'audit_log_export',
419
+ id: ex.id,
420
+ organization_id: ex.organization_id,
421
+ state: ex.state,
422
+ url: ex.url,
423
+ filters: ex.filters,
424
+ created_at: ex.created_at,
425
+ updated_at: ex.updated_at,
426
+ };
427
+ }
428
+ export function formatFeatureFlag(f) {
429
+ return {
430
+ object: 'feature_flag',
431
+ id: f.id,
432
+ slug: f.slug,
433
+ name: f.name,
434
+ description: f.description,
435
+ type: f.type,
436
+ default_value: f.default_value,
437
+ enabled: f.enabled,
438
+ created_at: f.created_at,
439
+ updated_at: f.updated_at,
440
+ };
441
+ }
442
+ export function formatConnectApplication(a) {
443
+ return {
444
+ object: 'connect_application',
445
+ id: a.id,
446
+ name: a.name,
447
+ redirect_uris: a.redirect_uris,
448
+ client_id: a.client_id,
449
+ logo_url: a.logo_url,
450
+ created_at: a.created_at,
451
+ updated_at: a.updated_at,
452
+ };
453
+ }
454
+ export function formatClientSecret(s) {
455
+ return {
456
+ object: 'client_secret',
457
+ id: s.id,
458
+ application_id: s.application_id,
459
+ last_four: s.last_four,
460
+ created_at: s.created_at,
461
+ updated_at: s.updated_at,
462
+ };
463
+ }
464
+ export function formatRadarAttempt(a) {
465
+ return {
466
+ object: 'radar_attempt',
467
+ id: a.id,
468
+ user_id: a.user_id,
469
+ ip_address: a.ip_address,
470
+ user_agent: a.user_agent,
471
+ verdict: a.verdict,
472
+ signals: a.signals,
473
+ created_at: a.created_at,
474
+ updated_at: a.updated_at,
475
+ };
476
+ }
477
+ export function formatApiKeyRecord(k) {
478
+ return {
479
+ object: 'api_key',
480
+ id: k.id,
481
+ name: k.name,
482
+ created_at: k.created_at,
483
+ updated_at: k.updated_at,
484
+ };
485
+ }
486
+ export function formatEvent(e) {
487
+ return {
488
+ object: 'event',
489
+ id: e.id,
490
+ event: e.event,
491
+ data: e.data,
492
+ environment_id: e.environment_id,
493
+ created_at: e.created_at,
494
+ };
495
+ }
496
+ export function formatWebhookEndpoint(ep, opts) {
497
+ return {
498
+ object: 'webhook_endpoint',
499
+ id: ep.id,
500
+ url: ep.url,
501
+ secret: opts?.includeSecret ? ep.secret : `${ep.secret.slice(0, 8)}****`,
502
+ enabled: ep.enabled,
503
+ events: ep.events,
504
+ description: ep.description,
505
+ created_at: ep.created_at,
506
+ updated_at: ep.updated_at,
507
+ };
508
+ }
509
+ export function sealSession(data, apiKey) {
510
+ const key = createHash('sha256').update(apiKey).digest();
511
+ const iv = randomBytes(12);
512
+ const cipher = createCipheriv('aes-256-gcm', key, iv);
513
+ const plaintext = JSON.stringify(data);
514
+ const encrypted = Buffer.concat([cipher.update(plaintext, 'utf8'), cipher.final()]);
515
+ const tag = cipher.getAuthTag();
516
+ return Buffer.concat([iv, tag, encrypted]).toString('base64');
517
+ }
518
+ //# sourceMappingURL=helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../src/emulate/workos/helpers.ts"],"names":[],"mappings":"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","sourcesContent":["import { randomBytes, createHash, createCipheriv } from 'node:crypto';\nimport { WorkOSApiError } from '../core/index.js';\nimport type { WorkOSStore } from './store.js';\nimport type {\n WorkOSOrganization,\n WorkOSOrganizationDomain,\n WorkOSOrganizationMembership,\n WorkOSUser,\n WorkOSSession,\n WorkOSEmailVerification,\n WorkOSPasswordReset,\n WorkOSMagicAuth,\n WorkOSAuthenticationFactor,\n WorkOSIdentity,\n WorkOSConnection,\n WorkOSSSOProfile,\n WorkOSPipeConnection,\n WorkOSInvitation,\n WorkOSRedirectUri,\n WorkOSCorsOrigin,\n WorkOSAuthorizedApplication,\n WorkOSConnectedAccount,\n WorkOSAuthenticationChallenge,\n WorkOSDeviceAuthorization,\n WorkOSRole,\n WorkOSPermission,\n WorkOSAuthorizationResource,\n WorkOSRoleAssignment,\n WorkOSDirectory,\n WorkOSDirectoryUser,\n WorkOSDirectoryGroup,\n WorkOSAuditLogAction,\n WorkOSAuditLogEvent,\n WorkOSAuditLogExport,\n WorkOSFeatureFlag,\n WorkOSConnectApplication,\n WorkOSClientSecret,\n WorkOSRadarAttempt,\n WorkOSApiKey,\n WorkOSEvent,\n WorkOSWebhookEndpoint,\n} from './entities.js';\n\nexport function formatOrganization(org: WorkOSOrganization, ws: WorkOSStore): Record<string, unknown> {\n const domains = ws.organizationDomains.findBy('organization_id', org.id).map(formatDomain);\n\n return {\n object: 'organization',\n id: org.id,\n name: org.name,\n external_id: org.external_id,\n metadata: org.metadata,\n domains,\n stripe_customer_id: org.stripe_customer_id,\n created_at: org.created_at,\n updated_at: org.updated_at,\n };\n}\n\nexport function formatDomain(domain: WorkOSOrganizationDomain): Record<string, unknown> {\n return {\n object: 'organization_domain',\n id: domain.id,\n organization_id: domain.organization_id,\n domain: domain.domain,\n state: domain.state,\n verification_strategy: domain.verification_strategy,\n verification_token: domain.verification_token,\n verification_prefix: domain.verification_prefix,\n created_at: domain.created_at,\n updated_at: domain.updated_at,\n };\n}\n\nexport function formatMembership(m: WorkOSOrganizationMembership): Record<string, unknown> {\n return {\n object: 'organization_membership',\n id: m.id,\n organization_id: m.organization_id,\n user_id: m.user_id,\n role: m.role,\n status: m.status,\n external_id: m.external_id,\n metadata: m.metadata,\n created_at: m.created_at,\n updated_at: m.updated_at,\n };\n}\n\nexport function formatUser(user: WorkOSUser): Record<string, unknown> {\n return {\n object: 'user',\n id: user.id,\n email: user.email,\n first_name: user.first_name,\n last_name: user.last_name,\n email_verified: user.email_verified,\n profile_picture_url: user.profile_picture_url,\n last_sign_in_at: user.last_sign_in_at,\n external_id: user.external_id,\n metadata: user.metadata,\n locale: user.locale,\n created_at: user.created_at,\n updated_at: user.updated_at,\n };\n}\n\nexport function formatSession(s: WorkOSSession): Record<string, unknown> {\n return {\n object: 'session',\n id: s.id,\n user_id: s.user_id,\n organization_id: s.organization_id,\n ip_address: s.ip_address,\n user_agent: s.user_agent,\n created_at: s.created_at,\n updated_at: s.updated_at,\n };\n}\n\nexport function formatEmailVerification(ev: WorkOSEmailVerification): Record<string, unknown> {\n return {\n object: 'email_verification',\n id: ev.id,\n user_id: ev.user_id,\n email: ev.email,\n code: ev.code,\n expires_at: ev.expires_at,\n created_at: ev.created_at,\n updated_at: ev.updated_at,\n };\n}\n\nexport function formatPasswordReset(pr: WorkOSPasswordReset): Record<string, unknown> {\n return {\n object: 'password_reset',\n id: pr.id,\n user_id: pr.user_id,\n email: pr.email,\n token: pr.token,\n expires_at: pr.expires_at,\n created_at: pr.created_at,\n updated_at: pr.updated_at,\n };\n}\n\nexport function formatMagicAuth(ma: WorkOSMagicAuth): Record<string, unknown> {\n return {\n object: 'magic_auth',\n id: ma.id,\n user_id: ma.user_id,\n email: ma.email,\n code: ma.code,\n expires_at: ma.expires_at,\n created_at: ma.created_at,\n updated_at: ma.updated_at,\n };\n}\n\nexport function formatAuthFactor(f: WorkOSAuthenticationFactor): Record<string, unknown> {\n return {\n object: 'authentication_factor',\n id: f.id,\n user_id: f.user_id,\n type: f.type,\n totp: f.totp,\n created_at: f.created_at,\n updated_at: f.updated_at,\n };\n}\n\nexport function formatIdentity(i: WorkOSIdentity): Record<string, unknown> {\n return {\n object: 'identity',\n id: i.id,\n user_id: i.user_id,\n provider: i.provider,\n provider_id: i.provider_id,\n type: i.type,\n created_at: i.created_at,\n updated_at: i.updated_at,\n };\n}\n\nexport function generateVerificationToken(): string {\n return randomBytes(16).toString('hex');\n}\n\nexport function generateCode(): string {\n return String(Math.floor(100000 + Math.random() * 900000));\n}\n\nexport function hashPassword(password: string): string {\n return createHash('sha256').update(password).digest('hex');\n}\n\nexport function verifyPassword(password: string, hash: string): boolean {\n return hashPassword(password) === hash;\n}\n\nexport function expiresIn(minutes: number): string {\n return new Date(Date.now() + minutes * 60 * 1000).toISOString();\n}\n\nexport function isExpired(expiresAt: string): boolean {\n return new Date(expiresAt).getTime() < Date.now();\n}\n\nexport function formatConnection(conn: WorkOSConnection): Record<string, unknown> {\n return {\n object: 'connection',\n id: conn.id,\n organization_id: conn.organization_id,\n connection_type: conn.connection_type,\n name: conn.name,\n state: conn.state,\n domains: conn.domains,\n created_at: conn.created_at,\n updated_at: conn.updated_at,\n };\n}\n\nexport function formatSSOProfile(p: WorkOSSSOProfile): Record<string, unknown> {\n return {\n object: 'profile',\n id: p.id,\n connection_id: p.connection_id,\n connection_type: p.connection_type,\n organization_id: p.organization_id,\n idp_id: p.idp_id,\n email: p.email,\n first_name: p.first_name,\n last_name: p.last_name,\n groups: p.groups,\n raw_attributes: p.raw_attributes,\n created_at: p.created_at,\n updated_at: p.updated_at,\n };\n}\n\nexport function formatPipeConnection(pc: WorkOSPipeConnection): Record<string, unknown> {\n return {\n object: 'pipe_connection',\n id: pc.id,\n user_id: pc.user_id,\n provider: pc.provider,\n scopes: pc.scopes,\n status: pc.status,\n external_account_id: pc.external_account_id,\n created_at: pc.created_at,\n updated_at: pc.updated_at,\n };\n}\n\nexport function formatInvitation(inv: WorkOSInvitation): Record<string, unknown> {\n return {\n object: 'invitation',\n id: inv.id,\n email: inv.email,\n state: inv.state,\n token: inv.token,\n accept_invitation_url: inv.accept_invitation_url,\n organization_id: inv.organization_id,\n inviter_user_id: inv.inviter_user_id,\n role_slug: inv.role_slug,\n expires_at: inv.expires_at,\n created_at: inv.created_at,\n updated_at: inv.updated_at,\n };\n}\n\nexport function formatRedirectUri(r: WorkOSRedirectUri): Record<string, unknown> {\n return {\n object: 'redirect_uri',\n id: r.id,\n uri: r.uri,\n created_at: r.created_at,\n updated_at: r.updated_at,\n };\n}\n\nexport function formatCorsOrigin(o: WorkOSCorsOrigin): Record<string, unknown> {\n return {\n object: 'cors_origin',\n id: o.id,\n origin: o.origin,\n created_at: o.created_at,\n updated_at: o.updated_at,\n };\n}\n\nexport function formatAuthorizedApplication(a: WorkOSAuthorizedApplication): Record<string, unknown> {\n return {\n object: 'authorized_application',\n id: a.id,\n user_id: a.user_id,\n name: a.name,\n redirect_uri: a.redirect_uri,\n created_at: a.created_at,\n updated_at: a.updated_at,\n };\n}\n\nexport function formatConnectedAccount(a: WorkOSConnectedAccount): Record<string, unknown> {\n return {\n object: 'connected_account',\n id: a.id,\n user_id: a.user_id,\n provider: a.provider,\n provider_id: a.provider_id,\n created_at: a.created_at,\n updated_at: a.updated_at,\n };\n}\n\nexport function parseListParams(url: URL) {\n const limit = Math.max(1, Math.min(parseInt(url.searchParams.get('limit') ?? '10'), 100));\n const order = (url.searchParams.get('order') as 'asc' | 'desc') ?? 'desc';\n const before = url.searchParams.get('before') ?? undefined;\n const after = url.searchParams.get('after') ?? undefined;\n return { limit, order, before, after };\n}\n\n/** Allowed redirect URI hosts for the emulator's authorize endpoints. */\nconst ALLOWED_REDIRECT_HOSTS = new Set(['localhost', '127.0.0.1', '[::1]']);\n\n/**\n * Validate that a redirect_uri points to a localhost origin.\n * Prevents the emulator from being used as an open redirect.\n */\nexport function assertLocalRedirectUri(uri: string): void {\n let parsed: URL;\n try {\n parsed = new URL(uri);\n } catch {\n throw new WorkOSApiError(400, 'Invalid redirect_uri', 'invalid_redirect_uri');\n }\n if (!ALLOWED_REDIRECT_HOSTS.has(parsed.hostname)) {\n throw new WorkOSApiError(\n 400,\n `redirect_uri must point to localhost, got ${parsed.hostname}`,\n 'invalid_redirect_uri',\n );\n }\n}\n\nexport function formatAuthChallenge(c: WorkOSAuthenticationChallenge): Record<string, unknown> {\n return {\n object: 'authentication_challenge',\n id: c.id,\n user_id: c.user_id,\n factor_id: c.factor_id,\n expires_at: c.expires_at,\n created_at: c.created_at,\n updated_at: c.updated_at,\n };\n}\n\nexport function formatRole(role: WorkOSRole): Record<string, unknown> {\n return {\n object: 'role',\n id: role.id,\n slug: role.slug,\n name: role.name,\n description: role.description,\n type: role.type,\n organization_id: role.organization_id,\n is_default_role: role.is_default_role,\n priority: role.priority,\n created_at: role.created_at,\n updated_at: role.updated_at,\n };\n}\n\nexport function formatPermission(p: WorkOSPermission): Record<string, unknown> {\n return {\n object: 'permission',\n id: p.id,\n slug: p.slug,\n name: p.name,\n description: p.description,\n created_at: p.created_at,\n updated_at: p.updated_at,\n };\n}\n\nexport function formatAuthorizationResource(r: WorkOSAuthorizationResource): Record<string, unknown> {\n return {\n object: 'authorization_resource',\n id: r.id,\n resource_type_slug: r.resource_type_slug,\n external_id: r.external_id,\n organization_id: r.organization_id,\n metadata: r.metadata,\n created_at: r.created_at,\n updated_at: r.updated_at,\n };\n}\n\nexport function formatRoleAssignment(ra: WorkOSRoleAssignment): Record<string, unknown> {\n return {\n object: 'role_assignment',\n id: ra.id,\n organization_membership_id: ra.organization_membership_id,\n role_id: ra.role_id,\n created_at: ra.created_at,\n updated_at: ra.updated_at,\n };\n}\n\nexport function formatDeviceAuthorization(d: WorkOSDeviceAuthorization): Record<string, unknown> {\n return {\n device_code: d.device_code,\n user_code: d.user_code,\n verification_uri: 'http://localhost:0/user_management/authorize/device/verify',\n expires_in: Math.max(0, Math.floor((new Date(d.expires_at).getTime() - Date.now()) / 1000)),\n interval: d.interval,\n };\n}\n\n// --- Phase 4: CRUD Domain formatters ---\n\nexport function formatDirectory(d: WorkOSDirectory): Record<string, unknown> {\n return {\n object: 'directory',\n id: d.id,\n name: d.name,\n organization_id: d.organization_id,\n domain: d.domain,\n type: d.type,\n state: d.state,\n external_key: d.external_key,\n created_at: d.created_at,\n updated_at: d.updated_at,\n };\n}\n\nexport function formatDirectoryUser(u: WorkOSDirectoryUser): Record<string, unknown> {\n return {\n object: 'directory_user',\n id: u.id,\n directory_id: u.directory_id,\n organization_id: u.organization_id,\n idp_id: u.idp_id,\n first_name: u.first_name,\n last_name: u.last_name,\n email: u.email,\n username: u.username,\n state: u.state,\n role: u.role,\n custom_attributes: u.custom_attributes,\n raw_attributes: u.raw_attributes,\n groups: u.groups,\n created_at: u.created_at,\n updated_at: u.updated_at,\n };\n}\n\nexport function formatDirectoryGroup(g: WorkOSDirectoryGroup): Record<string, unknown> {\n return {\n object: 'directory_group',\n id: g.id,\n directory_id: g.directory_id,\n organization_id: g.organization_id,\n idp_id: g.idp_id,\n name: g.name,\n raw_attributes: g.raw_attributes,\n created_at: g.created_at,\n updated_at: g.updated_at,\n };\n}\n\nexport function formatAuditLogAction(a: WorkOSAuditLogAction): Record<string, unknown> {\n return {\n object: 'audit_log_action',\n id: a.id,\n name: a.name,\n description: a.description,\n condition: a.condition,\n created_at: a.created_at,\n updated_at: a.updated_at,\n };\n}\n\nexport function formatAuditLogEvent(e: WorkOSAuditLogEvent): Record<string, unknown> {\n return {\n object: 'audit_log_event',\n id: e.id,\n organization_id: e.organization_id,\n action: e.action,\n actor: e.actor,\n targets: e.targets,\n metadata: e.metadata,\n occurred_at: e.occurred_at,\n created_at: e.created_at,\n updated_at: e.updated_at,\n };\n}\n\nexport function formatAuditLogExport(ex: WorkOSAuditLogExport): Record<string, unknown> {\n return {\n object: 'audit_log_export',\n id: ex.id,\n organization_id: ex.organization_id,\n state: ex.state,\n url: ex.url,\n filters: ex.filters,\n created_at: ex.created_at,\n updated_at: ex.updated_at,\n };\n}\n\nexport function formatFeatureFlag(f: WorkOSFeatureFlag): Record<string, unknown> {\n return {\n object: 'feature_flag',\n id: f.id,\n slug: f.slug,\n name: f.name,\n description: f.description,\n type: f.type,\n default_value: f.default_value,\n enabled: f.enabled,\n created_at: f.created_at,\n updated_at: f.updated_at,\n };\n}\n\nexport function formatConnectApplication(a: WorkOSConnectApplication): Record<string, unknown> {\n return {\n object: 'connect_application',\n id: a.id,\n name: a.name,\n redirect_uris: a.redirect_uris,\n client_id: a.client_id,\n logo_url: a.logo_url,\n created_at: a.created_at,\n updated_at: a.updated_at,\n };\n}\n\nexport function formatClientSecret(s: WorkOSClientSecret): Record<string, unknown> {\n return {\n object: 'client_secret',\n id: s.id,\n application_id: s.application_id,\n last_four: s.last_four,\n created_at: s.created_at,\n updated_at: s.updated_at,\n };\n}\n\nexport function formatRadarAttempt(a: WorkOSRadarAttempt): Record<string, unknown> {\n return {\n object: 'radar_attempt',\n id: a.id,\n user_id: a.user_id,\n ip_address: a.ip_address,\n user_agent: a.user_agent,\n verdict: a.verdict,\n signals: a.signals,\n created_at: a.created_at,\n updated_at: a.updated_at,\n };\n}\n\nexport function formatApiKeyRecord(k: WorkOSApiKey): Record<string, unknown> {\n return {\n object: 'api_key',\n id: k.id,\n name: k.name,\n created_at: k.created_at,\n updated_at: k.updated_at,\n };\n}\n\nexport function formatEvent(e: WorkOSEvent): Record<string, unknown> {\n return {\n object: 'event',\n id: e.id,\n event: e.event,\n data: e.data,\n environment_id: e.environment_id,\n created_at: e.created_at,\n };\n}\n\nexport function formatWebhookEndpoint(\n ep: WorkOSWebhookEndpoint,\n opts?: { includeSecret?: boolean },\n): Record<string, unknown> {\n return {\n object: 'webhook_endpoint',\n id: ep.id,\n url: ep.url,\n secret: opts?.includeSecret ? ep.secret : `${ep.secret.slice(0, 8)}****`,\n enabled: ep.enabled,\n events: ep.events,\n description: ep.description,\n created_at: ep.created_at,\n updated_at: ep.updated_at,\n };\n}\n\nexport function sealSession(\n data: { access_token: string; refresh_token: string; session_id: string },\n apiKey: string,\n): string {\n const key = createHash('sha256').update(apiKey).digest();\n const iv = randomBytes(12);\n const cipher = createCipheriv('aes-256-gcm', key, iv);\n const plaintext = JSON.stringify(data);\n const encrypted = Buffer.concat([cipher.update(plaintext, 'utf8'), cipher.final()]);\n const tag = cipher.getAuthTag();\n return Buffer.concat([iv, tag, encrypted]).toString('base64');\n}\n"]}
@@ -0,0 +1,91 @@
1
+ import type { ServicePlugin, Store } from '../core/index.js';
2
+ import type { WorkOSConnectionType, PipeProvider, PipeConnectionStatus } from './entities.js';
3
+ export { getWorkOSStore, type WorkOSStore } from './store.js';
4
+ export * from './entities.js';
5
+ export interface WorkOSSeedOrganization {
6
+ name: string;
7
+ external_id?: string;
8
+ metadata?: Record<string, string>;
9
+ domains?: Array<{
10
+ domain: string;
11
+ state?: 'verified' | 'pending';
12
+ }>;
13
+ memberships?: Array<{
14
+ user_id: string;
15
+ role?: string;
16
+ status?: 'active' | 'inactive' | 'pending';
17
+ }>;
18
+ }
19
+ export interface WorkOSSeedUser {
20
+ email: string;
21
+ first_name?: string;
22
+ last_name?: string;
23
+ password?: string;
24
+ email_verified?: boolean;
25
+ external_id?: string;
26
+ metadata?: Record<string, string>;
27
+ impersonator?: {
28
+ email: string;
29
+ reason: string;
30
+ };
31
+ }
32
+ export interface WorkOSSeedConnection {
33
+ name: string;
34
+ connection_type?: WorkOSConnectionType;
35
+ organization: string;
36
+ state?: 'active' | 'inactive' | 'validating';
37
+ domains?: string[];
38
+ profiles?: Array<{
39
+ email: string;
40
+ first_name?: string;
41
+ last_name?: string;
42
+ idp_id?: string;
43
+ groups?: string[];
44
+ }>;
45
+ }
46
+ export interface WorkOSSeedPipeConnection {
47
+ user_id: string;
48
+ provider: PipeProvider;
49
+ scopes: string[];
50
+ status?: PipeConnectionStatus;
51
+ external_account_id?: string;
52
+ }
53
+ export interface WorkOSSeedInvitation {
54
+ email: string;
55
+ organization_id?: string;
56
+ inviter_user_id?: string;
57
+ role_slug?: string;
58
+ }
59
+ export interface WorkOSSeedRole {
60
+ slug: string;
61
+ name: string;
62
+ description?: string;
63
+ type?: 'EnvironmentRole' | 'OrganizationRole';
64
+ organization_id?: string;
65
+ is_default_role?: boolean;
66
+ priority?: number;
67
+ permissions?: string[];
68
+ }
69
+ export interface WorkOSSeedPermission {
70
+ slug: string;
71
+ name: string;
72
+ description?: string;
73
+ }
74
+ export interface WorkOSSeedWebhookEndpoint {
75
+ url: string;
76
+ events?: string[];
77
+ enabled?: boolean;
78
+ }
79
+ export interface WorkOSSeedConfig {
80
+ organizations?: WorkOSSeedOrganization[];
81
+ users?: WorkOSSeedUser[];
82
+ connections?: WorkOSSeedConnection[];
83
+ pipeConnections?: WorkOSSeedPipeConnection[];
84
+ invitations?: WorkOSSeedInvitation[];
85
+ roles?: WorkOSSeedRole[];
86
+ permissions?: WorkOSSeedPermission[];
87
+ webhookEndpoints?: WorkOSSeedWebhookEndpoint[];
88
+ }
89
+ export declare function seedFromConfig(store: Store, _baseUrl: string, config: WorkOSSeedConfig): void;
90
+ export declare const workosPlugin: ServicePlugin;
91
+ export default workosPlugin;