@driveflux/api-functions 0.0.4 → 0.0.6

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 (56) hide show
  1. package/dist/auth/confirm.js +327 -73
  2. package/dist/auth/emails.js +210 -43
  3. package/dist/auth/formatter.js +11 -11
  4. package/dist/auth/otp.js +392 -122
  5. package/dist/auth/register.js +396 -100
  6. package/dist/auth/tokens.js +430 -115
  7. package/dist/auth/verifications.js +512 -154
  8. package/dist/constants.js +4 -5
  9. package/dist/mailjet/calls/manage-contacts-in-list.js +166 -22
  10. package/dist/mailjet/calls/manage-subscription-status.js +153 -13
  11. package/dist/mailjet/calls/request-service.js +183 -18
  12. package/dist/mailjet/refresh-email-preferences.d.ts +10 -10
  13. package/dist/mailjet/refresh-email-preferences.d.ts.map +1 -1
  14. package/dist/mailjet/refresh-email-preferences.js +226 -27
  15. package/dist/mailjet/refresh-email-preferences.js.map +1 -1
  16. package/dist/mailjet/set-contact.d.ts +10 -10
  17. package/dist/mailjet/set-contact.d.ts.map +1 -1
  18. package/dist/mailjet/set-contact.js +215 -24
  19. package/dist/mailjet/set-contact.js.map +1 -1
  20. package/dist/mailjet/types.js +1 -2
  21. package/dist/mailjet/utils/convert-to-array.js +58 -9
  22. package/dist/mailjet/utils/extract-email-preferences.d.ts +8 -8
  23. package/dist/mailjet/utils/extract-email-preferences.d.ts.map +1 -1
  24. package/dist/mailjet/utils/extract-email-preferences.js +218 -42
  25. package/dist/mailjet/utils/extract-email-preferences.js.map +1 -1
  26. package/dist/mailjet/utils/lists.js +249 -30
  27. package/dist/mailjet/utils/update-email-references.js +208 -27
  28. package/dist/notion/client.js +197 -48
  29. package/dist/notion/helpful.js +170 -29
  30. package/dist/notion/schemas/block.js +43 -49
  31. package/dist/notion/schemas/common.js +14 -17
  32. package/dist/notion/schemas/database.js +159 -125
  33. package/dist/notion/schemas/emoji.js +2 -3
  34. package/dist/notion/schemas/file.js +10 -10
  35. package/dist/notion/schemas/kb.js +8 -9
  36. package/dist/notion/schemas/page.js +171 -126
  37. package/dist/notion/schemas/parent.js +8 -9
  38. package/dist/notion/schemas/user.js +20 -21
  39. package/dist/reservation/agree.js +158 -19
  40. package/dist/reservation/checks.js +178 -23
  41. package/dist/reservation/display-vehicle.js +514 -142
  42. package/dist/reservation/fetch-or-create.js +482 -197
  43. package/dist/reservation/invoice.js +496 -198
  44. package/dist/reservation/payer.js +177 -28
  45. package/dist/reservation/reserve.js +191 -31
  46. package/dist/reservation/types.js +1 -2
  47. package/dist/reservation/vehicle.js +186 -24
  48. package/dist/slack.js +273 -67
  49. package/dist/validation.d.ts +19 -13
  50. package/dist/validation.d.ts.map +1 -1
  51. package/dist/validation.js +144 -63
  52. package/dist/validation.js.map +1 -1
  53. package/dist/vehicle/vehicle-pricing/constants.js +36 -33
  54. package/dist/vehicle/vehicle-pricing/index.js +257 -99
  55. package/dist/vehicle/vehicle-pricing/types.js +1 -2
  56. package/package.json +14 -14
@@ -1,3 +1,202 @@
1
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
2
+ try {
3
+ var info = gen[key](arg);
4
+ var value = info.value;
5
+ } catch (error) {
6
+ reject(error);
7
+ return;
8
+ }
9
+ if (info.done) {
10
+ resolve(value);
11
+ } else {
12
+ Promise.resolve(value).then(_next, _throw);
13
+ }
14
+ }
15
+ function _async_to_generator(fn) {
16
+ return function() {
17
+ var self = this, args = arguments;
18
+ return new Promise(function(resolve, reject) {
19
+ var gen = fn.apply(self, args);
20
+ function _next(value) {
21
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
22
+ }
23
+ function _throw(err) {
24
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
25
+ }
26
+ _next(undefined);
27
+ });
28
+ };
29
+ }
30
+ function _define_property(obj, key, value) {
31
+ if (key in obj) {
32
+ Object.defineProperty(obj, key, {
33
+ value: value,
34
+ enumerable: true,
35
+ configurable: true,
36
+ writable: true
37
+ });
38
+ } else {
39
+ obj[key] = value;
40
+ }
41
+ return obj;
42
+ }
43
+ function _object_spread(target) {
44
+ for(var i = 1; i < arguments.length; i++){
45
+ var source = arguments[i] != null ? arguments[i] : {};
46
+ var ownKeys = Object.keys(source);
47
+ if (typeof Object.getOwnPropertySymbols === "function") {
48
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
49
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
50
+ }));
51
+ }
52
+ ownKeys.forEach(function(key) {
53
+ _define_property(target, key, source[key]);
54
+ });
55
+ }
56
+ return target;
57
+ }
58
+ function ownKeys(object, enumerableOnly) {
59
+ var keys = Object.keys(object);
60
+ if (Object.getOwnPropertySymbols) {
61
+ var symbols = Object.getOwnPropertySymbols(object);
62
+ if (enumerableOnly) {
63
+ symbols = symbols.filter(function(sym) {
64
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
65
+ });
66
+ }
67
+ keys.push.apply(keys, symbols);
68
+ }
69
+ return keys;
70
+ }
71
+ function _object_spread_props(target, source) {
72
+ source = source != null ? source : {};
73
+ if (Object.getOwnPropertyDescriptors) {
74
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
75
+ } else {
76
+ ownKeys(Object(source)).forEach(function(key) {
77
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
78
+ });
79
+ }
80
+ return target;
81
+ }
82
+ function _object_without_properties(source, excluded) {
83
+ if (source == null) return {};
84
+ var target = _object_without_properties_loose(source, excluded);
85
+ var key, i;
86
+ if (Object.getOwnPropertySymbols) {
87
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
88
+ for(i = 0; i < sourceSymbolKeys.length; i++){
89
+ key = sourceSymbolKeys[i];
90
+ if (excluded.indexOf(key) >= 0) continue;
91
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
92
+ target[key] = source[key];
93
+ }
94
+ }
95
+ return target;
96
+ }
97
+ function _object_without_properties_loose(source, excluded) {
98
+ if (source == null) return {};
99
+ var target = {};
100
+ var sourceKeys = Object.keys(source);
101
+ var key, i;
102
+ for(i = 0; i < sourceKeys.length; i++){
103
+ key = sourceKeys[i];
104
+ if (excluded.indexOf(key) >= 0) continue;
105
+ target[key] = source[key];
106
+ }
107
+ return target;
108
+ }
109
+ function _ts_generator(thisArg, body) {
110
+ var f, y, t, _ = {
111
+ label: 0,
112
+ sent: function() {
113
+ if (t[0] & 1) throw t[1];
114
+ return t[1];
115
+ },
116
+ trys: [],
117
+ ops: []
118
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
119
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
120
+ return this;
121
+ }), g;
122
+ function verb(n) {
123
+ return function(v) {
124
+ return step([
125
+ n,
126
+ v
127
+ ]);
128
+ };
129
+ }
130
+ function step(op) {
131
+ if (f) throw new TypeError("Generator is already executing.");
132
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
133
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
134
+ if (y = 0, t) op = [
135
+ op[0] & 2,
136
+ t.value
137
+ ];
138
+ switch(op[0]){
139
+ case 0:
140
+ case 1:
141
+ t = op;
142
+ break;
143
+ case 4:
144
+ _.label++;
145
+ return {
146
+ value: op[1],
147
+ done: false
148
+ };
149
+ case 5:
150
+ _.label++;
151
+ y = op[1];
152
+ op = [
153
+ 0
154
+ ];
155
+ continue;
156
+ case 7:
157
+ op = _.ops.pop();
158
+ _.trys.pop();
159
+ continue;
160
+ default:
161
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
162
+ _ = 0;
163
+ continue;
164
+ }
165
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
166
+ _.label = op[1];
167
+ break;
168
+ }
169
+ if (op[0] === 6 && _.label < t[1]) {
170
+ _.label = t[1];
171
+ t = op;
172
+ break;
173
+ }
174
+ if (t && _.label < t[2]) {
175
+ _.label = t[2];
176
+ _.ops.push(op);
177
+ break;
178
+ }
179
+ if (t[2]) _.ops.pop();
180
+ _.trys.pop();
181
+ continue;
182
+ }
183
+ op = body.call(thisArg, _);
184
+ } catch (e) {
185
+ op = [
186
+ 6,
187
+ e
188
+ ];
189
+ y = 0;
190
+ } finally{
191
+ f = t = 0;
192
+ }
193
+ if (op[0] & 5) throw op[1];
194
+ return {
195
+ value: op[0] ? op[1] : void 0,
196
+ done: true
197
+ };
198
+ }
199
+ }
1
200
  import { refreshEmailPreferences } from '@driveflux/api-functions/mailjet/refresh-email-preferences';
2
201
  import { prisma } from '@driveflux/db';
3
202
  import { generateId } from '@driveflux/db/id';
@@ -8,81 +207,136 @@ import { addDays } from 'date-fns/addDays';
8
207
  import { z } from 'zod';
9
208
  import { clearToken, verifyToken } from './tokens.js';
10
209
  import { sendVerificationEmail } from './verifications.js';
11
- const Body = z.object({
210
+ var Body = z.object({
12
211
  firstName: z.string(),
13
212
  lastName: z.string(),
14
- phoneNumber: z.string().transform((s) => s.replace(/[\s-]/g, '')),
213
+ phoneNumber: z.string().transform(function(s) {
214
+ return s.replace(/[\s-]/g, '');
215
+ }),
15
216
  code: z.string().optional().nullable(),
16
- email: z
17
- .string()
18
- .email()
19
- .transform((s) => s.toLowerCase().trim()),
20
- pageSource: z.string().optional().nullable(),
217
+ email: z.string().email().transform(function(s) {
218
+ return s.toLowerCase().trim();
219
+ }),
220
+ pageSource: z.string().optional().nullable()
21
221
  });
22
- export const handleConfirmUser = async (b, user, xForwardedFor) => {
23
- const { phoneNumber, email, code, pageSource, ...body } = Body.parse(b);
24
- let phoneNumberVerified = false;
25
- if (code) {
26
- const tokenResult = await verifyToken(code, { scope: 'verify-phone' });
27
- if (tokenResult.err) {
28
- return new Err(makeProblem(PROBLEM_CONFLICT, 'Invalid OTP token'));
29
- }
30
- await clearToken(tokenResult.val.id);
31
- phoneNumberVerified = true;
32
- }
33
- else {
34
- phoneNumberVerified = user.phoneNumberVerified;
35
- }
36
- const method = isMetadata(user?.metadata)
37
- ? user?.metadata?.signupProvider
38
- : undefined;
39
- const updatedUser = await prisma.user.update({
40
- where: {
41
- id: user.id,
42
- },
43
- data: {
44
- ...body,
45
- phoneNumber: phoneNumber?.replace(/[\s-]/g, ''),
46
- preferredCurrency: 'MYR',
47
- preferredLocale: 'en',
48
- phoneNumberVerified,
49
- consented: true,
50
- groups: ['member'],
51
- signupParams: {
52
- method,
53
- source: pageSource,
54
- },
55
- consents: {
56
- create: {
57
- id: generateId('UserConsent'),
58
- ipAddress: Array.isArray(xForwardedFor)
59
- ? xForwardedFor?.[0] || '0.0.0.0'
60
- : xForwardedFor || '0.0.0.0',
61
- consentType: 'terms',
62
- email: email,
63
- },
64
- },
65
- registrationComplete: true,
66
- },
67
- });
68
- const token = await prisma.token.create({
69
- data: {
70
- id: generateId('Token'),
71
- user: {
72
- connect: {
73
- id: updatedUser.id,
74
- },
75
- },
76
- expiresAt: addDays(new Date(), 365),
77
- scope: 'all',
78
- },
79
- });
80
- // We don't want this to be a task. It should be instant
81
- await sendVerificationEmail(updatedUser.id);
82
- await refreshEmailPreferences(updatedUser.id);
83
- return new Ok({
84
- token,
85
- user: updatedUser,
86
- });
222
+ export var handleConfirmUser = function(b, user, xForwardedFor) {
223
+ return _async_to_generator(function() {
224
+ var _user_metadata, _Body_parse, phoneNumber, email, code, pageSource, body, phoneNumberVerified, tokenResult, method, updatedUser, token;
225
+ return _ts_generator(this, function(_state) {
226
+ switch(_state.label){
227
+ case 0:
228
+ _Body_parse = Body.parse(b), phoneNumber = _Body_parse.phoneNumber, email = _Body_parse.email, code = _Body_parse.code, pageSource = _Body_parse.pageSource, body = _object_without_properties(_Body_parse, [
229
+ "phoneNumber",
230
+ "email",
231
+ "code",
232
+ "pageSource"
233
+ ]);
234
+ phoneNumberVerified = false;
235
+ if (!code) return [
236
+ 3,
237
+ 3
238
+ ];
239
+ return [
240
+ 4,
241
+ verifyToken(code, {
242
+ scope: 'verify-phone'
243
+ })
244
+ ];
245
+ case 1:
246
+ tokenResult = _state.sent();
247
+ if (tokenResult.err) {
248
+ return [
249
+ 2,
250
+ new Err(makeProblem(PROBLEM_CONFLICT, 'Invalid OTP token'))
251
+ ];
252
+ }
253
+ return [
254
+ 4,
255
+ clearToken(tokenResult.val.id)
256
+ ];
257
+ case 2:
258
+ _state.sent();
259
+ phoneNumberVerified = true;
260
+ return [
261
+ 3,
262
+ 4
263
+ ];
264
+ case 3:
265
+ phoneNumberVerified = user.phoneNumberVerified;
266
+ _state.label = 4;
267
+ case 4:
268
+ method = isMetadata(user === null || user === void 0 ? void 0 : user.metadata) ? user === null || user === void 0 ? void 0 : (_user_metadata = user.metadata) === null || _user_metadata === void 0 ? void 0 : _user_metadata.signupProvider : undefined;
269
+ return [
270
+ 4,
271
+ prisma.user.update({
272
+ where: {
273
+ id: user.id
274
+ },
275
+ data: _object_spread_props(_object_spread({}, body), {
276
+ phoneNumber: phoneNumber === null || phoneNumber === void 0 ? void 0 : phoneNumber.replace(/[\s-]/g, ''),
277
+ preferredCurrency: 'MYR',
278
+ preferredLocale: 'en',
279
+ phoneNumberVerified: phoneNumberVerified,
280
+ consented: true,
281
+ groups: [
282
+ 'member'
283
+ ],
284
+ signupParams: {
285
+ method: method,
286
+ source: pageSource
287
+ },
288
+ consents: {
289
+ create: {
290
+ id: generateId('UserConsent'),
291
+ ipAddress: Array.isArray(xForwardedFor) ? (xForwardedFor === null || xForwardedFor === void 0 ? void 0 : xForwardedFor[0]) || '0.0.0.0' : xForwardedFor || '0.0.0.0',
292
+ consentType: 'terms',
293
+ email: email
294
+ }
295
+ },
296
+ registrationComplete: true
297
+ })
298
+ })
299
+ ];
300
+ case 5:
301
+ updatedUser = _state.sent();
302
+ return [
303
+ 4,
304
+ prisma.token.create({
305
+ data: {
306
+ id: generateId('Token'),
307
+ user: {
308
+ connect: {
309
+ id: updatedUser.id
310
+ }
311
+ },
312
+ expiresAt: addDays(new Date(), 365),
313
+ scope: 'all'
314
+ }
315
+ })
316
+ ];
317
+ case 6:
318
+ token = _state.sent();
319
+ // We don't want this to be a task. It should be instant
320
+ return [
321
+ 4,
322
+ sendVerificationEmail(updatedUser.id)
323
+ ];
324
+ case 7:
325
+ _state.sent();
326
+ return [
327
+ 4,
328
+ refreshEmailPreferences(updatedUser.id)
329
+ ];
330
+ case 8:
331
+ _state.sent();
332
+ return [
333
+ 2,
334
+ new Ok({
335
+ token: token,
336
+ user: updatedUser
337
+ })
338
+ ];
339
+ }
340
+ });
341
+ })();
87
342
  };
88
- //# sourceMappingURL=confirm.js.map
@@ -1,51 +1,218 @@
1
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
2
+ try {
3
+ var info = gen[key](arg);
4
+ var value = info.value;
5
+ } catch (error) {
6
+ reject(error);
7
+ return;
8
+ }
9
+ if (info.done) {
10
+ resolve(value);
11
+ } else {
12
+ Promise.resolve(value).then(_next, _throw);
13
+ }
14
+ }
15
+ function _async_to_generator(fn) {
16
+ return function() {
17
+ var self = this, args = arguments;
18
+ return new Promise(function(resolve, reject) {
19
+ var gen = fn.apply(self, args);
20
+ function _next(value) {
21
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
22
+ }
23
+ function _throw(err) {
24
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
25
+ }
26
+ _next(undefined);
27
+ });
28
+ };
29
+ }
30
+ function _ts_generator(thisArg, body) {
31
+ var f, y, t, _ = {
32
+ label: 0,
33
+ sent: function() {
34
+ if (t[0] & 1) throw t[1];
35
+ return t[1];
36
+ },
37
+ trys: [],
38
+ ops: []
39
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
40
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
41
+ return this;
42
+ }), g;
43
+ function verb(n) {
44
+ return function(v) {
45
+ return step([
46
+ n,
47
+ v
48
+ ]);
49
+ };
50
+ }
51
+ function step(op) {
52
+ if (f) throw new TypeError("Generator is already executing.");
53
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
54
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
55
+ if (y = 0, t) op = [
56
+ op[0] & 2,
57
+ t.value
58
+ ];
59
+ switch(op[0]){
60
+ case 0:
61
+ case 1:
62
+ t = op;
63
+ break;
64
+ case 4:
65
+ _.label++;
66
+ return {
67
+ value: op[1],
68
+ done: false
69
+ };
70
+ case 5:
71
+ _.label++;
72
+ y = op[1];
73
+ op = [
74
+ 0
75
+ ];
76
+ continue;
77
+ case 7:
78
+ op = _.ops.pop();
79
+ _.trys.pop();
80
+ continue;
81
+ default:
82
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
83
+ _ = 0;
84
+ continue;
85
+ }
86
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
87
+ _.label = op[1];
88
+ break;
89
+ }
90
+ if (op[0] === 6 && _.label < t[1]) {
91
+ _.label = t[1];
92
+ t = op;
93
+ break;
94
+ }
95
+ if (t && _.label < t[2]) {
96
+ _.label = t[2];
97
+ _.ops.push(op);
98
+ break;
99
+ }
100
+ if (t[2]) _.ops.pop();
101
+ _.trys.pop();
102
+ continue;
103
+ }
104
+ op = body.call(thisArg, _);
105
+ } catch (e) {
106
+ op = [
107
+ 6,
108
+ e
109
+ ];
110
+ y = 0;
111
+ } finally{
112
+ f = t = 0;
113
+ }
114
+ if (op[0] & 5) throw op[1];
115
+ return {
116
+ value: op[0] ? op[1] : void 0,
117
+ done: true
118
+ };
119
+ }
120
+ }
1
121
  import { prisma } from '@driveflux/db';
2
122
  import { send } from '@driveflux/email';
3
123
  import { emailChangedEmail } from '@driveflux/email-templates/flux/email-changed';
4
124
  import { passwordChangedEmail } from '@driveflux/email-templates/flux/password-changed';
5
125
  import { makeProblem, PROBLEM_NOT_FOUND } from '@driveflux/problem';
6
126
  import { Err } from '@driveflux/result';
7
- export const sendEmailChangedEmail = async (userId) => {
8
- const user = await prisma.user.findUnique({
9
- where: {
10
- id: userId,
11
- },
12
- });
13
- if (!user) {
14
- return new Err(makeProblem(PROBLEM_NOT_FOUND, `The user ${userId} was not found`));
15
- }
16
- return await send({
17
- subject: 'Email change confirmation',
18
- to: {
19
- name: user.firstName || '',
20
- address: user.email,
21
- },
22
- html: emailChangedEmail({
23
- user: user.firstName || '',
24
- title: 'Email change confirmation',
25
- newEmail: user.email,
26
- }),
27
- });
127
+ export var sendEmailChangedEmail = function(userId) {
128
+ return _async_to_generator(function() {
129
+ var user;
130
+ return _ts_generator(this, function(_state) {
131
+ switch(_state.label){
132
+ case 0:
133
+ return [
134
+ 4,
135
+ prisma.user.findUnique({
136
+ where: {
137
+ id: userId
138
+ }
139
+ })
140
+ ];
141
+ case 1:
142
+ user = _state.sent();
143
+ if (!user) {
144
+ return [
145
+ 2,
146
+ new Err(makeProblem(PROBLEM_NOT_FOUND, "The user ".concat(userId, " was not found")))
147
+ ];
148
+ }
149
+ return [
150
+ 4,
151
+ send({
152
+ subject: 'Email change confirmation',
153
+ to: {
154
+ name: user.firstName || '',
155
+ address: user.email
156
+ },
157
+ html: emailChangedEmail({
158
+ user: user.firstName || '',
159
+ title: 'Email change confirmation',
160
+ newEmail: user.email
161
+ })
162
+ })
163
+ ];
164
+ case 2:
165
+ return [
166
+ 2,
167
+ _state.sent()
168
+ ];
169
+ }
170
+ });
171
+ })();
28
172
  };
29
- export const sendPasswordChangedEmail = async (userId) => {
30
- const user = await prisma.user.findUnique({
31
- where: {
32
- id: userId,
33
- },
34
- });
35
- if (!user) {
36
- return new Err(makeProblem(PROBLEM_NOT_FOUND, `The user ${userId} was not found`));
37
- }
38
- const title = 'Password changed';
39
- return await send({
40
- subject: title,
41
- to: {
42
- name: user.firstName || '',
43
- address: user.email,
44
- },
45
- html: passwordChangedEmail({
46
- user: user.firstName || '',
47
- title: title,
48
- }),
49
- });
173
+ export var sendPasswordChangedEmail = function(userId) {
174
+ return _async_to_generator(function() {
175
+ var user, title;
176
+ return _ts_generator(this, function(_state) {
177
+ switch(_state.label){
178
+ case 0:
179
+ return [
180
+ 4,
181
+ prisma.user.findUnique({
182
+ where: {
183
+ id: userId
184
+ }
185
+ })
186
+ ];
187
+ case 1:
188
+ user = _state.sent();
189
+ if (!user) {
190
+ return [
191
+ 2,
192
+ new Err(makeProblem(PROBLEM_NOT_FOUND, "The user ".concat(userId, " was not found")))
193
+ ];
194
+ }
195
+ title = 'Password changed';
196
+ return [
197
+ 4,
198
+ send({
199
+ subject: title,
200
+ to: {
201
+ name: user.firstName || '',
202
+ address: user.email
203
+ },
204
+ html: passwordChangedEmail({
205
+ user: user.firstName || '',
206
+ title: title
207
+ })
208
+ })
209
+ ];
210
+ case 2:
211
+ return [
212
+ 2,
213
+ _state.sent()
214
+ ];
215
+ }
216
+ });
217
+ })();
50
218
  };
51
- //# sourceMappingURL=emails.js.map