@boxyhq/saml-jackson 1.32.0 → 1.33.1-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.
- package/dist/controller/api.js +17 -7
- package/dist/controller/api.js.map +1 -1
- package/dist/controller/connection/oidc.js +17 -7
- package/dist/controller/connection/oidc.js.map +1 -1
- package/dist/controller/connection/saml.js +17 -7
- package/dist/controller/connection/saml.js.map +1 -1
- package/dist/controller/logout.js +17 -7
- package/dist/controller/logout.js.map +1 -1
- package/dist/controller/oauth/oidc-client.d.ts +9 -4
- package/dist/controller/oauth/oidc-client.js +80 -11
- package/dist/controller/oauth/oidc-client.js.map +1 -1
- package/dist/controller/oauth/oidc-issuer.d.ts +2 -0
- package/dist/controller/oauth/oidc-issuer.js +25 -0
- package/dist/controller/oauth/oidc-issuer.js.map +1 -0
- package/dist/controller/oauth.js +97 -46
- package/dist/controller/oauth.js.map +1 -1
- package/dist/controller/setup-link.js +17 -7
- package/dist/controller/setup-link.js.map +1 -1
- package/dist/controller/sso-handler.d.ts +10 -2
- package/dist/controller/sso-handler.js +34 -12
- package/dist/controller/sso-handler.js.map +1 -1
- package/dist/controller/utils.d.ts +5 -3
- package/dist/controller/utils.js +27 -9
- package/dist/controller/utils.js.map +1 -1
- package/dist/db/db.js +17 -7
- package/dist/db/db.js.map +1 -1
- package/dist/db/dynamoDb.js +17 -7
- package/dist/db/dynamoDb.js.map +1 -1
- package/dist/db/mem.js +17 -7
- package/dist/db/mem.js.map +1 -1
- package/dist/db/mongo.js +17 -7
- package/dist/db/mongo.js.map +1 -1
- package/dist/db/redis.js +17 -7
- package/dist/db/redis.js.map +1 -1
- package/dist/db/sql/sql.js +17 -7
- package/dist/db/sql/sql.js.map +1 -1
- package/dist/db/store.js +17 -7
- package/dist/db/store.js.map +1 -1
- package/dist/directory-sync/batch-events/queue.js +17 -7
- package/dist/directory-sync/batch-events/queue.js.map +1 -1
- package/dist/directory-sync/scim/DirectoryConfig.js +17 -7
- package/dist/directory-sync/scim/DirectoryConfig.js.map +1 -1
- package/dist/directory-sync/scim/Groups.js +17 -7
- package/dist/directory-sync/scim/Groups.js.map +1 -1
- package/dist/ee/identity-federation/idp-login.js +20 -14
- package/dist/ee/identity-federation/idp-login.js.map +1 -1
- package/dist/ee/identity-federation/sso.js +16 -11
- package/dist/ee/identity-federation/sso.js.map +1 -1
- package/dist/event/axios.d.ts +2 -1
- package/dist/index.js +17 -7
- package/dist/index.js.map +1 -1
- package/dist/loadConnection.js +17 -7
- package/dist/loadConnection.js.map +1 -1
- package/dist/saml/lib.js +17 -7
- package/dist/saml/lib.js.map +1 -1
- package/dist/saml/x509.js +17 -7
- package/dist/saml/x509.js.map +1 -1
- package/dist/src/controller/admin.d.ts +27 -0
- package/dist/src/controller/admin.js +60 -0
- package/dist/src/controller/admin.js.map +1 -0
- package/dist/src/controller/analytics.d.ts +16 -0
- package/dist/src/controller/analytics.js +79 -0
- package/dist/src/controller/analytics.js.map +1 -0
- package/dist/src/controller/api.d.ts +557 -0
- package/dist/src/controller/api.js +806 -0
- package/dist/src/controller/api.js.map +1 -0
- package/dist/src/controller/connection/oidc.d.ts +7 -0
- package/dist/src/controller/connection/oidc.js +181 -0
- package/dist/src/controller/connection/oidc.js.map +1 -0
- package/dist/src/controller/connection/saml.d.ts +7 -0
- package/dist/src/controller/connection/saml.js +250 -0
- package/dist/src/controller/connection/saml.js.map +1 -0
- package/dist/src/controller/error.d.ts +10 -0
- package/dist/src/controller/error.js +13 -0
- package/dist/src/controller/error.js.map +1 -0
- package/dist/src/controller/health-check.d.ts +11 -0
- package/dist/src/controller/health-check.js +51 -0
- package/dist/src/controller/health-check.js.map +1 -0
- package/dist/src/controller/logout.d.ts +18 -0
- package/dist/src/controller/logout.js +132 -0
- package/dist/src/controller/logout.js.map +1 -0
- package/dist/src/controller/oauth/allowed.d.ts +1 -0
- package/dist/src/controller/oauth/allowed.js +30 -0
- package/dist/src/controller/oauth/allowed.js.map +1 -0
- package/dist/src/controller/oauth/code-verifier.d.ts +1 -0
- package/dist/src/controller/oauth/code-verifier.js +8 -0
- package/dist/src/controller/oauth/code-verifier.js.map +1 -0
- package/dist/src/controller/oauth/oidc-client.d.ts +12 -0
- package/dist/src/controller/oauth/oidc-client.js +89 -0
- package/dist/src/controller/oauth/oidc-client.js.map +1 -0
- package/dist/src/controller/oauth/redirect.d.ts +1 -0
- package/dist/src/controller/oauth/redirect.js +13 -0
- package/dist/src/controller/oauth/redirect.js.map +1 -0
- package/dist/src/controller/oauth.d.ts +142 -0
- package/dist/src/controller/oauth.js +1112 -0
- package/dist/src/controller/oauth.js.map +1 -0
- package/dist/src/controller/oidc-discovery.d.ts +22 -0
- package/dist/src/controller/oidc-discovery.js +47 -0
- package/dist/src/controller/oidc-discovery.js.map +1 -0
- package/dist/src/controller/setup-link.d.ts +307 -0
- package/dist/src/controller/setup-link.js +462 -0
- package/dist/src/controller/setup-link.js.map +1 -0
- package/dist/src/controller/sp-config.d.ts +22 -0
- package/dist/src/controller/sp-config.js +89 -0
- package/dist/src/controller/sp-config.js.map +1 -0
- package/dist/src/controller/sso-handler.d.ts +66 -0
- package/dist/src/controller/sso-handler.js +306 -0
- package/dist/src/controller/sso-handler.js.map +1 -0
- package/dist/src/controller/utils.d.ts +84 -0
- package/dist/src/controller/utils.js +328 -0
- package/dist/src/controller/utils.js.map +1 -0
- package/dist/src/cron/lock.d.ts +18 -0
- package/dist/src/cron/lock.js +98 -0
- package/dist/src/cron/lock.js.map +1 -0
- package/dist/src/db/db.d.ts +5 -0
- package/dist/src/db/db.js +178 -0
- package/dist/src/db/db.js.map +1 -0
- package/dist/src/db/defaultDb.d.ts +2 -0
- package/dist/src/db/defaultDb.js +18 -0
- package/dist/src/db/defaultDb.js.map +1 -0
- package/dist/src/db/dynamoDb.d.ts +19 -0
- package/dist/src/db/dynamoDb.js +320 -0
- package/dist/src/db/dynamoDb.js.map +1 -0
- package/dist/src/db/encrypter.d.ts +3 -0
- package/dist/src/db/encrypter.js +22 -0
- package/dist/src/db/encrypter.js.map +1 -0
- package/dist/src/db/mem.d.ts +23 -0
- package/dist/src/db/mem.js +186 -0
- package/dist/src/db/mem.js.map +1 -0
- package/dist/src/db/mongo.d.ts +22 -0
- package/dist/src/db/mongo.js +177 -0
- package/dist/src/db/mongo.js.map +1 -0
- package/dist/src/db/planetscale/entity/JacksonIndex.d.ts +5 -0
- package/dist/src/db/planetscale/entity/JacksonIndex.js +32 -0
- package/dist/src/db/planetscale/entity/JacksonIndex.js.map +1 -0
- package/dist/src/db/planetscale/entity/JacksonStore.d.ts +9 -0
- package/dist/src/db/planetscale/entity/JacksonStore.js +63 -0
- package/dist/src/db/planetscale/entity/JacksonStore.js.map +1 -0
- package/dist/src/db/planetscale/entity/JacksonTTL.d.ts +4 -0
- package/dist/src/db/planetscale/entity/JacksonTTL.js +27 -0
- package/dist/src/db/planetscale/entity/JacksonTTL.js.map +1 -0
- package/dist/src/db/redis.d.ts +18 -0
- package/dist/src/db/redis.js +214 -0
- package/dist/src/db/redis.js.map +1 -0
- package/dist/src/db/sql/entity/JacksonIndex.d.ts +7 -0
- package/dist/src/db/sql/entity/JacksonIndex.js +39 -0
- package/dist/src/db/sql/entity/JacksonIndex.js.map +1 -0
- package/dist/src/db/sql/entity/JacksonStore.d.ts +9 -0
- package/dist/src/db/sql/entity/JacksonStore.js +61 -0
- package/dist/src/db/sql/entity/JacksonStore.js.map +1 -0
- package/dist/src/db/sql/entity/JacksonTTL.d.ts +4 -0
- package/dist/src/db/sql/entity/JacksonTTL.js +27 -0
- package/dist/src/db/sql/entity/JacksonTTL.js.map +1 -0
- package/dist/src/db/sql/mariadb/entity/JacksonIndex.d.ts +7 -0
- package/dist/src/db/sql/mariadb/entity/JacksonIndex.js +39 -0
- package/dist/src/db/sql/mariadb/entity/JacksonIndex.js.map +1 -0
- package/dist/src/db/sql/mariadb/entity/JacksonStore.d.ts +9 -0
- package/dist/src/db/sql/mariadb/entity/JacksonStore.js +63 -0
- package/dist/src/db/sql/mariadb/entity/JacksonStore.js.map +1 -0
- package/dist/src/db/sql/mariadb/entity/JacksonTTL.d.ts +4 -0
- package/dist/src/db/sql/mariadb/entity/JacksonTTL.js +27 -0
- package/dist/src/db/sql/mariadb/entity/JacksonTTL.js.map +1 -0
- package/dist/src/db/sql/mssql/entity/JacksonIndex.d.ts +7 -0
- package/dist/src/db/sql/mssql/entity/JacksonIndex.js +39 -0
- package/dist/src/db/sql/mssql/entity/JacksonIndex.js.map +1 -0
- package/dist/src/db/sql/mssql/entity/JacksonStore.d.ts +9 -0
- package/dist/src/db/sql/mssql/entity/JacksonStore.js +61 -0
- package/dist/src/db/sql/mssql/entity/JacksonStore.js.map +1 -0
- package/dist/src/db/sql/mssql/entity/JacksonTTL.d.ts +4 -0
- package/dist/src/db/sql/mssql/entity/JacksonTTL.js +27 -0
- package/dist/src/db/sql/mssql/entity/JacksonTTL.js.map +1 -0
- package/dist/src/db/sql/mssql.d.ts +1 -0
- package/dist/src/db/sql/mssql.js +44 -0
- package/dist/src/db/sql/mssql.js.map +1 -0
- package/dist/src/db/sql/sql.d.ts +32 -0
- package/dist/src/db/sql/sql.js +318 -0
- package/dist/src/db/sql/sql.js.map +1 -0
- package/dist/src/db/sql/sqlite/entity/JacksonIndex.d.ts +7 -0
- package/dist/src/db/sql/sqlite/entity/JacksonIndex.js +39 -0
- package/dist/src/db/sql/sqlite/entity/JacksonIndex.js.map +1 -0
- package/dist/src/db/sql/sqlite/entity/JacksonStore.d.ts +9 -0
- package/dist/src/db/sql/sqlite/entity/JacksonStore.js +61 -0
- package/dist/src/db/sql/sqlite/entity/JacksonStore.js.map +1 -0
- package/dist/src/db/sql/sqlite/entity/JacksonTTL.d.ts +4 -0
- package/dist/src/db/sql/sqlite/entity/JacksonTTL.js +27 -0
- package/dist/src/db/sql/sqlite/entity/JacksonTTL.js.map +1 -0
- package/dist/src/db/store.d.ts +5 -0
- package/dist/src/db/store.js +65 -0
- package/dist/src/db/store.js.map +1 -0
- package/dist/src/db/utils.d.ts +16 -0
- package/dist/src/db/utils.js +28 -0
- package/dist/src/db/utils.js.map +1 -0
- package/dist/src/directory-sync/batch-events/queue.d.ts +40 -0
- package/dist/src/directory-sync/batch-events/queue.js +225 -0
- package/dist/src/directory-sync/batch-events/queue.js.map +1 -0
- package/dist/src/directory-sync/index.d.ts +27 -0
- package/dist/src/directory-sync/index.js +97 -0
- package/dist/src/directory-sync/index.js.map +1 -0
- package/dist/src/directory-sync/non-scim/google/api.d.ts +36 -0
- package/dist/src/directory-sync/non-scim/google/api.js +143 -0
- package/dist/src/directory-sync/non-scim/google/api.js.map +1 -0
- package/dist/src/directory-sync/non-scim/google/index.d.ts +12 -0
- package/dist/src/directory-sync/non-scim/google/index.js +10 -0
- package/dist/src/directory-sync/non-scim/google/index.js.map +1 -0
- package/dist/src/directory-sync/non-scim/google/oauth.d.ts +27 -0
- package/dist/src/directory-sync/non-scim/google/oauth.js +105 -0
- package/dist/src/directory-sync/non-scim/google/oauth.js.map +1 -0
- package/dist/src/directory-sync/non-scim/index.d.ts +24 -0
- package/dist/src/directory-sync/non-scim/index.js +85 -0
- package/dist/src/directory-sync/non-scim/index.js.map +1 -0
- package/dist/src/directory-sync/non-scim/syncGroupMembers.d.ts +23 -0
- package/dist/src/directory-sync/non-scim/syncGroupMembers.js +105 -0
- package/dist/src/directory-sync/non-scim/syncGroupMembers.js.map +1 -0
- package/dist/src/directory-sync/non-scim/syncGroups.d.ts +24 -0
- package/dist/src/directory-sync/non-scim/syncGroups.js +120 -0
- package/dist/src/directory-sync/non-scim/syncGroups.js.map +1 -0
- package/dist/src/directory-sync/non-scim/syncUsers.d.ts +24 -0
- package/dist/src/directory-sync/non-scim/syncUsers.js +120 -0
- package/dist/src/directory-sync/non-scim/syncUsers.js.map +1 -0
- package/dist/src/directory-sync/non-scim/utils.d.ts +36 -0
- package/dist/src/directory-sync/non-scim/utils.js +109 -0
- package/dist/src/directory-sync/non-scim/utils.js.map +1 -0
- package/dist/src/directory-sync/request.d.ts +14 -0
- package/dist/src/directory-sync/request.js +29 -0
- package/dist/src/directory-sync/request.js.map +1 -0
- package/dist/src/directory-sync/scim/Base.d.ts +12 -0
- package/dist/src/directory-sync/scim/Base.js +23 -0
- package/dist/src/directory-sync/scim/Base.js.map +1 -0
- package/dist/src/directory-sync/scim/DirectoryConfig.d.ts +343 -0
- package/dist/src/directory-sync/scim/DirectoryConfig.js +580 -0
- package/dist/src/directory-sync/scim/DirectoryConfig.js.map +1 -0
- package/dist/src/directory-sync/scim/DirectoryGroups.d.ts +28 -0
- package/dist/src/directory-sync/scim/DirectoryGroups.js +252 -0
- package/dist/src/directory-sync/scim/DirectoryGroups.js.map +1 -0
- package/dist/src/directory-sync/scim/DirectoryUsers.d.ts +25 -0
- package/dist/src/directory-sync/scim/DirectoryUsers.js +193 -0
- package/dist/src/directory-sync/scim/DirectoryUsers.js.map +1 -0
- package/dist/src/directory-sync/scim/Groups.d.ts +166 -0
- package/dist/src/directory-sync/scim/Groups.js +348 -0
- package/dist/src/directory-sync/scim/Groups.js.map +1 -0
- package/dist/src/directory-sync/scim/Users.d.ts +99 -0
- package/dist/src/directory-sync/scim/Users.js +215 -0
- package/dist/src/directory-sync/scim/Users.js.map +1 -0
- package/dist/src/directory-sync/scim/WebhookEventsLogger.d.ts +101 -0
- package/dist/src/directory-sync/scim/WebhookEventsLogger.js +165 -0
- package/dist/src/directory-sync/scim/WebhookEventsLogger.js.map +1 -0
- package/dist/src/directory-sync/scim/transform.d.ts +6 -0
- package/dist/src/directory-sync/scim/transform.js +37 -0
- package/dist/src/directory-sync/scim/transform.js.map +1 -0
- package/dist/src/directory-sync/scim/utils.d.ts +33 -0
- package/dist/src/directory-sync/scim/utils.js +129 -0
- package/dist/src/directory-sync/scim/utils.js.map +1 -0
- package/dist/src/directory-sync/types.d.ts +195 -0
- package/dist/src/directory-sync/types.js +10 -0
- package/dist/src/directory-sync/types.js.map +1 -0
- package/dist/src/directory-sync/utils.d.ts +19 -0
- package/dist/src/directory-sync/utils.js +56 -0
- package/dist/src/directory-sync/utils.js.map +1 -0
- package/dist/src/ee/branding/index.d.ts +17 -0
- package/dist/src/ee/branding/index.js +49 -0
- package/dist/src/ee/branding/index.js.map +1 -0
- package/dist/src/ee/common/checkLicense.d.ts +3 -0
- package/dist/src/ee/common/checkLicense.js +23 -0
- package/dist/src/ee/common/checkLicense.js.map +1 -0
- package/dist/src/ee/identity-federation/app.d.ts +328 -0
- package/dist/src/ee/identity-federation/app.js +532 -0
- package/dist/src/ee/identity-federation/app.js.map +1 -0
- package/dist/src/ee/identity-federation/idp-login.d.ts +18 -0
- package/dist/src/ee/identity-federation/idp-login.js +98 -0
- package/dist/src/ee/identity-federation/idp-login.js.map +1 -0
- package/dist/src/ee/identity-federation/index.d.ts +15 -0
- package/dist/src/ee/identity-federation/index.js +43 -0
- package/dist/src/ee/identity-federation/index.js.map +1 -0
- package/dist/src/ee/identity-federation/sso.d.ts +24 -0
- package/dist/src/ee/identity-federation/sso.js +124 -0
- package/dist/src/ee/identity-federation/sso.js.map +1 -0
- package/dist/src/ee/identity-federation/types.d.ts +38 -0
- package/dist/src/ee/identity-federation/types.js +2 -0
- package/dist/src/ee/identity-federation/types.js.map +1 -0
- package/dist/src/ee/ory/ory.d.ts +18 -0
- package/dist/src/ee/ory/ory.js +195 -0
- package/dist/src/ee/ory/ory.js.map +1 -0
- package/dist/src/ee/product/index.d.ts +14 -0
- package/dist/src/ee/product/index.js +45 -0
- package/dist/src/ee/product/index.js.map +1 -0
- package/dist/src/event/axios.d.ts +2 -0
- package/dist/src/event/axios.js +27 -0
- package/dist/src/event/axios.js.map +1 -0
- package/dist/src/event/index.d.ts +11 -0
- package/dist/src/event/index.js +53 -0
- package/dist/src/event/index.js.map +1 -0
- package/dist/src/event/types.d.ts +21 -0
- package/dist/src/event/types.js +2 -0
- package/dist/src/event/types.js.map +1 -0
- package/dist/src/event/utils.d.ts +4 -0
- package/dist/src/event/utils.js +33 -0
- package/dist/src/event/utils.js.map +1 -0
- package/dist/src/event/webhook.d.ts +3 -0
- package/dist/src/event/webhook.js +34 -0
- package/dist/src/event/webhook.js.map +1 -0
- package/dist/src/index.d.ts +35 -0
- package/dist/src/index.js +161 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/loadConnection.d.ts +4 -0
- package/dist/src/loadConnection.js +38 -0
- package/dist/src/loadConnection.js.map +1 -0
- package/dist/src/opentelemetry/metrics.d.ts +14 -0
- package/dist/src/opentelemetry/metrics.js +64 -0
- package/dist/src/opentelemetry/metrics.js.map +1 -0
- package/dist/src/saml/claims.d.ts +12 -0
- package/dist/src/saml/claims.js +57 -0
- package/dist/src/saml/claims.js.map +1 -0
- package/dist/src/saml/lib.d.ts +8 -0
- package/dist/src/saml/lib.js +29 -0
- package/dist/src/saml/lib.js.map +1 -0
- package/dist/src/saml/x509.d.ts +9 -0
- package/dist/src/saml/x509.js +93 -0
- package/dist/src/saml/x509.js.map +1 -0
- package/dist/src/sso-traces/index.d.ts +114 -0
- package/dist/src/sso-traces/index.js +229 -0
- package/dist/src/sso-traces/index.js.map +1 -0
- package/dist/src/sso-traces/types.d.ts +44 -0
- package/dist/src/sso-traces/types.js +2 -0
- package/dist/src/sso-traces/types.js.map +1 -0
- package/dist/src/typings.d.ts +540 -0
- package/dist/src/typings.js +5 -0
- package/dist/src/typings.js.map +1 -0
- package/dist/typeorm.d.ts +3 -0
- package/dist/typeorm.js +58 -0
- package/dist/typeorm.js.map +1 -0
- package/dist/typings.d.ts +1 -1
- package/package.json +13 -13
@@ -0,0 +1,40 @@
|
|
1
|
+
import type { DirectorySyncEvent, IDirectoryConfig, Storable, JacksonOption, CronLock, IWebhookEventsLogger } from '../../typings';
|
2
|
+
declare enum EventStatus {
|
3
|
+
PENDING = "PENDING",
|
4
|
+
FAILED = "FAILED",
|
5
|
+
PROCESSING = "PROCESSING"
|
6
|
+
}
|
7
|
+
interface QueuedEvent {
|
8
|
+
event: DirectorySyncEvent;
|
9
|
+
id: string;
|
10
|
+
retry_count: number;
|
11
|
+
status: EventStatus;
|
12
|
+
created_at: string;
|
13
|
+
}
|
14
|
+
interface DirectoryEventsParams {
|
15
|
+
opts: JacksonOption;
|
16
|
+
eventStore: Storable;
|
17
|
+
eventLock: CronLock;
|
18
|
+
directories: IDirectoryConfig;
|
19
|
+
webhookLogs: IWebhookEventsLogger;
|
20
|
+
}
|
21
|
+
export declare class EventProcessor {
|
22
|
+
private eventStore;
|
23
|
+
private eventLock;
|
24
|
+
private opts;
|
25
|
+
private directories;
|
26
|
+
private webhookLogs;
|
27
|
+
private cronInterval;
|
28
|
+
constructor({ opts, eventStore, eventLock, directories, webhookLogs }: DirectoryEventsParams);
|
29
|
+
push(event: DirectorySyncEvent): Promise<QueuedEvent>;
|
30
|
+
private _process;
|
31
|
+
process(): Promise<void>;
|
32
|
+
fetchNextBatch(offset: number, limit: number): Promise<QueuedEvent[]>;
|
33
|
+
private send;
|
34
|
+
private delete;
|
35
|
+
private markAsFailed;
|
36
|
+
private logWebhookEvent;
|
37
|
+
private notifyAllEventsFailed;
|
38
|
+
scheduleWorker(): Promise<void>;
|
39
|
+
}
|
40
|
+
export {};
|
@@ -0,0 +1,225 @@
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
8
|
+
});
|
9
|
+
};
|
10
|
+
import _ from 'lodash';
|
11
|
+
import { randomUUID } from 'crypto';
|
12
|
+
import { sendPayloadToWebhook } from '../../event/webhook';
|
13
|
+
import { isConnectionActive } from '../../controller/utils';
|
14
|
+
import { JacksonError } from '../../controller/error';
|
15
|
+
import * as metrics from '../../opentelemetry/metrics';
|
16
|
+
import { indexNames } from '../scim/utils';
|
17
|
+
var EventStatus;
|
18
|
+
(function (EventStatus) {
|
19
|
+
EventStatus["PENDING"] = "PENDING";
|
20
|
+
EventStatus["FAILED"] = "FAILED";
|
21
|
+
EventStatus["PROCESSING"] = "PROCESSING";
|
22
|
+
})(EventStatus || (EventStatus = {}));
|
23
|
+
let isJobRunning = false;
|
24
|
+
let intervalId;
|
25
|
+
export class EventProcessor {
|
26
|
+
constructor({ opts, eventStore, eventLock, directories, webhookLogs }) {
|
27
|
+
var _a;
|
28
|
+
this.opts = opts;
|
29
|
+
this.eventLock = eventLock;
|
30
|
+
this.eventStore = eventStore;
|
31
|
+
this.directories = directories;
|
32
|
+
this.webhookLogs = webhookLogs;
|
33
|
+
this.cronInterval = (_a = this.opts.dsync) === null || _a === void 0 ? void 0 : _a.webhookBatchCronInterval;
|
34
|
+
if (this.cronInterval) {
|
35
|
+
this.scheduleWorker = this.scheduleWorker.bind(this);
|
36
|
+
this.scheduleWorker();
|
37
|
+
}
|
38
|
+
}
|
39
|
+
// Push the new event to the database
|
40
|
+
push(event) {
|
41
|
+
return __awaiter(this, void 0, void 0, function* () {
|
42
|
+
const id = randomUUID();
|
43
|
+
const record = {
|
44
|
+
id,
|
45
|
+
event,
|
46
|
+
retry_count: 0,
|
47
|
+
status: EventStatus.PENDING,
|
48
|
+
created_at: new Date().toISOString(),
|
49
|
+
};
|
50
|
+
const index = [
|
51
|
+
{
|
52
|
+
name: indexNames.directoryId,
|
53
|
+
value: event.directory_id,
|
54
|
+
},
|
55
|
+
];
|
56
|
+
yield this.eventStore.put(id, record, ...index);
|
57
|
+
return record;
|
58
|
+
});
|
59
|
+
}
|
60
|
+
_process() {
|
61
|
+
return __awaiter(this, void 0, void 0, function* () {
|
62
|
+
var _a, _b;
|
63
|
+
const batchSize = ((_a = this.opts.dsync) === null || _a === void 0 ? void 0 : _a.webhookBatchSize) || 50;
|
64
|
+
while (true) {
|
65
|
+
const events = yield this.fetchNextBatch(0, batchSize);
|
66
|
+
const eventsCount = events.length;
|
67
|
+
if (eventsCount === 0) {
|
68
|
+
yield this.eventLock.release();
|
69
|
+
break;
|
70
|
+
}
|
71
|
+
// Group the events by directory
|
72
|
+
const eventsByDirectory = _.groupBy(events, 'event.directory_id');
|
73
|
+
const directoryIds = Object.keys(eventsByDirectory);
|
74
|
+
const directoryCount = directoryIds.length;
|
75
|
+
// Fetch the connections corresponding to the directories it belongs to
|
76
|
+
const directoriesResult = yield Promise.allSettled(directoryIds.map((directoryId) => this.directories.get(directoryId)));
|
77
|
+
// Iterate over the directories and send the events to the webhooks
|
78
|
+
// For each directory, we will send the events in a batch
|
79
|
+
// directoryIds and directoriesResult are in the same order
|
80
|
+
for (let i = 0; i < directoryCount; i++) {
|
81
|
+
const directoryId = directoryIds[i];
|
82
|
+
const directoryResult = directoriesResult[i];
|
83
|
+
const events = eventsByDirectory[directoryId];
|
84
|
+
if (directoryResult.status === 'rejected') {
|
85
|
+
yield this.markAsFailed(events);
|
86
|
+
continue;
|
87
|
+
}
|
88
|
+
const directory = directoryResult.value.data;
|
89
|
+
if (!directory) {
|
90
|
+
console.error(`Directory ${directoryId} not found. Deleting the dsync events.`);
|
91
|
+
yield this.delete(events);
|
92
|
+
continue;
|
93
|
+
}
|
94
|
+
if (!isConnectionActive(directory)) {
|
95
|
+
console.error(`Directory ${directoryId} is not active. Deleting the dsync events.`);
|
96
|
+
yield this.delete(events);
|
97
|
+
continue;
|
98
|
+
}
|
99
|
+
if (!directory.webhook.endpoint || !directory.webhook.secret) {
|
100
|
+
console.error(`Webhook not configured for directory ${directoryId}. Deleting the dsync events.`);
|
101
|
+
yield this.delete(events);
|
102
|
+
continue;
|
103
|
+
}
|
104
|
+
try {
|
105
|
+
const { status } = yield this.send(directory.webhook, events);
|
106
|
+
if (status === 200) {
|
107
|
+
yield this.delete(events);
|
108
|
+
}
|
109
|
+
else {
|
110
|
+
console.error(`Webhook returned status ${status}. Marking the events as failed.`);
|
111
|
+
yield this.markAsFailed(events);
|
112
|
+
}
|
113
|
+
yield this.logWebhookEvent(directory, events, status);
|
114
|
+
}
|
115
|
+
catch (error) {
|
116
|
+
const message = `Error sending payload to webhook ${directory.webhook.endpoint}. Marking the events as failed. ${error.message}`;
|
117
|
+
const status = ((_b = error.response) === null || _b === void 0 ? void 0 : _b.status) || 500;
|
118
|
+
console.error(message, error);
|
119
|
+
yield this.markAsFailed(events);
|
120
|
+
yield this.logWebhookEvent(directory, events, status);
|
121
|
+
throw new JacksonError(message, status);
|
122
|
+
}
|
123
|
+
}
|
124
|
+
}
|
125
|
+
});
|
126
|
+
}
|
127
|
+
// Process the events and send them to the webhooks as a batch
|
128
|
+
process() {
|
129
|
+
return __awaiter(this, void 0, void 0, function* () {
|
130
|
+
if (isJobRunning) {
|
131
|
+
console.info('A batch process is already running, skipping.');
|
132
|
+
return;
|
133
|
+
}
|
134
|
+
if (!(yield this.eventLock.acquire())) {
|
135
|
+
return;
|
136
|
+
}
|
137
|
+
isJobRunning = true;
|
138
|
+
try {
|
139
|
+
this._process();
|
140
|
+
}
|
141
|
+
catch (e) {
|
142
|
+
console.error(' Error processing webhooks batch:', e);
|
143
|
+
}
|
144
|
+
isJobRunning = false;
|
145
|
+
if (this.cronInterval) {
|
146
|
+
this.scheduleWorker();
|
147
|
+
}
|
148
|
+
});
|
149
|
+
}
|
150
|
+
// Fetch next batch of events from the database
|
151
|
+
fetchNextBatch(offset, limit) {
|
152
|
+
return __awaiter(this, void 0, void 0, function* () {
|
153
|
+
const { data: events } = (yield this.eventStore.getAll(offset, limit, undefined, 'ASC'));
|
154
|
+
if (!events.length) {
|
155
|
+
return [];
|
156
|
+
}
|
157
|
+
// Check if all the events in the batch have failed
|
158
|
+
if (events.every((event) => event.status === EventStatus.FAILED)) {
|
159
|
+
yield this.notifyAllEventsFailed();
|
160
|
+
}
|
161
|
+
// Update the status of the events to PROCESSING
|
162
|
+
const promises = events.map((event) => this.eventStore.put(event.id, Object.assign(Object.assign({}, event), { status: EventStatus.PROCESSING })));
|
163
|
+
yield Promise.allSettled(promises);
|
164
|
+
return events;
|
165
|
+
});
|
166
|
+
}
|
167
|
+
// Send the events to the webhooks
|
168
|
+
send(webhook, events) {
|
169
|
+
return __awaiter(this, void 0, void 0, function* () {
|
170
|
+
var _a, _b;
|
171
|
+
const payload = events.map(({ event }) => event);
|
172
|
+
try {
|
173
|
+
return yield sendPayloadToWebhook(webhook, payload, (_b = (_a = this.opts) === null || _a === void 0 ? void 0 : _a.dsync) === null || _b === void 0 ? void 0 : _b.debugWebhooks);
|
174
|
+
}
|
175
|
+
catch (err) {
|
176
|
+
console.error(`Error sending payload to webhook: ${err.message}`);
|
177
|
+
throw err;
|
178
|
+
}
|
179
|
+
});
|
180
|
+
}
|
181
|
+
// Delete the delivered events
|
182
|
+
delete(events) {
|
183
|
+
return __awaiter(this, void 0, void 0, function* () {
|
184
|
+
const promises = events.map((event) => this.eventStore.delete(event.id));
|
185
|
+
yield Promise.allSettled(promises);
|
186
|
+
});
|
187
|
+
}
|
188
|
+
// Mark the events as failed
|
189
|
+
markAsFailed(events) {
|
190
|
+
return __awaiter(this, void 0, void 0, function* () {
|
191
|
+
const promises = events.map((event) => this.eventStore.put(event.id, Object.assign(Object.assign({}, event), { status: EventStatus.FAILED, retry_count: event.retry_count + 1 })));
|
192
|
+
yield Promise.allSettled(promises);
|
193
|
+
});
|
194
|
+
}
|
195
|
+
logWebhookEvent(directory, events, status) {
|
196
|
+
return __awaiter(this, void 0, void 0, function* () {
|
197
|
+
if (!directory.log_webhook_events) {
|
198
|
+
return;
|
199
|
+
}
|
200
|
+
const payload = events.map(({ event }) => event);
|
201
|
+
yield this.webhookLogs
|
202
|
+
.setTenantAndProduct(directory.tenant, directory.product)
|
203
|
+
.log(directory, payload, status);
|
204
|
+
});
|
205
|
+
}
|
206
|
+
// Send a OpenTelemetry event indicating that all the events in the batch have failed
|
207
|
+
notifyAllEventsFailed() {
|
208
|
+
return __awaiter(this, void 0, void 0, function* () {
|
209
|
+
metrics.increment('dsyncEventsBatchFailed');
|
210
|
+
console.error('All events in the batch have failed. Please check the system.');
|
211
|
+
});
|
212
|
+
}
|
213
|
+
scheduleWorker() {
|
214
|
+
return __awaiter(this, void 0, void 0, function* () {
|
215
|
+
if (!this.cronInterval) {
|
216
|
+
return;
|
217
|
+
}
|
218
|
+
if (intervalId) {
|
219
|
+
clearInterval(intervalId);
|
220
|
+
}
|
221
|
+
intervalId = setInterval(() => this.process(), this.cronInterval * 1000);
|
222
|
+
});
|
223
|
+
}
|
224
|
+
}
|
225
|
+
//# sourceMappingURL=queue.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../../../src/directory-sync/batch-events/queue.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import type { JacksonOption, IEventController, DB } from '../typings';
|
2
|
+
import { DirectoryConfig } from './scim/DirectoryConfig';
|
3
|
+
import { Users } from './scim/Users';
|
4
|
+
import { Groups } from './scim/Groups';
|
5
|
+
import { RequestHandler } from './request';
|
6
|
+
import { WebhookEventsLogger } from './scim/WebhookEventsLogger';
|
7
|
+
import { EventProcessor } from './batch-events/queue';
|
8
|
+
declare const directorySync: (params: {
|
9
|
+
db: DB;
|
10
|
+
opts: JacksonOption;
|
11
|
+
eventController: IEventController;
|
12
|
+
}) => Promise<{
|
13
|
+
users: Users;
|
14
|
+
groups: Groups;
|
15
|
+
directories: DirectoryConfig;
|
16
|
+
webhookLogs: WebhookEventsLogger;
|
17
|
+
requests: RequestHandler;
|
18
|
+
providers: () => {
|
19
|
+
[K: string]: string;
|
20
|
+
};
|
21
|
+
events: {
|
22
|
+
batch: EventProcessor;
|
23
|
+
};
|
24
|
+
google: any;
|
25
|
+
sync: any;
|
26
|
+
}>;
|
27
|
+
export default directorySync;
|
@@ -0,0 +1,97 @@
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
8
|
+
});
|
9
|
+
};
|
10
|
+
import { DirectoryConfig } from './scim/DirectoryConfig';
|
11
|
+
import { DirectoryUsers } from './scim/DirectoryUsers';
|
12
|
+
import { DirectoryGroups } from './scim/DirectoryGroups';
|
13
|
+
import { Users } from './scim/Users';
|
14
|
+
import { Groups } from './scim/Groups';
|
15
|
+
import { getDirectorySyncProviders } from './scim/utils';
|
16
|
+
import { RequestHandler } from './request';
|
17
|
+
import { WebhookEventsLogger } from './scim/WebhookEventsLogger';
|
18
|
+
import { newGoogleProvider } from './non-scim/google';
|
19
|
+
import { SyncProviders } from './non-scim';
|
20
|
+
import { storeNamespacePrefix } from '../controller/utils';
|
21
|
+
import { eventLockKey, eventLockTTL, googleLockKey, handleEventCallback } from './utils';
|
22
|
+
import { EventProcessor } from './batch-events/queue';
|
23
|
+
import { CronLock } from '../cron/lock';
|
24
|
+
const directorySync = (params) => __awaiter(void 0, void 0, void 0, function* () {
|
25
|
+
var _a;
|
26
|
+
const { db, opts, eventController } = params;
|
27
|
+
const users = new Users({ db });
|
28
|
+
const groups = new Groups({ db });
|
29
|
+
const webhookLogs = new WebhookEventsLogger({ db });
|
30
|
+
const directories = new DirectoryConfig({
|
31
|
+
db,
|
32
|
+
opts,
|
33
|
+
users,
|
34
|
+
groups,
|
35
|
+
logger: webhookLogs,
|
36
|
+
eventController,
|
37
|
+
});
|
38
|
+
const directoryUsers = new DirectoryUsers({ directories, users });
|
39
|
+
const directoryGroups = new DirectoryGroups({ directories, users, groups });
|
40
|
+
// Fetch the supported providers
|
41
|
+
const getProviders = () => {
|
42
|
+
return getDirectorySyncProviders();
|
43
|
+
};
|
44
|
+
const googleProvider = newGoogleProvider({ directories, opts });
|
45
|
+
// Batch send events
|
46
|
+
const eventStore = db.store(storeNamespacePrefix.dsync.events);
|
47
|
+
const lockStore = db.store(storeNamespacePrefix.dsync.lock, eventLockTTL);
|
48
|
+
const eventLock = new CronLock({ key: eventLockKey, lockStore });
|
49
|
+
const googleLock = new CronLock({ key: googleLockKey, lockStore });
|
50
|
+
const eventProcessor = new EventProcessor({
|
51
|
+
opts,
|
52
|
+
eventStore,
|
53
|
+
eventLock,
|
54
|
+
directories,
|
55
|
+
webhookLogs,
|
56
|
+
});
|
57
|
+
// Internal callback handles sending webhooks
|
58
|
+
const internalCallback = yield handleEventCallback({
|
59
|
+
opts,
|
60
|
+
directories,
|
61
|
+
webhookLogs,
|
62
|
+
eventProcessor,
|
63
|
+
});
|
64
|
+
// Use the provided callback (Embedded) or fallback to the internal callback (Hosted)
|
65
|
+
const _callback = ((_a = opts.dsync) === null || _a === void 0 ? void 0 : _a.callback) || internalCallback;
|
66
|
+
// SCIM handler
|
67
|
+
const requestHandler = new RequestHandler({
|
68
|
+
directoryUsers,
|
69
|
+
directoryGroups,
|
70
|
+
eventCallback: _callback,
|
71
|
+
});
|
72
|
+
// Google sync handler
|
73
|
+
const syncProviders = new SyncProviders({
|
74
|
+
userController: users,
|
75
|
+
groupController: groups,
|
76
|
+
opts,
|
77
|
+
directories,
|
78
|
+
requestHandler,
|
79
|
+
eventCallback: _callback,
|
80
|
+
eventLock: googleLock,
|
81
|
+
});
|
82
|
+
return {
|
83
|
+
users,
|
84
|
+
groups,
|
85
|
+
directories,
|
86
|
+
webhookLogs,
|
87
|
+
requests: requestHandler,
|
88
|
+
providers: getProviders,
|
89
|
+
events: {
|
90
|
+
batch: eventProcessor,
|
91
|
+
},
|
92
|
+
google: googleProvider.oauth,
|
93
|
+
sync: syncProviders.startSync.bind(syncProviders),
|
94
|
+
};
|
95
|
+
});
|
96
|
+
export default directorySync;
|
97
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/directory-sync/index.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,36 @@
|
|
1
|
+
import type { Directory, IDirectoryConfig, Group, GroupMember, IDirectoryProvider, JacksonOption, PaginationParams } from '../../../typings';
|
2
|
+
interface GoogleProviderParams {
|
3
|
+
opts: JacksonOption;
|
4
|
+
directories: IDirectoryConfig;
|
5
|
+
}
|
6
|
+
export declare class GoogleProvider implements IDirectoryProvider {
|
7
|
+
opts: JacksonOption;
|
8
|
+
directories: IDirectoryConfig;
|
9
|
+
groupFieldsToExcludeWhenCompare: string[];
|
10
|
+
userFieldsToExcludeWhenCompare: string[];
|
11
|
+
constructor({ directories, opts }: GoogleProviderParams);
|
12
|
+
createOAuth2Client(directory: Directory): any;
|
13
|
+
getDirectories(): Promise<Directory[]>;
|
14
|
+
getUsers(directory: Directory, options: PaginationParams | null): Promise<{
|
15
|
+
data: never[];
|
16
|
+
metadata: null;
|
17
|
+
} | {
|
18
|
+
data: any;
|
19
|
+
metadata: {
|
20
|
+
pageToken: any;
|
21
|
+
hasNextPage: boolean;
|
22
|
+
};
|
23
|
+
}>;
|
24
|
+
getGroups(directory: Directory, options: PaginationParams | null): Promise<{
|
25
|
+
data: never[];
|
26
|
+
metadata: null;
|
27
|
+
} | {
|
28
|
+
data: any;
|
29
|
+
metadata: {
|
30
|
+
pageToken: string;
|
31
|
+
hasNextPage: boolean;
|
32
|
+
};
|
33
|
+
}>;
|
34
|
+
getGroupMembers(directory: Directory, group: Group): Promise<GroupMember[]>;
|
35
|
+
}
|
36
|
+
export {};
|
@@ -0,0 +1,143 @@
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
8
|
+
});
|
9
|
+
};
|
10
|
+
import { admin } from '@googleapis/admin';
|
11
|
+
import { OAuth2Client } from 'google-auth-library';
|
12
|
+
export class GoogleProvider {
|
13
|
+
constructor({ directories, opts }) {
|
14
|
+
this.groupFieldsToExcludeWhenCompare = ['etag'];
|
15
|
+
this.userFieldsToExcludeWhenCompare = ['etag', 'lastLoginTime', 'thumbnailPhotoEtag'];
|
16
|
+
this.opts = opts;
|
17
|
+
this.directories = directories;
|
18
|
+
}
|
19
|
+
createOAuth2Client(directory) {
|
20
|
+
var _a, _b;
|
21
|
+
const googleProvider = (_b = (_a = this.opts.dsync) === null || _a === void 0 ? void 0 : _a.providers) === null || _b === void 0 ? void 0 : _b.google;
|
22
|
+
const authClient = new OAuth2Client(googleProvider === null || googleProvider === void 0 ? void 0 : googleProvider.clientId, googleProvider === null || googleProvider === void 0 ? void 0 : googleProvider.clientSecret, `${this.opts.externalUrl}${googleProvider === null || googleProvider === void 0 ? void 0 : googleProvider.callbackPath}`);
|
23
|
+
authClient.setCredentials({
|
24
|
+
access_token: directory.google_access_token,
|
25
|
+
refresh_token: directory.google_refresh_token,
|
26
|
+
});
|
27
|
+
return authClient;
|
28
|
+
}
|
29
|
+
getDirectories() {
|
30
|
+
return __awaiter(this, void 0, void 0, function* () {
|
31
|
+
const { data: directories } = yield this.directories.filterBy({
|
32
|
+
provider: 'google',
|
33
|
+
});
|
34
|
+
if (!directories || directories.length === 0) {
|
35
|
+
return [];
|
36
|
+
}
|
37
|
+
return directories.filter((directory) => {
|
38
|
+
return (directory.google_access_token && directory.google_refresh_token && directory.google_domain !== '');
|
39
|
+
});
|
40
|
+
});
|
41
|
+
}
|
42
|
+
getUsers(directory, options) {
|
43
|
+
return __awaiter(this, void 0, void 0, function* () {
|
44
|
+
var _a;
|
45
|
+
const query = {
|
46
|
+
maxResults: 200,
|
47
|
+
customer: 'my_customer',
|
48
|
+
};
|
49
|
+
if (options === null || options === void 0 ? void 0 : options.pageToken) {
|
50
|
+
query['pageToken'] = options.pageToken;
|
51
|
+
}
|
52
|
+
const googleAdmin = admin({ version: 'directory_v1', auth: this.createOAuth2Client(directory) });
|
53
|
+
const response = yield googleAdmin.users.list(query);
|
54
|
+
if (!response.data.users) {
|
55
|
+
return {
|
56
|
+
data: [],
|
57
|
+
metadata: null,
|
58
|
+
};
|
59
|
+
}
|
60
|
+
const users = response.data.users.map((user) => {
|
61
|
+
var _a, _b;
|
62
|
+
return {
|
63
|
+
id: user.id,
|
64
|
+
email: user.primaryEmail,
|
65
|
+
first_name: (_a = user.name) === null || _a === void 0 ? void 0 : _a.givenName,
|
66
|
+
last_name: (_b = user.name) === null || _b === void 0 ? void 0 : _b.familyName,
|
67
|
+
active: !user.suspended,
|
68
|
+
raw: user,
|
69
|
+
};
|
70
|
+
});
|
71
|
+
return {
|
72
|
+
data: users,
|
73
|
+
metadata: {
|
74
|
+
pageToken: (_a = response.data.nextPageToken) !== null && _a !== void 0 ? _a : undefined,
|
75
|
+
hasNextPage: !!response.data.nextPageToken,
|
76
|
+
},
|
77
|
+
};
|
78
|
+
});
|
79
|
+
}
|
80
|
+
getGroups(directory, options) {
|
81
|
+
return __awaiter(this, void 0, void 0, function* () {
|
82
|
+
const googleAdmin = admin({ version: 'directory_v1', auth: this.createOAuth2Client(directory) });
|
83
|
+
const query = {
|
84
|
+
maxResults: 200,
|
85
|
+
customer: 'my_customer',
|
86
|
+
};
|
87
|
+
if (options === null || options === void 0 ? void 0 : options.pageToken) {
|
88
|
+
query['pageToken'] = options.pageToken;
|
89
|
+
}
|
90
|
+
const response = yield googleAdmin.groups.list(query);
|
91
|
+
if (!response.data.groups) {
|
92
|
+
return {
|
93
|
+
data: [],
|
94
|
+
metadata: null,
|
95
|
+
};
|
96
|
+
}
|
97
|
+
const groups = response.data.groups.map((group) => {
|
98
|
+
return {
|
99
|
+
id: group.id,
|
100
|
+
name: group.name,
|
101
|
+
raw: group,
|
102
|
+
};
|
103
|
+
});
|
104
|
+
return {
|
105
|
+
data: groups,
|
106
|
+
metadata: {
|
107
|
+
pageToken: response.data.nextPageToken,
|
108
|
+
hasNextPage: !!response.data.nextPageToken,
|
109
|
+
},
|
110
|
+
};
|
111
|
+
});
|
112
|
+
}
|
113
|
+
getGroupMembers(directory, group) {
|
114
|
+
return __awaiter(this, void 0, void 0, function* () {
|
115
|
+
const googleAdmin = admin({ version: 'directory_v1', auth: this.createOAuth2Client(directory) });
|
116
|
+
const allMembers = [];
|
117
|
+
const query = {
|
118
|
+
maxResults: 200,
|
119
|
+
groupKey: group.id,
|
120
|
+
};
|
121
|
+
let nextPageToken = null;
|
122
|
+
do {
|
123
|
+
if (nextPageToken) {
|
124
|
+
query['pageToken'] = nextPageToken;
|
125
|
+
}
|
126
|
+
const response = yield googleAdmin.members.list(query);
|
127
|
+
if (!response.data.members) {
|
128
|
+
break;
|
129
|
+
}
|
130
|
+
const members = response.data.members.map((user) => {
|
131
|
+
return {
|
132
|
+
id: user.id,
|
133
|
+
raw: user,
|
134
|
+
};
|
135
|
+
});
|
136
|
+
allMembers.push(...members);
|
137
|
+
nextPageToken = response.data.nextPageToken;
|
138
|
+
} while (nextPageToken);
|
139
|
+
return allMembers;
|
140
|
+
});
|
141
|
+
}
|
142
|
+
}
|
143
|
+
//# sourceMappingURL=api.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../../src/directory-sync/non-scim/google/api.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import { GoogleAuth } from './oauth';
|
2
|
+
import { GoogleProvider } from './api';
|
3
|
+
import type { IDirectoryConfig, JacksonOption } from '../../../typings';
|
4
|
+
interface NewGoogleProviderParams {
|
5
|
+
directories: IDirectoryConfig;
|
6
|
+
opts: JacksonOption;
|
7
|
+
}
|
8
|
+
export declare const newGoogleProvider: (params: NewGoogleProviderParams) => {
|
9
|
+
directory: GoogleProvider;
|
10
|
+
oauth: GoogleAuth;
|
11
|
+
};
|
12
|
+
export {};
|
@@ -0,0 +1,10 @@
|
|
1
|
+
import { GoogleAuth } from './oauth';
|
2
|
+
import { GoogleProvider } from './api';
|
3
|
+
export const newGoogleProvider = (params) => {
|
4
|
+
const { directories, opts } = params;
|
5
|
+
return {
|
6
|
+
directory: new GoogleProvider({ opts, directories }),
|
7
|
+
oauth: new GoogleAuth({ opts, directories }),
|
8
|
+
};
|
9
|
+
};
|
10
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/directory-sync/non-scim/google/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAQvC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,MAA+B,EAAE,EAAE;IACnE,MAAM,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,MAAM,CAAC;IAErC,OAAO;QACL,SAAS,EAAE,IAAI,cAAc,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;QACpD,KAAK,EAAE,IAAI,UAAU,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;KAC7C,CAAC;AACJ,CAAC,CAAC"}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import { Credentials } from 'google-auth-library';
|
2
|
+
import type { Directory, IDirectoryConfig, JacksonOption, Response } from '../../../typings';
|
3
|
+
interface GoogleAuthParams {
|
4
|
+
opts: JacksonOption;
|
5
|
+
directories: IDirectoryConfig;
|
6
|
+
}
|
7
|
+
export declare class GoogleAuth {
|
8
|
+
private opts;
|
9
|
+
private directories;
|
10
|
+
constructor({ directories, opts }: GoogleAuthParams);
|
11
|
+
createOAuth2Client(directory: Directory): any;
|
12
|
+
generateAuthorizationUrl(params: {
|
13
|
+
directoryId: string;
|
14
|
+
}): Promise<Response<{
|
15
|
+
authorizationUrl: string;
|
16
|
+
}>>;
|
17
|
+
getAccessToken(params: {
|
18
|
+
directoryId: string;
|
19
|
+
code: string;
|
20
|
+
}): Promise<Response<Credentials>>;
|
21
|
+
setToken(params: {
|
22
|
+
directoryId: string;
|
23
|
+
accessToken: Credentials['access_token'];
|
24
|
+
refreshToken: Credentials['refresh_token'];
|
25
|
+
}): Promise<Response<Directory>>;
|
26
|
+
}
|
27
|
+
export {};
|