@bitblit/ratchet-warden-server 5.1.118 → 5.1.121

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 (36) hide show
  1. package/lib/server/provider/warden-default-user-decoration-provider.js +3 -1
  2. package/lib/server/provider/warden-default-user-decoration-provider.js.map +1 -1
  3. package/lib/server/provider/warden-dynamo-storage-provider-options.d.ts +7 -0
  4. package/lib/server/provider/warden-dynamo-storage-provider-options.js +7 -0
  5. package/lib/server/provider/warden-dynamo-storage-provider-options.js.map +1 -0
  6. package/lib/server/provider/warden-dynamo-storage-provider.d.ts +50 -0
  7. package/lib/server/provider/warden-dynamo-storage-provider.js +214 -0
  8. package/lib/server/provider/warden-dynamo-storage-provider.js.map +1 -0
  9. package/lib/server/provider/warden-mailer-and-expiring-code-ratchet-single-use-code-provider.d.ts +1 -1
  10. package/lib/server/provider/warden-mailer-and-expiring-code-ratchet-single-use-code-provider.js +5 -2
  11. package/lib/server/provider/warden-mailer-and-expiring-code-ratchet-single-use-code-provider.js.map +1 -1
  12. package/lib/server/provider/warden-s3-single-file-storage-provider.d.ts +1 -0
  13. package/lib/server/provider/warden-s3-single-file-storage-provider.js +8 -0
  14. package/lib/server/provider/warden-s3-single-file-storage-provider.js.map +1 -1
  15. package/lib/server/provider/warden-single-use-code-provider.d.ts +1 -1
  16. package/lib/server/provider/warden-storage-provider.d.ts +1 -0
  17. package/lib/server/provider/warden-third-party-authentication-provider.d.ts +7 -0
  18. package/lib/server/provider/warden-third-party-authentication-provider.js +2 -0
  19. package/lib/server/provider/warden-third-party-authentication-provider.js.map +1 -0
  20. package/lib/server/provider/warden-twilio-verify-single-use-code-provider.d.ts +1 -1
  21. package/lib/server/provider/warden-twilio-verify-single-use-code-provider.js +1 -1
  22. package/lib/server/provider/warden-twilio-verify-single-use-code-provider.js.map +1 -1
  23. package/lib/server/warden-authorizer.d.ts +35 -0
  24. package/lib/server/warden-authorizer.js +88 -0
  25. package/lib/server/warden-authorizer.js.map +1 -0
  26. package/lib/server/warden-entry-builder.d.ts +13 -0
  27. package/lib/server/warden-entry-builder.js +42 -0
  28. package/lib/server/warden-entry-builder.js.map +1 -0
  29. package/lib/server/warden-service-options.d.ts +2 -0
  30. package/lib/server/warden-service.d.ts +21 -13
  31. package/lib/server/warden-service.js +239 -140
  32. package/lib/server/warden-service.js.map +1 -1
  33. package/lib/server/warden-web-authn-export-token.d.ts +5 -0
  34. package/lib/server/warden-web-authn-export-token.js +2 -0
  35. package/lib/server/warden-web-authn-export-token.js.map +1 -0
  36. package/package.json +16 -16
@@ -3,8 +3,10 @@ export class WardenDefaultUserDecorationProvider {
3
3
  async fetchDecoration(wardenUser) {
4
4
  const rval = {
5
5
  userTokenData: WardenUtils.stripWardenEntryToSummary(wardenUser),
6
+ proxyUserTokenData: null,
6
7
  userTokenExpirationSeconds: 3600,
7
- userTeamRoles: [{ team: 'WARDEN', role: 'USER' }],
8
+ globalRoleIds: [],
9
+ teamRoleMappings: [],
8
10
  };
9
11
  return rval;
10
12
  }
@@ -1 +1 @@
1
- {"version":3,"file":"warden-default-user-decoration-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-default-user-decoration-provider.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAE,MAAM,yDAAyD,CAAC;AAItF,MAAM,OAAO,mCAAmC;IACvC,KAAK,CAAC,eAAe,CAAC,UAAuB;QAElD,MAAM,IAAI,GAA6C;YACrD,aAAa,EAAE,WAAW,CAAC,yBAAyB,CAAC,UAAU,CAAC;YAChE,0BAA0B,EAAE,IAAI;YAChC,aAAa,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;SAClD,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
1
+ {"version":3,"file":"warden-default-user-decoration-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-default-user-decoration-provider.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAE,MAAM,yDAAyD,CAAC;AAItF,MAAM,OAAO,mCAAmC;IACvC,KAAK,CAAC,eAAe,CAAC,UAAuB;QAElD,MAAM,IAAI,GAA6C;YACrD,aAAa,EAAE,WAAW,CAAC,yBAAyB,CAAC,UAAU,CAAC;YAChE,kBAAkB,EAAE,IAAI;YACxB,0BAA0B,EAAE,IAAI;YAChC,aAAa,EAAE,EAAE;YACjB,gBAAgB,EAAE,EAAE;SACrB,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -0,0 +1,7 @@
1
+ import { WardenTeamRoleMapping } from "@bitblit/ratchet-warden-common/common/model/warden-team-role-mapping";
2
+ export declare class WardenDynamoStorageProviderOptions<T> {
3
+ tableName: string;
4
+ defaultTeamRoleMappings: WardenTeamRoleMapping[];
5
+ defaultTokenExpirationSeconds: number;
6
+ defaultDecoration?: T;
7
+ }
@@ -0,0 +1,7 @@
1
+ export class WardenDynamoStorageProviderOptions {
2
+ tableName;
3
+ defaultTeamRoleMappings;
4
+ defaultTokenExpirationSeconds;
5
+ defaultDecoration;
6
+ }
7
+ //# sourceMappingURL=warden-dynamo-storage-provider-options.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"warden-dynamo-storage-provider-options.js","sourceRoot":"","sources":["../../../src/server/provider/warden-dynamo-storage-provider-options.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,kCAAkC;IAC7C,SAAS,CAAS;IAClB,uBAAuB,CAA0B;IACjD,6BAA6B,CAAS;IACtC,iBAAiB,CAAI;CACtB"}
@@ -0,0 +1,50 @@
1
+ import { DynamoRatchet } from '@bitblit/ratchet-aws/dynamodb/dynamo-ratchet';
2
+ import { WardenDynamoStorageProviderOptions } from './warden-dynamo-storage-provider-options.js';
3
+ import { WardenContact } from '@bitblit/ratchet-warden-common/common/model/warden-contact';
4
+ import { WardenEntry } from '@bitblit/ratchet-warden-common/common/model/warden-entry';
5
+ import { WardenEntrySummary } from '@bitblit/ratchet-warden-common/common/model/warden-entry-summary';
6
+ import { ExpiringCodeProvider } from '@bitblit/ratchet-aws/expiring-code/expiring-code-provider';
7
+ import { ExpiringCode } from '@bitblit/ratchet-aws/expiring-code/expiring-code';
8
+ import { WardenStorageProvider } from "./warden-storage-provider.js";
9
+ import { WardenUserDecorationProvider } from "./warden-user-decoration-provider.js";
10
+ import { WardenUserDecoration } from "@bitblit/ratchet-warden-common/common/model/warden-user-decoration";
11
+ import { WardenTeamRoleMapping } from "@bitblit/ratchet-warden-common/common/model/warden-team-role-mapping";
12
+ export declare class WardenDynamoStorageProvider<T> implements WardenStorageProvider, ExpiringCodeProvider, WardenUserDecorationProvider<T> {
13
+ private ddb;
14
+ private options;
15
+ private static readonly EXPIRING_CODE_PROVIDER_KEY;
16
+ constructor(ddb: DynamoRatchet, options: WardenDynamoStorageProviderOptions<T>);
17
+ createDecoration(decoration: T): WardenUserDecoration<T>;
18
+ updateRoles(userId: string, roles: WardenTeamRoleMapping[]): Promise<WardenUserDecoration<T>>;
19
+ updateTokenExpirationSeconds(userId: string, newValue: number): Promise<WardenUserDecoration<T>>;
20
+ updateDecoration(userId: string, decoration: T): Promise<WardenUserDecoration<T>>;
21
+ fetchDecoration(wardenUser: WardenEntry): Promise<WardenUserDecoration<T>>;
22
+ fetchDecorationById(userId: string): Promise<WardenUserDecoration<T>>;
23
+ private fetchExpiringCodes;
24
+ private updateInternal;
25
+ checkCode(code: string, context: string, deleteOnMatch?: boolean): Promise<boolean>;
26
+ storeCode(code: ExpiringCode): Promise<boolean>;
27
+ private static contactToSearchString;
28
+ private static thirdPartyToSearchString;
29
+ private fetchInternalByUserId;
30
+ fetchCurrentUserChallenge(userId: string, relyingPartyId: string): Promise<string>;
31
+ findEntryByThirdPartyId(thirdParty: string, thirdPartyId: string): Promise<WardenEntry>;
32
+ findEntryByContact(contact: WardenContact): Promise<WardenEntry>;
33
+ findEntryById(userId: string): Promise<WardenEntry>;
34
+ listUserSummaries(): Promise<WardenEntrySummary[]>;
35
+ removeEntry(userId: string): Promise<boolean>;
36
+ saveEntry(entry: WardenEntry): Promise<WardenEntry>;
37
+ updateUserChallenge(userId: string, relyingPartyId: string, challenge: string): Promise<boolean>;
38
+ }
39
+ export interface WardenDynamoStorageDataWrapper {
40
+ userId: string;
41
+ entry: WardenEntry;
42
+ decoration: WardenUserDecoration<any>;
43
+ currentUserChallenges: string[];
44
+ contactSearchString: string;
45
+ thirdPartySearchString: string;
46
+ }
47
+ export interface ExpiringCodeHolder {
48
+ userId: string;
49
+ values: ExpiringCode[];
50
+ }
@@ -0,0 +1,214 @@
1
+ import { Logger } from '@bitblit/ratchet-common/logger/logger';
2
+ import { ErrorRatchet } from '@bitblit/ratchet-common/lang/error-ratchet';
3
+ import { WardenUtils } from '@bitblit/ratchet-warden-common/common/util/warden-utils';
4
+ export class WardenDynamoStorageProvider {
5
+ ddb;
6
+ options;
7
+ static EXPIRING_CODE_PROVIDER_KEY = '__EXPIRING_CODE_DATA';
8
+ constructor(ddb, options) {
9
+ this.ddb = ddb;
10
+ this.options = options;
11
+ }
12
+ createDecoration(decoration) {
13
+ return {
14
+ globalRoleIds: [],
15
+ teamRoleMappings: this.options.defaultTeamRoleMappings,
16
+ userTokenExpirationSeconds: this.options.defaultTokenExpirationSeconds,
17
+ userTokenData: decoration,
18
+ proxyUserTokenData: null
19
+ };
20
+ }
21
+ async updateRoles(userId, roles) {
22
+ const rval = await this.fetchInternalByUserId(userId);
23
+ if (rval) {
24
+ rval.decoration ??= this.createDecoration(null);
25
+ rval.decoration.teamRoleMappings = roles;
26
+ await this.updateInternal(rval);
27
+ }
28
+ else {
29
+ throw ErrorRatchet.fErr('Cannot update roles - no entry found for %s', userId);
30
+ }
31
+ return this.fetchDecorationById(userId);
32
+ }
33
+ async updateTokenExpirationSeconds(userId, newValue) {
34
+ const rval = await this.fetchInternalByUserId(userId);
35
+ if (rval) {
36
+ rval.decoration ??= this.createDecoration(null);
37
+ rval.decoration.userTokenExpirationSeconds = newValue;
38
+ await this.updateInternal(rval);
39
+ }
40
+ else {
41
+ throw ErrorRatchet.fErr('Cannot update roles - no entry found for %s', userId);
42
+ }
43
+ return this.fetchDecorationById(userId);
44
+ }
45
+ async updateDecoration(userId, decoration) {
46
+ const rval = await this.fetchInternalByUserId(userId);
47
+ if (rval) {
48
+ rval.decoration ??= this.createDecoration(null);
49
+ rval.decoration.userTokenData = decoration;
50
+ await this.updateInternal(rval);
51
+ }
52
+ else {
53
+ throw ErrorRatchet.fErr('Cannot update roles - no entry found for %s', userId);
54
+ }
55
+ return this.fetchDecorationById(userId);
56
+ }
57
+ async fetchDecoration(wardenUser) {
58
+ return this.fetchDecorationById(wardenUser.userId);
59
+ }
60
+ async fetchDecorationById(userId) {
61
+ const rval = await this.fetchInternalByUserId(userId);
62
+ return rval?.decoration;
63
+ }
64
+ async fetchExpiringCodes() {
65
+ let rval = await this.ddb.simpleGet(this.options.tableName, {
66
+ userId: WardenDynamoStorageProvider.EXPIRING_CODE_PROVIDER_KEY
67
+ });
68
+ if (!rval) {
69
+ rval = {
70
+ userId: WardenDynamoStorageProvider.EXPIRING_CODE_PROVIDER_KEY,
71
+ values: []
72
+ };
73
+ await this.updateInternal(rval);
74
+ }
75
+ return rval;
76
+ }
77
+ async updateInternal(val) {
78
+ return this.ddb.simplePut(this.options.tableName, val);
79
+ }
80
+ async checkCode(code, context, deleteOnMatch) {
81
+ const codes = await this.fetchExpiringCodes();
82
+ const rval = codes.values.find((c) => c.code === code && c.context === context);
83
+ if (rval) {
84
+ if (deleteOnMatch) {
85
+ codes.values = codes.values.filter((c) => c.code !== code || c.context !== context);
86
+ await this.updateInternal(codes);
87
+ }
88
+ return true;
89
+ }
90
+ else {
91
+ return !!rval;
92
+ }
93
+ }
94
+ async storeCode(code) {
95
+ const codes = await this.fetchExpiringCodes();
96
+ codes.values.push(code);
97
+ const now = Date.now();
98
+ codes.values = codes.values.filter(c => c.expiresEpochMS > now);
99
+ const stored = await this.updateInternal(codes);
100
+ return stored ? true : false;
101
+ }
102
+ static contactToSearchString(contact) {
103
+ const toFind = `${contact.type}:${contact.value}`;
104
+ return toFind;
105
+ }
106
+ static thirdPartyToSearchString(thirdParty, thirdPartyId) {
107
+ const toFind = `${thirdParty}:${thirdPartyId}`;
108
+ return toFind;
109
+ }
110
+ async fetchInternalByUserId(userId) {
111
+ return this.ddb.simpleGet(this.options.tableName, { userId: userId });
112
+ }
113
+ async fetchCurrentUserChallenge(userId, relyingPartyId) {
114
+ const rval = await this.fetchInternalByUserId(userId);
115
+ const cuc = rval ? rval.currentUserChallenges.find((c) => c.startsWith(relyingPartyId)) : null;
116
+ return cuc ? cuc.substring(relyingPartyId.length + 1) : null;
117
+ }
118
+ async findEntryByThirdPartyId(thirdParty, thirdPartyId) {
119
+ const toFind = WardenDynamoStorageProvider.thirdPartyToSearchString(thirdParty, thirdPartyId);
120
+ const scan = {
121
+ TableName: this.options.tableName,
122
+ FilterExpression: 'contains(#thirdPartySearchString,:thirdPartySearchString)',
123
+ ExpressionAttributeNames: {
124
+ '#thirdPartySearchString': 'thirdPartySearchString',
125
+ },
126
+ ExpressionAttributeValues: {
127
+ ':thirdPartySearchString': toFind
128
+ }
129
+ };
130
+ const results = await this.ddb.fullyExecuteScan(scan);
131
+ if (results && results.length > 0) {
132
+ const rval = results[0];
133
+ return rval.entry;
134
+ }
135
+ else {
136
+ Logger.info('No results found for %s', toFind);
137
+ return null;
138
+ }
139
+ }
140
+ async findEntryByContact(contact) {
141
+ const toFind = WardenDynamoStorageProvider.contactToSearchString(contact);
142
+ const scan = {
143
+ TableName: this.options.tableName,
144
+ FilterExpression: 'contains(#contactSearchString,:contactSearchString)',
145
+ ExpressionAttributeNames: {
146
+ '#contactSearchString': 'contactSearchString',
147
+ },
148
+ ExpressionAttributeValues: {
149
+ ':contactSearchString': toFind
150
+ }
151
+ };
152
+ const results = await this.ddb.fullyExecuteScan(scan);
153
+ if (results && results.length > 0) {
154
+ const rval = results[0];
155
+ return rval.entry;
156
+ }
157
+ else {
158
+ Logger.info('No results found for %s', toFind);
159
+ return null;
160
+ }
161
+ }
162
+ async findEntryById(userId) {
163
+ const rval = await this.fetchInternalByUserId(userId);
164
+ return rval ? rval.entry : null;
165
+ }
166
+ async listUserSummaries() {
167
+ const scan = {
168
+ TableName: this.options.tableName,
169
+ };
170
+ const results = await this.ddb.fullyExecuteScan(scan);
171
+ const rval = results.map(wd => {
172
+ return WardenUtils.stripWardenEntryToSummary(wd.entry);
173
+ });
174
+ return rval;
175
+ }
176
+ async removeEntry(userId) {
177
+ const tmp = await this.ddb.simpleDelete(this.options.tableName, { userId: userId });
178
+ return tmp.Attributes ? true : false;
179
+ }
180
+ async saveEntry(entry) {
181
+ let rval = await this.fetchInternalByUserId(entry.userId);
182
+ if (!rval) {
183
+ rval = {
184
+ userId: entry.userId,
185
+ entry: entry,
186
+ currentUserChallenges: [],
187
+ decoration: this.createDecoration(null),
188
+ contactSearchString: 'ContactSearch: ' + (entry.contactMethods || []).map((cm) => WardenDynamoStorageProvider.contactToSearchString(cm)).join(' '),
189
+ thirdPartySearchString: '3rdPartySearch: ' + (entry.thirdPartyAuthenticators || []).map((item) => WardenDynamoStorageProvider.thirdPartyToSearchString(item.thirdParty, item.thirdPartyId)).join(' '),
190
+ };
191
+ }
192
+ rval.entry = entry;
193
+ const now = Date.now();
194
+ rval.entry.updatedEpochMS = now;
195
+ rval.entry.createdEpochMS = rval.entry.createdEpochMS || now;
196
+ const saved = await this.updateInternal(rval);
197
+ Logger.silly('Saved %j', saved);
198
+ const postSaveLookup = await this.fetchInternalByUserId(entry.userId);
199
+ return postSaveLookup.entry;
200
+ }
201
+ async updateUserChallenge(userId, relyingPartyId, challenge) {
202
+ const rval = await this.fetchInternalByUserId(userId);
203
+ if (!rval) {
204
+ throw ErrorRatchet.fErr('Cannot update user challenge - no entry found for %s', userId);
205
+ }
206
+ rval.currentUserChallenges = (rval.currentUserChallenges || []).filter((c) => !c.startsWith(relyingPartyId));
207
+ const cuc = relyingPartyId + ':' + challenge;
208
+ rval.currentUserChallenges.push(cuc);
209
+ const saved = await this.updateInternal(rval);
210
+ Logger.silly('Saved %j', saved);
211
+ return saved.Attributes ? true : false;
212
+ }
213
+ }
214
+ //# sourceMappingURL=warden-dynamo-storage-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"warden-dynamo-storage-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-dynamo-storage-provider.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,yDAAyD,CAAC;AAUtF,MAAM,OAAO,2BAA2B;IAK5B;IACA;IAJF,MAAM,CAAU,0BAA0B,GAAW,sBAAsB,CAAC;IAEpF,YACU,GAAkB,EAClB,OAA8C;QAD9C,QAAG,GAAH,GAAG,CAAe;QAClB,YAAO,GAAP,OAAO,CAAuC;IAExD,CAAC;IAEM,gBAAgB,CAAC,UAAa;QACnC,OAAO;YACL,aAAa,EAAE,EAAE;YACjB,gBAAgB,EAAE,IAAI,CAAC,OAAO,CAAC,uBAAuB;YACtD,0BAA0B,EAAE,IAAI,CAAC,OAAO,CAAC,6BAA6B;YACtE,aAAa,EAAE,UAAU;YACzB,kBAAkB,EAAE,IAAI;SACzB,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,MAAc,EAAE,KAA8B;QACrE,MAAM,IAAI,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QACtF,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC,UAAU,KAAK,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;YAChD,IAAI,CAAC,UAAU,CAAC,gBAAgB,GAAG,KAAK,CAAC;YACzC,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;aAAM,CAAC;YACN,MAAM,YAAY,CAAC,IAAI,CAAC,6CAA6C,EAAE,MAAM,CAAC,CAAC;QACjF,CAAC;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;IAC1C,CAAC;IAEM,KAAK,CAAC,4BAA4B,CAAC,MAAc,EAAE,QAAgB;QACxE,MAAM,IAAI,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QACtF,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC,UAAU,KAAK,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;YAChD,IAAI,CAAC,UAAU,CAAC,0BAA0B,GAAG,QAAQ,CAAC;YACtD,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;aAAM,CAAC;YACN,MAAM,YAAY,CAAC,IAAI,CAAC,6CAA6C,EAAE,MAAM,CAAC,CAAC;QACjF,CAAC;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;IAC1C,CAAC;IAEM,KAAK,CAAC,gBAAgB,CAAC,MAAc,EAAE,UAAY;QACxD,MAAM,IAAI,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QACtF,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC,UAAU,KAAK,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;YAChD,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,UAAU,CAAC;YAC3C,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;aAAM,CAAC;YACN,MAAM,YAAY,CAAC,IAAI,CAAC,6CAA6C,EAAE,MAAM,CAAC,CAAC;QACjF,CAAC;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;IAC1C,CAAC;IAEM,KAAK,CAAC,eAAe,CAAC,UAAuB;QAClD,OAAO,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IACrD,CAAC;IAEM,KAAK,CAAC,mBAAmB,CAAC,MAAc;QAC7C,MAAM,IAAI,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QACtF,OAAO,IAAI,EAAE,UAAU,CAAC;IAC1B,CAAC;IAIO,KAAK,CAAC,kBAAkB;QAC9B,IAAI,IAAI,GAAuB,MAAM,IAAI,CAAC,GAAG,CAAC,SAAS,CAAqB,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;YAClG,MAAM,EAAE,2BAA2B,CAAC,0BAA0B;SAC/D,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,IAAI,GAAG;gBACL,MAAM,EAAE,2BAA2B,CAAC,0BAA0B;gBAC9D,MAAM,EAAE,EAAE;aACX,CAAC;YACF,MAAM,IAAI,CAAC,cAAc,CAAC,IAAiD,CAAC,CAAC;QAC/E,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,KAAK,CAAC,cAAc,CAAC,GAAmC;QAC9D,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;IACzD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,IAAY,EAAE,OAAe,EAAE,aAAuB;QAC3E,MAAM,KAAK,GAAuB,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClE,MAAM,IAAI,GAAiB,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;QAC9F,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,aAAa,EAAE,CAAC;gBAClB,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;gBACpF,MAAM,IAAI,CAAC,cAAc,CAAC,KAAkD,CAAC,CAAC;YAChF,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,CAAC,IAAI,CAAC;QAChB,CAAC;IACH,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,IAAkB;QACvC,MAAM,KAAK,GAAuB,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClE,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxB,MAAM,GAAG,GAAW,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,KAAK,CAAC,MAAM,GAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,cAAc,GAAC,GAAG,CAAC,CAAC;QAC1D,MAAM,MAAM,GAAqB,MAAM,IAAI,CAAC,cAAc,CAAC,KAAkD,CAAC,CAAC;QAE/G,OAAO,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IAC/B,CAAC;IAEO,MAAM,CAAC,qBAAqB,CAAC,OAAsB;QACzD,MAAM,MAAM,GAAW,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;QAC1D,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,MAAM,CAAC,wBAAwB,CAAC,UAAkB,EAAE,YAAoB;QAC9E,MAAM,MAAM,GAAW,GAAG,UAAU,IAAI,YAAY,EAAE,CAAC;QACvD,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,KAAK,CAAC,qBAAqB,CAAC,MAAc;QAChD,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAiC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,EAAC,MAAM,EAAE,MAAM,EAAC,CAAC,CAAC;IACtG,CAAC;IAEM,KAAK,CAAC,yBAAyB,CAAC,MAAc,EAAE,cAAsB;QAC3E,MAAM,IAAI,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QACtF,MAAM,GAAG,GAAW,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACvG,OAAO,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,GAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC7D,CAAC;IAIM,KAAK,CAAC,uBAAuB,CAAC,UAAkB,EAAE,YAAoB;QAC3E,MAAM,MAAM,GAAW,2BAA2B,CAAC,wBAAwB,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QACtG,MAAM,IAAI,GAAqB;YAC7B,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS;YACjC,gBAAgB,EAAE,2DAA2D;YAC7E,wBAAwB,EAAE;gBACxB,yBAAyB,EAAE,wBAAwB;aACpD;YACD,yBAAyB,EAAE;gBACzB,yBAAyB,EAAE,MAAM;aAClC;SACF,CAAC;QAEF,MAAM,OAAO,GAAqC,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAiC,IAAI,CAAC,CAAC;QACxH,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,GAAmC,OAAO,CAAC,CAAC,CAAC,CAAC;YACxD,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,IAAI,CAAC,yBAAyB,EAAE,MAAM,CAAC,CAAC;YAC/C,OAAO,IAAI,CAAC;QACd,CAAC;IAEH,CAAC;IAEM,KAAK,CAAC,kBAAkB,CAAC,OAAsB;QACpD,MAAM,MAAM,GAAW,2BAA2B,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;QAClF,MAAM,IAAI,GAAqB;YAC7B,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS;YACjC,gBAAgB,EAAE,qDAAqD;YACvE,wBAAwB,EAAE;gBACxB,sBAAsB,EAAE,qBAAqB;aAC9C;YACD,yBAAyB,EAAE;gBACzB,sBAAsB,EAAE,MAAM;aAC/B;SACF,CAAC;QAEF,MAAM,OAAO,GAAqC,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAiC,IAAI,CAAC,CAAC;QACxH,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,GAAmC,OAAO,CAAC,CAAC,CAAC,CAAC;YACxD,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,IAAI,CAAC,yBAAyB,EAAE,MAAM,CAAC,CAAC;YAC/C,OAAO,IAAI,CAAC;QACd,CAAC;IAEH,CAAC;IAEM,KAAK,CAAC,aAAa,CAAC,MAAc;QACvC,MAAM,IAAI,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QACtF,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IAClC,CAAC;IAEM,KAAK,CAAC,iBAAiB;QAE5B,MAAM,IAAI,GAAqB;YAC7B,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS;SAClC,CAAC;QAEF,MAAM,OAAO,GAAqC,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAiC,IAAI,CAAC,CAAC;QACxH,MAAM,IAAI,GAAyB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAA,EAAE;YACjD,OAAO,WAAW,CAAC,yBAAyB,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QACzD,CAAC,CAAC,CAAA;QACF,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,MAAc;QACrC,MAAM,GAAG,GAAwB,MAAM,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,EAAC,MAAM,EAAE,MAAM,EAAC,CAAC,CAAC;QACvG,OAAO,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IACvC,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,KAAkB;QACvC,IAAI,IAAI,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAC1F,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,IAAI,GAAG;gBACL,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,KAAK,EAAE,KAAK;gBACZ,qBAAqB,EAAE,EAAE;gBACzB,UAAU,EAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC;gBACvC,mBAAmB,EAAE,kBAAkB,GAAC,CAAC,KAAK,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,2BAA2B,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;gBACjJ,sBAAsB,EAAE,mBAAmB,GAAC,CAAC,KAAK,CAAC,wBAAwB,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,2BAA2B,CAAC,wBAAwB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;aACrM,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,MAAM,GAAG,GAAW,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,GAAG,CAAC;QAChC,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,IAAI,GAAG,CAAC;QAC7D,MAAM,KAAK,GAAqB,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAChE,MAAM,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAEhC,MAAM,cAAc,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACtG,OAAO,cAAc,CAAC,KAAK,CAAC;IAC9B,CAAC;IAEM,KAAK,CAAC,mBAAmB,CAAC,MAAc,EAAE,cAAsB,EAAE,SAAiB;QACxF,MAAM,IAAI,GAAmC,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QACtF,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,YAAY,CAAC,IAAI,CAAC,sDAAsD,EAAE,MAAM,CAAC,CAAC;QAC1F,CAAC;QACD,IAAI,CAAC,qBAAqB,GAAG,CAAC,IAAI,CAAC,qBAAqB,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC,CAAC;QAC7G,MAAM,GAAG,GAAW,cAAc,GAAG,GAAG,GAAG,SAAS,CAAC;QACrD,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAErC,MAAM,KAAK,GAAqB,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAChE,MAAM,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAChC,OAAO,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IACzC,CAAC"}
@@ -14,7 +14,7 @@ export declare class WardenMailerAndExpiringCodeRatchetSingleUseCodeProvider imp
14
14
  private static defaultOptions;
15
15
  constructor(mailer: Mailer<any, any>, expiringCodeRatchet: ExpiringCodeRatchet, mailerOptions?: WardenMailerAndExpiringCodeRatchetSingleUseCodeProviderOptions);
16
16
  handlesContactType(type: WardenContactType): boolean;
17
- createAndSendNewCode(contact: WardenContact, relyingPartyName: string): Promise<boolean>;
17
+ createAndSendNewCode(contact: WardenContact, relyingPartyName: string, origin: string): Promise<boolean>;
18
18
  checkCode(contactValue: string, code: string): Promise<boolean>;
19
19
  createCodeAndSendMagicLink?(loginContact: WardenContact, relyingPartyName: string, landingUrl: string, metaIn?: Record<string, string>, ttlSeconds?: number, destinationContact?: WardenContact, customTemplate?: WardenCustomTemplateDescriptor): Promise<boolean>;
20
20
  formatMessage(contact: WardenContact, messageType: WardenCustomerMessageType, context: Record<string, any>, destinationContact?: WardenContact, customTemplate?: WardenCustomTemplateDescriptor): Promise<ReadyToSendEmail>;
@@ -26,7 +26,7 @@ export class WardenMailerAndExpiringCodeRatchetSingleUseCodeProvider {
26
26
  handlesContactType(type) {
27
27
  return type === WardenContactType.EmailAddress;
28
28
  }
29
- async createAndSendNewCode(contact, relyingPartyName) {
29
+ async createAndSendNewCode(contact, relyingPartyName, origin) {
30
30
  let rval = null;
31
31
  const token = await this.expiringCodeRatchet.createNewCode({
32
32
  context: contact.value,
@@ -36,8 +36,11 @@ export class WardenMailerAndExpiringCodeRatchetSingleUseCodeProvider {
36
36
  tags: ['Login'],
37
37
  });
38
38
  const msg = await this.formatMessage(contact, WardenCustomerMessageType.ExpiringCode, {
39
+ requestor: contact.value,
40
+ requestorB64: Base64Ratchet.encodeStringToBase64String(contact.value),
39
41
  code: token.code,
40
42
  relyingPartyName: relyingPartyName,
43
+ origin: origin
41
44
  });
42
45
  rval = await this.sendMessage(msg);
43
46
  return rval;
@@ -71,7 +74,7 @@ export class WardenMailerAndExpiringCodeRatchetSingleUseCodeProvider {
71
74
  async formatMessage(contact, messageType, context, destinationContact, customTemplate) {
72
75
  const rts = {
73
76
  destinationAddresses: [destinationContact?.value || contact.value],
74
- subject: customTemplate?.subjectLine || this.mailerOptions.magicLinkSubjectLine || 'Your login token',
77
+ subject: customTemplate?.subjectLine || this.mailerOptions.magicLinkSubjectLine || 'Login token for ' + contact.value,
75
78
  };
76
79
  Logger.info('Formatting Message for magic link, rts: %j, messageType: %s, context: %j', rts, messageType, context);
77
80
  if (messageType === WardenCustomerMessageType.ExpiringCode) {
@@ -1 +1 @@
1
- {"version":3,"file":"warden-mailer-and-expiring-code-ratchet-single-use-code-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-mailer-and-expiring-code-ratchet-single-use-code-provider.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AAO5E,OAAO,EAAE,iBAAiB,EAAE,MAAM,iEAAiE,CAAC;AAEpG,OAAO,EAAE,yBAAyB,EAAE,MAAM,0EAA0E,CAAC;AAQrH,MAAM,OAAO,uDAAuD;IAaxD;IACA;IACA;IAdF,MAAM,CAAC,cAAc;QAC3B,MAAM,IAAI,GAAmE;YAC3E,mBAAmB,EAAE,SAAS;YAC9B,6BAA6B,EAAE,8BAA8B;YAC7D,4BAA4B,EAAE,SAAS;YACvC,yBAAyB,EAAE,2BAA2B;YACtD,wBAAwB,EAAE,SAAS;SACpC,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC;IAED,YACU,MAAwB,EACxB,mBAAwC,EACxC,gBAAgF,uDAAuD,CAAC,cAAc,EAAE;QAFxJ,WAAM,GAAN,MAAM,CAAkB;QACxB,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,kBAAa,GAAb,aAAa,CAA2I;IAC/J,CAAC;IACG,kBAAkB,CAAC,IAAuB;QAC/C,OAAO,IAAI,KAAK,iBAAiB,CAAC,YAAY,CAAC;IACjD,CAAC;IAEM,KAAK,CAAC,oBAAoB,CAAC,OAAsB,EAAE,gBAAwB;QAChF,IAAI,IAAI,GAAY,IAAI,CAAC;QACzB,MAAM,KAAK,GAAiB,MAAM,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACvE,OAAO,EAAE,OAAO,CAAC,KAAK;YACtB,MAAM,EAAE,CAAC;YACT,QAAQ,EAAE,YAAY;YACtB,iBAAiB,EAAE,GAAG;YACtB,IAAI,EAAE,CAAC,OAAO,CAAC;SAChB,CAAC,CAAC;QACH,MAAM,GAAG,GAAQ,MAAM,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,yBAAyB,CAAC,YAAY,EAAE;YACzF,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,gBAAgB,EAAE,gBAAgB;SACnC,CAAC,CAAC;QACH,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACnC,OAAO,IAAI,CAAC;IACd,CAAC;IACM,KAAK,CAAC,SAAS,CAAC,YAAoB,EAAE,IAAY;QACvD,MAAM,IAAI,GAAY,MAAM,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;QACnF,OAAO,IAAI,CAAC;IACd,CAAC;IACM,KAAK,CAAC,0BAA0B,CACrC,YAA2B,EAC3B,gBAAwB,EACxB,UAAkB,EAClB,MAA+B,EAC/B,UAAmB,EACnB,kBAAkC,EAClC,cAA+C;QAE/C,IAAI,IAAI,GAAY,IAAI,CAAC;QACzB,MAAM,KAAK,GAAiB,MAAM,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACvE,OAAO,EAAE,YAAY,CAAC,KAAK;YAC3B,MAAM,EAAE,EAAE;YACV,QAAQ,EAAE,aAAa,CAAC,gBAAgB;YACxC,iBAAiB,EAAE,UAAU;YAC7B,IAAI,EAAE,CAAC,WAAW,CAAC;SACpB,CAAC,CAAC;QAEH,MAAM,IAAI,GAAwB,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,IAAI,EAAE,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC;QAC7F,MAAM,WAAW,GAAW,aAAa,CAAC,sBAAsB,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAE7E,MAAM,gBAAgB,GAAW,aAAa,CAAC,kBAAkB,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAEvI,MAAM,OAAO,GAA2B,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,IAAI,EAAE,EAAE;YACpE,UAAU,EAAE,gBAAgB;YAC5B,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,gBAAgB,EAAE,gBAAgB;SACnC,CAAC,CAAC;QAEH,MAAM,OAAO,GAA8B,cAAc,CAAC,CAAC,CAAC,yBAAyB,CAAC,MAAM,CAAC,CAAC,CAAC,yBAAyB,CAAC,SAAS,CAAC;QACnI,MAAM,GAAG,GAAqB,MAAM,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,OAAO,EAAE,OAAO,EAAE,kBAAkB,EAAE,cAAc,CAAC,CAAC;QAC3H,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACnC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK,CAAC,aAAa,CACxB,OAAsB,EACtB,WAAsC,EACtC,OAA4B,EAC5B,kBAAkC,EAClC,cAA+C;QAE/C,MAAM,GAAG,GAAqB;YAC5B,oBAAoB,EAAE,CAAC,kBAAkB,EAAE,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC;YAClE,OAAO,EAAE,cAAc,EAAE,WAAW,IAAI,IAAI,CAAC,aAAa,CAAC,oBAAoB,IAAI,kBAAkB;SACtG,CAAC;QAEF,MAAM,CAAC,IAAI,CAAC,0EAA0E,EAAE,GAAG,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAEnH,IAAI,WAAW,KAAK,yBAAyB,CAAC,YAAY,EAAE,CAAC;YAC3D,MAAM,IAAI,CAAC,MAAM,CAAC,aAAa,CAC7B,GAAG,EACH,OAAO,EACP,IAAI,CAAC,aAAa,CAAC,6BAA6B,EAChD,IAAI,CAAC,aAAa,CAAC,4BAA4B,EAC/C,IAAI,CAAC,aAAa,CAAC,mBAAmB,CACvC,CAAC;QACJ,CAAC;aAAM,IAAI,WAAW,KAAK,yBAAyB,CAAC,SAAS,EAAE,CAAC;YAC/D,MAAM,IAAI,CAAC,MAAM,CAAC,aAAa,CAC7B,GAAG,EACH,OAAO,EACP,IAAI,CAAC,aAAa,CAAC,yBAAyB,EAC5C,IAAI,CAAC,aAAa,CAAC,wBAAwB,EAC3C,IAAI,CAAC,aAAa,CAAC,mBAAmB,CACvC,CAAC;QACJ,CAAC;aAAM,IAAI,WAAW,KAAK,yBAAyB,CAAC,MAAM,EAAE,CAAC;YAC5D,IAAI,CAAC,cAAc,EAAE,CAAC;gBACpB,MAAM,YAAY,CAAC,IAAI,CAAC,sDAAsD,CAAC,CAAC;YAClF,CAAC;YACD,MAAM,CAAC,IAAI,CAAC,8BAA8B,EAAE,cAAc,CAAC,CAAC;YAC5D,MAAM,IAAI,CAAC,MAAM,CAAC,aAAa,CAC7B,GAAG,EACH,OAAO,EACP,cAAc,CAAC,WAAW,EAC1B,cAAc,CAAC,WAAW,EAC1B,cAAc,CAAC,UAAU,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC,CAAC,cAAc,CAAC,UAAU,CAC7G,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,MAAM,YAAY,CAAC,IAAI,CAAC,2BAA2B,EAAE,WAAW,CAAC,CAAC;QACpE,CAAC;QAED,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,OAAyB;QAChD,MAAM,IAAI,GAA8B,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC7E,MAAM,CAAC,KAAK,CAAC,+BAA+B,EAAE,IAAI,CAAC,CAAC;QACpD,OAAO,CAAC,CAAC,IAAI,CAAC;IAChB,CAAC;CACF"}
1
+ {"version":3,"file":"warden-mailer-and-expiring-code-ratchet-single-use-code-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-mailer-and-expiring-code-ratchet-single-use-code-provider.ts"],"names":[],"mappings":"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"}
@@ -14,6 +14,7 @@ export declare class WardenS3SingleFileStorageProvider implements WardenStorageP
14
14
  storeDataFile(file: WardenS3SingleFileStorageProviderDataFile): Promise<PutObjectOutput>;
15
15
  fetchCurrentUserChallenge(userId: string, relyingPartyId: string): Promise<string>;
16
16
  findEntryByContact(contact: WardenContact): Promise<WardenEntry>;
17
+ findEntryByThirdPartyId(thirdParty: string, thirdPartyId: string): Promise<WardenEntry>;
17
18
  findEntryById(userId: string): Promise<WardenEntry>;
18
19
  removeEntry(userId: string): Promise<boolean>;
19
20
  saveEntry(entry: WardenEntry): Promise<WardenEntry>;
@@ -47,6 +47,14 @@ export class WardenS3SingleFileStorageProvider {
47
47
  }
48
48
  return rval;
49
49
  }
50
+ async findEntryByThirdPartyId(thirdParty, thirdPartyId) {
51
+ let rval = null;
52
+ if (StringRatchet.trimToNull(thirdParty) && StringRatchet.trimToNull(thirdPartyId)) {
53
+ const data = await this.fetchDataFile();
54
+ rval = (data.entries || []).find((d) => !!(d.thirdPartyAuthenticators || []).find((x) => x.thirdParty === thirdParty && x.thirdPartyId === thirdPartyId));
55
+ }
56
+ return rval;
57
+ }
50
58
  async findEntryById(userId) {
51
59
  let rval = null;
52
60
  if (StringRatchet.trimToNull(userId)) {
@@ -1 +1 @@
1
- {"version":3,"file":"warden-s3-single-file-storage-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-s3-single-file-storage-provider.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"warden-s3-single-file-storage-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-s3-single-file-storage-provider.ts"],"names":[],"mappings":"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"}
@@ -3,7 +3,7 @@ import { WardenContact } from '@bitblit/ratchet-warden-common/common/model/warde
3
3
  import { WardenCustomTemplateDescriptor } from '@bitblit/ratchet-warden-common/common/command/warden-custom-template-descriptor';
4
4
  export interface WardenSingleUseCodeProvider {
5
5
  handlesContactType(type: WardenContactType): boolean;
6
- createAndSendNewCode(contact: WardenContact, relyingPartyName: string): Promise<boolean>;
6
+ createAndSendNewCode(contact: WardenContact, relyingPartyName: string, origin: string): Promise<boolean>;
7
7
  checkCode(contactValue: string, code: string): Promise<boolean>;
8
8
  createCodeAndSendMagicLink?(loginContact: WardenContact, relyingPartyName: string, landingUrl: string, metaIn?: Record<string, string>, ttlSeconds?: number, destinationContact?: WardenContact, customTemplate?: WardenCustomTemplateDescriptor): Promise<boolean>;
9
9
  }
@@ -4,6 +4,7 @@ import { WardenEntry } from '@bitblit/ratchet-warden-common/common/model/warden-
4
4
  export interface WardenStorageProvider {
5
5
  findEntryById(userId: string): Promise<WardenEntry>;
6
6
  findEntryByContact(contact: WardenContact): Promise<WardenEntry>;
7
+ findEntryByThirdPartyId(thirdParty: string, thirdPartyId: string): Promise<WardenEntry>;
7
8
  saveEntry(entry: WardenEntry): Promise<WardenEntry>;
8
9
  removeEntry(userId: string): Promise<boolean>;
9
10
  updateUserChallenge(userId: string, relyingPartyId: string, challenge: string): Promise<boolean>;
@@ -0,0 +1,7 @@
1
+ import { WardenLoginThirdPartyToken } from "@bitblit/ratchet-warden-common/common/model/warden-login-third-party-token";
2
+ import { WardenThirdPartyAuthentication } from "@bitblit/ratchet-warden-common/common/model/warden-third-party-authentication";
3
+ export interface WardenThirdPartyAuthenticationProvider {
4
+ handlesThirdParty(thirdParty: string): boolean;
5
+ validateTokenAndReturnThirdPartyUserId(input: WardenLoginThirdPartyToken, origin: string): Promise<WardenThirdPartyAuthentication>;
6
+ extractUserLabelFromAuthentication?(auth: WardenThirdPartyAuthentication): Promise<string>;
7
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=warden-third-party-authentication-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"warden-third-party-authentication-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-third-party-authentication-provider.ts"],"names":[],"mappings":""}
@@ -8,6 +8,6 @@ export declare class WardenTwilioVerifySingleUseCodeProvider implements WardenSi
8
8
  constructor(optsPromise: Promise<WardenTwilioVerifySingleUseCodeProviderOptions>);
9
9
  private twilioVerifyRatchet;
10
10
  handlesContactType(type: WardenContactType): boolean;
11
- createAndSendNewCode(contact: WardenContact, _relyingPartyNameIgnored: string): Promise<boolean>;
11
+ createAndSendNewCode(contact: WardenContact, _relyingPartyNameIgnored: string, _origin: string): Promise<boolean>;
12
12
  checkCode(contactValue: string, code: string): Promise<boolean>;
13
13
  }
@@ -17,7 +17,7 @@ export class WardenTwilioVerifySingleUseCodeProvider {
17
17
  handlesContactType(type) {
18
18
  return type === WardenContactType.TextCapablePhoneNumber;
19
19
  }
20
- async createAndSendNewCode(contact, _relyingPartyNameIgnored) {
20
+ async createAndSendNewCode(contact, _relyingPartyNameIgnored, _origin) {
21
21
  const ratchet = await this.twilioVerifyRatchet();
22
22
  const rval = await ratchet.sendVerificationTokenUsingTwilioVerify(contact.value);
23
23
  Logger.debug('sendMessage was : %j', rval);
@@ -1 +1 @@
1
- {"version":3,"file":"warden-twilio-verify-single-use-code-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-twilio-verify-single-use-code-provider.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAE/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,kEAAkE,CAAC;AACvG,OAAO,EAAE,iBAAiB,EAAE,MAAM,iEAAiE,CAAC;AAGpG,MAAM,OAAO,uCAAuC;IAG9B;IAFZ,yBAAyB,CAAsB;IAEvD,YAAoB,WAAoE;QAApE,gBAAW,GAAX,WAAW,CAAyD;IAAG,CAAC;IAEpF,KAAK,CAAC,mBAAmB;QAC/B,IAAI,CAAC,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACpC,MAAM,IAAI,GAAmD,MAAM,IAAI,CAAC,WAAW,CAAC;YACpF,IAAI,CAAC,yBAAyB,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACnH,CAAC;QACD,OAAO,IAAI,CAAC,yBAAyB,CAAC;IACxC,CAAC;IAEM,kBAAkB,CAAC,IAAuB;QAC/C,OAAO,IAAI,KAAK,iBAAiB,CAAC,sBAAsB,CAAC;IAC3D,CAAC;IAEM,KAAK,CAAC,oBAAoB,CAAC,OAAsB,EAAE,wBAAgC;QAExF,MAAM,OAAO,GAAwB,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACtE,MAAM,IAAI,GAAQ,MAAM,OAAO,CAAC,sCAAsC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtF,MAAM,CAAC,KAAK,CAAC,sBAAsB,EAAE,IAAI,CAAC,CAAC;QAC3C,OAAO,CAAC,CAAC,IAAI,CAAC;IAChB,CAAC;IACM,KAAK,CAAC,SAAS,CAAC,YAAoB,EAAE,IAAY;QACvD,MAAM,OAAO,GAAwB,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACtE,MAAM,IAAI,GAAY,MAAM,OAAO,CAAC,6CAA6C,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QACtG,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
1
+ {"version":3,"file":"warden-twilio-verify-single-use-code-provider.js","sourceRoot":"","sources":["../../../src/server/provider/warden-twilio-verify-single-use-code-provider.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAE/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,kEAAkE,CAAC;AACvG,OAAO,EAAE,iBAAiB,EAAE,MAAM,iEAAiE,CAAC;AAGpG,MAAM,OAAO,uCAAuC;IAG9B;IAFZ,yBAAyB,CAAsB;IAEvD,YAAoB,WAAoE;QAApE,gBAAW,GAAX,WAAW,CAAyD;IAAG,CAAC;IAEpF,KAAK,CAAC,mBAAmB;QAC/B,IAAI,CAAC,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACpC,MAAM,IAAI,GAAmD,MAAM,IAAI,CAAC,WAAW,CAAC;YACpF,IAAI,CAAC,yBAAyB,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACnH,CAAC;QACD,OAAO,IAAI,CAAC,yBAAyB,CAAC;IACxC,CAAC;IAEM,kBAAkB,CAAC,IAAuB;QAC/C,OAAO,IAAI,KAAK,iBAAiB,CAAC,sBAAsB,CAAC;IAC3D,CAAC;IAEM,KAAK,CAAC,oBAAoB,CAAC,OAAsB,EAAE,wBAAgC,EAAE,OAAe;QAEzG,MAAM,OAAO,GAAwB,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACtE,MAAM,IAAI,GAAQ,MAAM,OAAO,CAAC,sCAAsC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtF,MAAM,CAAC,KAAK,CAAC,sBAAsB,EAAE,IAAI,CAAC,CAAC;QAC3C,OAAO,CAAC,CAAC,IAAI,CAAC;IAChB,CAAC;IACM,KAAK,CAAC,SAAS,CAAC,YAAoB,EAAE,IAAY;QACvD,MAAM,OAAO,GAAwB,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACtE,MAAM,IAAI,GAAY,MAAM,OAAO,CAAC,6CAA6C,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QACtG,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -0,0 +1,35 @@
1
+ import { WardenServiceOptions } from "./warden-service-options.js";
2
+ import { WardenContact } from "@bitblit/ratchet-warden-common/common/model/warden-contact";
3
+ import { WardenEntry } from "@bitblit/ratchet-warden-common/common/model/warden-entry";
4
+ import { WardenUserDecoration } from "@bitblit/ratchet-warden-common/common/model/warden-user-decoration";
5
+ import { WardenJwtToken } from "@bitblit/ratchet-warden-common/common/model/warden-jwt-token";
6
+ export declare class WardenAuthorizer {
7
+ private opts;
8
+ constructor(opts: WardenServiceOptions);
9
+ findEntryByContact(contact: WardenContact): Promise<WardenEntry>;
10
+ findEntryById(userId: string): Promise<WardenEntry>;
11
+ findDecoratorById(userId: string): Promise<WardenUserDecoration<any>>;
12
+ userHasGlobalRoleById(userId: string, roleId: string): Promise<boolean>;
13
+ userHasRoleOnTeamById(userId: string, teamId: string, roleId: string): Promise<boolean>;
14
+ userHasAtLeastOneGlobalRoleById(userId: string, roleIds: string[]): Promise<boolean>;
15
+ userHasAtLeastOneRoleOnTeamById(userId: string, teamId: string, roleIds: string[]): Promise<boolean>;
16
+ userHasAllGlobalRolesById(userId: string, roleIds: string[]): Promise<boolean>;
17
+ userHasAllRolesOnTeamById(userId: string, teamId: string, roleIds: string[]): Promise<boolean>;
18
+ userHasGlobalRolesById(userId: string, roleIds: string[], combineWithAnd: boolean): Promise<boolean>;
19
+ userHasRolesOnTeamById(userId: string, teamId: string, roleIds: string[], combineWithAnd: boolean): Promise<boolean>;
20
+ userIsTeamMemberById(userId: string, teamId: string): Promise<boolean>;
21
+ userHasAnyRoleOnTeamById(userId: string, teamId: string): Promise<boolean>;
22
+ usersTeamMembershipsById(userId: string): Promise<string[]>;
23
+ userHasGlobalRole(user: WardenUserDecoration<any>, roleId: string): boolean;
24
+ userHasRoleOnTeam(user: WardenUserDecoration<any>, teamId: string, roleId: string): boolean;
25
+ userHasAtLeastOneGlobalRole(user: WardenUserDecoration<any>, roleIds: string[]): boolean;
26
+ userHasAtLeastOneRoleOnTeam(user: WardenUserDecoration<any>, teamId: string, roleIds: string[]): boolean;
27
+ userHasAllGlobalRoles(user: WardenUserDecoration<any>, roleIds: string[]): boolean;
28
+ userHasAllRolesOnTeam(user: WardenUserDecoration<any>, teamId: string, roleIds: string[]): boolean;
29
+ userHasGlobalRoles(user: WardenUserDecoration<any>, roleIds: string[], combineWithAnd: boolean): boolean;
30
+ userHasRolesOnTeam(user: WardenUserDecoration<any>, teamId: string, roleIds: string[], combineWithAnd: boolean): boolean;
31
+ wardenUserDecorationFromToken(jwt: WardenJwtToken<any>): WardenUserDecoration<any>;
32
+ userIsTeamMember(user: WardenUserDecoration<any>, teamId: string): boolean;
33
+ userHasAnyRoleOnTeam(user: WardenUserDecoration<any>, teamId: string): boolean;
34
+ usersTeamMemberships(user: WardenUserDecoration<any>): string[];
35
+ }
@@ -0,0 +1,88 @@
1
+ import { WardenUtils } from "@bitblit/ratchet-warden-common/common/util/warden-utils";
2
+ export class WardenAuthorizer {
3
+ opts;
4
+ constructor(opts) {
5
+ this.opts = opts;
6
+ }
7
+ findEntryByContact(contact) {
8
+ return this.opts.storageProvider.findEntryByContact(contact);
9
+ }
10
+ findEntryById(userId) {
11
+ return this.opts.storageProvider.findEntryById(userId);
12
+ }
13
+ async findDecoratorById(userId) {
14
+ const user = await this.findEntryById(userId);
15
+ const rval = user ? await this.opts.userDecorationProvider.fetchDecoration(user) : null;
16
+ return rval;
17
+ }
18
+ async userHasGlobalRoleById(userId, roleId) {
19
+ return this.userHasGlobalRole(await this.findDecoratorById(userId), roleId);
20
+ }
21
+ async userHasRoleOnTeamById(userId, teamId, roleId) {
22
+ return this.userHasRolesOnTeam(await this.findDecoratorById(userId), teamId, [roleId], true);
23
+ }
24
+ async userHasAtLeastOneGlobalRoleById(userId, roleIds) {
25
+ return this.userHasGlobalRoles(await this.findDecoratorById(userId), roleIds, false);
26
+ }
27
+ async userHasAtLeastOneRoleOnTeamById(userId, teamId, roleIds) {
28
+ return this.userHasRolesOnTeam(await this.findDecoratorById(userId), teamId, roleIds, false);
29
+ }
30
+ async userHasAllGlobalRolesById(userId, roleIds) {
31
+ return this.userHasGlobalRoles(await this.findDecoratorById(userId), roleIds, true);
32
+ }
33
+ async userHasAllRolesOnTeamById(userId, teamId, roleIds) {
34
+ return this.userHasRolesOnTeam(await this.findDecoratorById(userId), teamId, roleIds, true);
35
+ }
36
+ async userHasGlobalRolesById(userId, roleIds, combineWithAnd) {
37
+ return WardenUtils.userHasGlobalRoles(await this.findDecoratorById(userId), roleIds, combineWithAnd);
38
+ }
39
+ async userHasRolesOnTeamById(userId, teamId, roleIds, combineWithAnd) {
40
+ return WardenUtils.userHasRolesOnTeam(await this.findDecoratorById(userId), teamId, roleIds, combineWithAnd);
41
+ }
42
+ async userIsTeamMemberById(userId, teamId) {
43
+ return WardenUtils.userIsTeamMember(await this.findDecoratorById(userId), teamId);
44
+ }
45
+ async userHasAnyRoleOnTeamById(userId, teamId) {
46
+ return WardenUtils.userHasAnyRoleOnTeam(await this.findDecoratorById(userId), teamId);
47
+ }
48
+ async usersTeamMembershipsById(userId) {
49
+ return WardenUtils.usersTeamMemberships(await this.findDecoratorById(userId));
50
+ }
51
+ userHasGlobalRole(user, roleId) {
52
+ return WardenUtils.userHasGlobalRoles(user, [roleId], true);
53
+ }
54
+ userHasRoleOnTeam(user, teamId, roleId) {
55
+ return WardenUtils.userHasRolesOnTeam(user, teamId, [roleId], true);
56
+ }
57
+ userHasAtLeastOneGlobalRole(user, roleIds) {
58
+ return WardenUtils.userHasGlobalRoles(user, roleIds, false);
59
+ }
60
+ userHasAtLeastOneRoleOnTeam(user, teamId, roleIds) {
61
+ return WardenUtils.userHasRolesOnTeam(user, teamId, roleIds, false);
62
+ }
63
+ userHasAllGlobalRoles(user, roleIds) {
64
+ return WardenUtils.userHasGlobalRoles(user, roleIds, true);
65
+ }
66
+ userHasAllRolesOnTeam(user, teamId, roleIds) {
67
+ return WardenUtils.userHasRolesOnTeam(user, teamId, roleIds, true);
68
+ }
69
+ userHasGlobalRoles(user, roleIds, combineWithAnd) {
70
+ return WardenUtils.userHasGlobalRoles(user, roleIds, combineWithAnd);
71
+ }
72
+ userHasRolesOnTeam(user, teamId, roleIds, combineWithAnd) {
73
+ return WardenUtils.userHasRolesOnTeam(user, teamId, roleIds, combineWithAnd);
74
+ }
75
+ wardenUserDecorationFromToken(jwt) {
76
+ return WardenUtils.wardenUserDecorationFromToken(jwt);
77
+ }
78
+ userIsTeamMember(user, teamId) {
79
+ return WardenUtils.userIsTeamMember(user, teamId);
80
+ }
81
+ userHasAnyRoleOnTeam(user, teamId) {
82
+ return WardenUtils.userHasAnyRoleOnTeam(user, teamId);
83
+ }
84
+ usersTeamMemberships(user) {
85
+ return WardenUtils.usersTeamMemberships(user);
86
+ }
87
+ }
88
+ //# sourceMappingURL=warden-authorizer.js.map