@boxyhq/saml-jackson 1.3.6 → 1.3.8

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 (106) hide show
  1. package/dist/controller/admin.js +1 -0
  2. package/dist/controller/admin.js.map +1 -0
  3. package/dist/controller/api.d.ts +14 -0
  4. package/dist/controller/api.js +15 -0
  5. package/dist/controller/api.js.map +1 -0
  6. package/dist/controller/connection/oidc.js +1 -0
  7. package/dist/controller/connection/oidc.js.map +1 -0
  8. package/dist/controller/connection/saml.js +27 -9
  9. package/dist/controller/connection/saml.js.map +1 -0
  10. package/dist/controller/error.js +1 -0
  11. package/dist/controller/error.js.map +1 -0
  12. package/dist/controller/health-check.js +1 -0
  13. package/dist/controller/health-check.js.map +1 -0
  14. package/dist/controller/logout.js +1 -0
  15. package/dist/controller/logout.js.map +1 -0
  16. package/dist/controller/oauth/allowed.js +1 -0
  17. package/dist/controller/oauth/allowed.js.map +1 -0
  18. package/dist/controller/oauth/code-verifier.js +1 -0
  19. package/dist/controller/oauth/code-verifier.js.map +1 -0
  20. package/dist/controller/oauth/redirect.js +1 -0
  21. package/dist/controller/oauth/redirect.js.map +1 -0
  22. package/dist/controller/oauth.js +4 -0
  23. package/dist/controller/oauth.js.map +1 -0
  24. package/dist/controller/oidc-discovery.js +1 -0
  25. package/dist/controller/oidc-discovery.js.map +1 -0
  26. package/dist/controller/sp-config.d.ts +1 -0
  27. package/dist/controller/sp-config.js +55 -0
  28. package/dist/controller/sp-config.js.map +1 -0
  29. package/dist/controller/utils.js +4 -2
  30. package/dist/controller/utils.js.map +1 -0
  31. package/dist/db/db.js +1 -0
  32. package/dist/db/db.js.map +1 -0
  33. package/dist/db/defaultDb.js +1 -0
  34. package/dist/db/defaultDb.js.map +1 -0
  35. package/dist/db/encrypter.js +1 -0
  36. package/dist/db/encrypter.js.map +1 -0
  37. package/dist/db/mem.js +1 -0
  38. package/dist/db/mem.js.map +1 -0
  39. package/dist/db/mongo.js +1 -0
  40. package/dist/db/mongo.js.map +1 -0
  41. package/dist/db/planetscale/entity/JacksonIndex.js +1 -0
  42. package/dist/db/planetscale/entity/JacksonIndex.js.map +1 -0
  43. package/dist/db/planetscale/entity/JacksonStore.js +1 -0
  44. package/dist/db/planetscale/entity/JacksonStore.js.map +1 -0
  45. package/dist/db/planetscale/entity/JacksonTTL.js +1 -0
  46. package/dist/db/planetscale/entity/JacksonTTL.js.map +1 -0
  47. package/dist/db/redis.js +17 -9
  48. package/dist/db/redis.js.map +1 -0
  49. package/dist/db/sql/entity/JacksonIndex.js +1 -0
  50. package/dist/db/sql/entity/JacksonIndex.js.map +1 -0
  51. package/dist/db/sql/entity/JacksonStore.js +1 -0
  52. package/dist/db/sql/entity/JacksonStore.js.map +1 -0
  53. package/dist/db/sql/entity/JacksonTTL.js +1 -0
  54. package/dist/db/sql/entity/JacksonTTL.js.map +1 -0
  55. package/dist/db/sql/mssql/entity/JacksonIndex.js +1 -0
  56. package/dist/db/sql/mssql/entity/JacksonIndex.js.map +1 -0
  57. package/dist/db/sql/mssql/entity/JacksonStore.js +1 -0
  58. package/dist/db/sql/mssql/entity/JacksonStore.js.map +1 -0
  59. package/dist/db/sql/mssql/entity/JacksonTTL.js +1 -0
  60. package/dist/db/sql/mssql/entity/JacksonTTL.js.map +1 -0
  61. package/dist/db/sql/mssql.js +1 -0
  62. package/dist/db/sql/mssql.js.map +1 -0
  63. package/dist/db/sql/sql.js +1 -0
  64. package/dist/db/sql/sql.js.map +1 -0
  65. package/dist/db/store.js +1 -0
  66. package/dist/db/store.js.map +1 -0
  67. package/dist/db/utils.js +1 -0
  68. package/dist/db/utils.js.map +1 -0
  69. package/dist/directory-sync/Base.js +1 -0
  70. package/dist/directory-sync/Base.js.map +1 -0
  71. package/dist/directory-sync/DirectoryConfig.js +1 -0
  72. package/dist/directory-sync/DirectoryConfig.js.map +1 -0
  73. package/dist/directory-sync/DirectoryGroups.js +1 -0
  74. package/dist/directory-sync/DirectoryGroups.js.map +1 -0
  75. package/dist/directory-sync/DirectoryUsers.js +1 -0
  76. package/dist/directory-sync/DirectoryUsers.js.map +1 -0
  77. package/dist/directory-sync/Groups.js +1 -0
  78. package/dist/directory-sync/Groups.js.map +1 -0
  79. package/dist/directory-sync/Users.js +1 -0
  80. package/dist/directory-sync/Users.js.map +1 -0
  81. package/dist/directory-sync/WebhookEventsLogger.js +1 -0
  82. package/dist/directory-sync/WebhookEventsLogger.js.map +1 -0
  83. package/dist/directory-sync/events.js +1 -0
  84. package/dist/directory-sync/events.js.map +1 -0
  85. package/dist/directory-sync/index.js +1 -0
  86. package/dist/directory-sync/index.js.map +1 -0
  87. package/dist/directory-sync/request.js +1 -0
  88. package/dist/directory-sync/request.js.map +1 -0
  89. package/dist/directory-sync/transform.js +1 -0
  90. package/dist/directory-sync/transform.js.map +1 -0
  91. package/dist/directory-sync/utils.js +1 -0
  92. package/dist/directory-sync/utils.js.map +1 -0
  93. package/dist/index.js +1 -0
  94. package/dist/index.js.map +1 -0
  95. package/dist/loadConnection.js +3 -1
  96. package/dist/loadConnection.js.map +1 -0
  97. package/dist/opentelemetry/metrics.js +1 -0
  98. package/dist/opentelemetry/metrics.js.map +1 -0
  99. package/dist/saml/claims.js +1 -0
  100. package/dist/saml/claims.js.map +1 -0
  101. package/dist/saml/x509.js +1 -0
  102. package/dist/saml/x509.js.map +1 -0
  103. package/dist/typings.d.ts +28 -23
  104. package/dist/typings.js +1 -0
  105. package/dist/typings.js.map +1 -0
  106. package/package.json +11 -11
package/dist/typings.d.ts CHANGED
@@ -13,10 +13,12 @@ export interface SAMLSSOConnection extends SSOConnection {
13
13
  export interface SAMLSSOConnectionWithRawMetadata extends SAMLSSOConnection {
14
14
  rawMetadata: string;
15
15
  encodedRawMetadata?: never;
16
+ metadataUrl?: string;
16
17
  }
17
18
  export interface SAMLSSOConnectionWithEncodedMetadata extends SAMLSSOConnection {
18
19
  rawMetadata?: never;
19
20
  encodedRawMetadata: string;
21
+ metadataUrl?: string;
20
22
  }
21
23
  export interface OIDCSSOConnection extends SSOConnection {
22
24
  oidcDiscoveryUrl: string;
@@ -26,6 +28,7 @@ export interface OIDCSSOConnection extends SSOConnection {
26
28
  export interface SAMLSSORecord extends SAMLSSOConnection {
27
29
  clientID: string;
28
30
  clientSecret: string;
31
+ metadataUrl?: string;
29
32
  idpMetadata: {
30
33
  entityID: string;
31
34
  loginType?: string;
@@ -52,21 +55,21 @@ export interface OIDCSSORecord extends SSOConnection {
52
55
  clientSecret?: string;
53
56
  };
54
57
  }
55
- export declare type ConnectionType = 'saml' | 'oidc';
56
- declare type ClientIDQuery = {
58
+ export type ConnectionType = 'saml' | 'oidc';
59
+ type ClientIDQuery = {
57
60
  clientID: string;
58
61
  };
59
- declare type TenantQuery = {
62
+ type TenantQuery = {
60
63
  tenant: string;
61
64
  product: string;
62
65
  strategy?: ConnectionType;
63
66
  };
64
- export declare type GetConnectionsQuery = ClientIDQuery | TenantQuery;
65
- export declare type DelConnectionsQuery = (ClientIDQuery & {
67
+ export type GetConnectionsQuery = ClientIDQuery | TenantQuery;
68
+ export type DelConnectionsQuery = (ClientIDQuery & {
66
69
  clientSecret: string;
67
70
  }) | TenantQuery;
68
- export declare type GetConfigQuery = ClientIDQuery | Omit<TenantQuery, 'strategy'>;
69
- export declare type DelConfigQuery = (ClientIDQuery & {
71
+ export type GetConfigQuery = ClientIDQuery | Omit<TenantQuery, 'strategy'>;
72
+ export type DelConfigQuery = (ClientIDQuery & {
70
73
  clientSecret: string;
71
74
  }) | Omit<TenantQuery, 'strategy'>;
72
75
  export interface IConnectionAPIController {
@@ -177,7 +180,7 @@ export interface OAuthReqBodyWithResource extends OAuthReqBody {
177
180
  client_id: 'dummy';
178
181
  resource: string;
179
182
  }
180
- export declare type OAuthReq = OAuthReqBodyWithClientId | OAuthReqBodyWithTenantProduct | OAuthReqBodyWithAccessType | OAuthReqBodyWithResource;
183
+ export type OAuthReq = OAuthReqBodyWithClientId | OAuthReqBodyWithTenantProduct | OAuthReqBodyWithAccessType | OAuthReqBodyWithResource;
181
184
  export interface SAMLResponsePayload {
182
185
  SAMLResponse: string;
183
186
  RelayState: string;
@@ -195,7 +198,7 @@ interface OIDCAuthzResponseError {
195
198
  error: OAuthErrorHandlerParams['error'] | OIDCErrorCodes;
196
199
  error_description?: string;
197
200
  }
198
- export declare type OIDCAuthzResponsePayload = OIDCAuthzResponseSuccess | OIDCAuthzResponseError;
201
+ export type OIDCAuthzResponsePayload = OIDCAuthzResponseSuccess | OIDCAuthzResponseError;
199
202
  interface OAuthTokenReqBody {
200
203
  code: string;
201
204
  grant_type: 'authorization_code';
@@ -211,7 +214,7 @@ export interface OAuthTokenReqWithCredentials extends OAuthTokenReqBody {
211
214
  client_id: string;
212
215
  client_secret: string;
213
216
  }
214
- export declare type OAuthTokenReq = OAuthTokenReqWithCodeVerifier | OAuthTokenReqWithCredentials;
217
+ export type OAuthTokenReq = OAuthTokenReqWithCodeVerifier | OAuthTokenReqWithCredentials;
215
218
  export interface OAuthTokenRes {
216
219
  access_token: string;
217
220
  id_token?: string;
@@ -220,6 +223,7 @@ export interface OAuthTokenRes {
220
223
  }
221
224
  export interface Profile {
222
225
  id: string;
226
+ idHash: string;
223
227
  sub?: string;
224
228
  email: string;
225
229
  firstName: string;
@@ -255,9 +259,9 @@ export interface Encrypted {
255
259
  tag?: string;
256
260
  value: string;
257
261
  }
258
- export declare type EncryptionKey = any;
259
- export declare type DatabaseEngine = 'redis' | 'sql' | 'mongo' | 'mem' | 'planetscale';
260
- export declare type DatabaseType = 'postgres' | 'mysql' | 'mariadb' | 'mssql';
262
+ export type EncryptionKey = any;
263
+ export type DatabaseEngine = 'redis' | 'sql' | 'mongo' | 'mem' | 'planetscale';
264
+ export type DatabaseType = 'postgres' | 'mysql' | 'mariadb' | 'mssql';
261
265
  export interface DatabaseOption {
262
266
  engine?: DatabaseEngine;
263
267
  url?: string;
@@ -318,7 +322,7 @@ export interface OAuthErrorHandlerParams {
318
322
  redirect_uri: string;
319
323
  state?: string;
320
324
  }
321
- export declare type OIDCErrorCodes = 'interaction_required' | 'login_required' | 'account_selection_required' | 'consent_required' | 'invalid_request_uri' | 'invalid_request_object' | 'request_not_supported' | 'request_uri_not_supported' | 'registration_not_supported';
325
+ export type OIDCErrorCodes = 'interaction_required' | 'login_required' | 'account_selection_required' | 'consent_required' | 'invalid_request_uri' | 'invalid_request_object' | 'request_not_supported' | 'request_uri_not_supported' | 'registration_not_supported';
322
326
  export interface ISPSAMLConfig {
323
327
  get(): Promise<{
324
328
  acsUrl: string;
@@ -331,8 +335,9 @@ export interface ISPSAMLConfig {
331
335
  }>;
332
336
  toMarkdown(): string;
333
337
  toHTML(): string;
338
+ toXMLMetadata(): Promise<string>;
334
339
  }
335
- export declare type DirectorySyncEventType = 'user.created' | 'user.updated' | 'user.deleted' | 'group.created' | 'group.updated' | 'group.deleted' | 'group.user_added' | 'group.user_removed';
340
+ export type DirectorySyncEventType = 'user.created' | 'user.updated' | 'user.deleted' | 'group.created' | 'group.updated' | 'group.deleted' | 'group.user_added' | 'group.user_removed';
336
341
  export interface Base {
337
342
  store(type: 'groups' | 'members' | 'users'): Storable;
338
343
  setTenant(tenant: string): this;
@@ -425,7 +430,7 @@ export interface Groups extends Base {
425
430
  error: ApiError | null;
426
431
  }>;
427
432
  }
428
- export declare type User = {
433
+ export type User = {
429
434
  id: string;
430
435
  email: string;
431
436
  first_name: string;
@@ -433,7 +438,7 @@ export declare type User = {
433
438
  active: boolean;
434
439
  raw?: any;
435
440
  };
436
- export declare type Group = {
441
+ export type Group = {
437
442
  id: string;
438
443
  name: string;
439
444
  raw?: any;
@@ -445,9 +450,9 @@ export declare enum DirectorySyncProviders {
445
450
  'jumpcloud-scim-v2' = "JumpCloud v2.0",
446
451
  'generic-scim-v2' = "SCIM Generic v2.0"
447
452
  }
448
- export declare type DirectoryType = keyof typeof DirectorySyncProviders;
449
- export declare type HTTPMethod = 'POST' | 'PUT' | 'DELETE' | 'GET' | 'PATCH';
450
- export declare type Directory = {
453
+ export type DirectoryType = keyof typeof DirectorySyncProviders;
454
+ export type HTTPMethod = 'POST' | 'PUT' | 'DELETE' | 'GET' | 'PATCH';
455
+ export type Directory = {
451
456
  id: string;
452
457
  name: string;
453
458
  tenant: string;
@@ -464,7 +469,7 @@ export declare type Directory = {
464
469
  secret: string;
465
470
  };
466
471
  };
467
- export declare type DirectorySyncGroupMember = {
472
+ export type DirectorySyncGroupMember = {
468
473
  value: string;
469
474
  email?: string;
470
475
  };
@@ -537,7 +542,7 @@ export interface IWebhookEventsLogger extends Base {
537
542
  delete(id: string): Promise<void>;
538
543
  updateStatus(log: WebhookEventLog, statusCode: number): Promise<WebhookEventLog>;
539
544
  }
540
- export declare type DirectorySyncResponse = {
545
+ export type DirectorySyncResponse = {
541
546
  status: number;
542
547
  data?: any;
543
548
  };
@@ -560,7 +565,7 @@ export interface DirectorySyncRequest {
560
565
  filter?: string;
561
566
  };
562
567
  }
563
- export declare type DirectorySync = {
568
+ export type DirectorySync = {
564
569
  requests: DirectorySyncRequestHandler;
565
570
  directories: DirectoryConfig;
566
571
  groups: Groups;
package/dist/typings.js CHANGED
@@ -9,3 +9,4 @@ var DirectorySyncProviders;
9
9
  DirectorySyncProviders["jumpcloud-scim-v2"] = "JumpCloud v2.0";
10
10
  DirectorySyncProviders["generic-scim-v2"] = "SCIM Generic v2.0";
11
11
  })(DirectorySyncProviders = exports.DirectorySyncProviders || (exports.DirectorySyncProviders = {}));
12
+ //# sourceMappingURL=typings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"typings.js","sourceRoot":"","sources":["../src/typings.ts"],"names":[],"mappings":";;;AAueA,IAAY,sBAMX;AAND,WAAY,sBAAsB;IAChC,2DAAmC,CAAA;IACnC,iEAAyC,CAAA;IACzC,yDAAiC,CAAA;IACjC,8DAAsC,CAAA;IACtC,+DAAuC,CAAA;AACzC,CAAC,EANW,sBAAsB,GAAtB,8BAAsB,KAAtB,8BAAsB,QAMjC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@boxyhq/saml-jackson",
3
- "version": "1.3.6",
3
+ "version": "1.3.8",
4
4
  "description": "SAML Jackson library",
5
5
  "keywords": [
6
6
  "SAML 2.0"
@@ -40,19 +40,19 @@
40
40
  "statements": 70
41
41
  },
42
42
  "dependencies": {
43
- "@boxyhq/saml20": "1.0.11",
43
+ "@boxyhq/saml20": "1.0.14",
44
44
  "@opentelemetry/api": "1.0.4",
45
45
  "@opentelemetry/api-metrics": "0.27.0",
46
46
  "axios": "1.1.3",
47
- "jose": "4.10.4",
48
- "marked": "4.2.2",
47
+ "jose": "4.11.0",
48
+ "marked": "4.2.3",
49
49
  "mongodb": "4.11.0",
50
50
  "mssql": "9.0.1",
51
51
  "mysql2": "2.3.3",
52
52
  "node-forge": "1.3.1",
53
- "openid-client": "5.2.1",
53
+ "openid-client": "5.3.0",
54
54
  "pg": "8.8.0",
55
- "redis": "4.4.0",
55
+ "redis": "4.5.0",
56
56
  "reflect-metadata": "0.1.13",
57
57
  "ripemd160": "2.0.2",
58
58
  "typeorm": "0.3.10",
@@ -64,17 +64,17 @@
64
64
  "@types/node": "18.11.9",
65
65
  "@types/sinon": "10.0.13",
66
66
  "@types/tap": "15.0.7",
67
- "@typescript-eslint/eslint-plugin": "5.42.0",
68
- "@typescript-eslint/parser": "5.42.0",
67
+ "@typescript-eslint/eslint-plugin": "5.43.0",
68
+ "@typescript-eslint/parser": "5.42.1",
69
69
  "cross-env": "7.0.3",
70
- "eslint": "8.27.0",
70
+ "eslint": "8.28.0",
71
71
  "eslint-config-prettier": "8.5.0",
72
72
  "prettier": "2.7.1",
73
- "sinon": "14.0.1",
73
+ "sinon": "14.0.2",
74
74
  "tap": "16.3.0",
75
75
  "ts-node": "10.9.1",
76
76
  "tsconfig-paths": "4.1.0",
77
- "typescript": "4.8.4"
77
+ "typescript": "4.9.3"
78
78
  },
79
79
  "engines": {
80
80
  "node": ">=14.18.1 <=18.x"