@driveflux/api-functions 0.0.4 → 0.0.5

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 +9 -9
@@ -1,31 +1,212 @@
1
- import { prisma } from '@driveflux/db';
2
- import { userForEmailPreferencesQuery, } from './extract-email-preferences';
3
- export const updateEmailPreferences = async (idOrUserForEmailPreferences, preferences) => {
4
- const user = typeof idOrUserForEmailPreferences === 'string'
5
- ? await prisma.user.findUnique({
6
- where: { id: idOrUserForEmailPreferences },
7
- ...userForEmailPreferencesQuery,
8
- })
9
- : idOrUserForEmailPreferences;
10
- if (!user) {
11
- return null;
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);
12
13
  }
13
- const merged = {
14
- ...user.emailPreferences,
15
- ...preferences,
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
+ });
16
28
  };
17
- const updated = await prisma.user.update({
18
- where: { id: user.id },
19
- data: {
20
- emailPreferences: {
21
- upsert: {
22
- set: merged,
23
- update: merged,
24
- },
25
- },
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 _ts_generator(thisArg, body) {
59
+ var f, y, t, _ = {
60
+ label: 0,
61
+ sent: function() {
62
+ if (t[0] & 1) throw t[1];
63
+ return t[1];
26
64
  },
27
- ...userForEmailPreferencesQuery,
28
- });
29
- return updated;
65
+ trys: [],
66
+ ops: []
67
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
68
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
69
+ return this;
70
+ }), g;
71
+ function verb(n) {
72
+ return function(v) {
73
+ return step([
74
+ n,
75
+ v
76
+ ]);
77
+ };
78
+ }
79
+ function step(op) {
80
+ if (f) throw new TypeError("Generator is already executing.");
81
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
82
+ 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;
83
+ if (y = 0, t) op = [
84
+ op[0] & 2,
85
+ t.value
86
+ ];
87
+ switch(op[0]){
88
+ case 0:
89
+ case 1:
90
+ t = op;
91
+ break;
92
+ case 4:
93
+ _.label++;
94
+ return {
95
+ value: op[1],
96
+ done: false
97
+ };
98
+ case 5:
99
+ _.label++;
100
+ y = op[1];
101
+ op = [
102
+ 0
103
+ ];
104
+ continue;
105
+ case 7:
106
+ op = _.ops.pop();
107
+ _.trys.pop();
108
+ continue;
109
+ default:
110
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
111
+ _ = 0;
112
+ continue;
113
+ }
114
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
115
+ _.label = op[1];
116
+ break;
117
+ }
118
+ if (op[0] === 6 && _.label < t[1]) {
119
+ _.label = t[1];
120
+ t = op;
121
+ break;
122
+ }
123
+ if (t && _.label < t[2]) {
124
+ _.label = t[2];
125
+ _.ops.push(op);
126
+ break;
127
+ }
128
+ if (t[2]) _.ops.pop();
129
+ _.trys.pop();
130
+ continue;
131
+ }
132
+ op = body.call(thisArg, _);
133
+ } catch (e) {
134
+ op = [
135
+ 6,
136
+ e
137
+ ];
138
+ y = 0;
139
+ } finally{
140
+ f = t = 0;
141
+ }
142
+ if (op[0] & 5) throw op[1];
143
+ return {
144
+ value: op[0] ? op[1] : void 0,
145
+ done: true
146
+ };
147
+ }
148
+ }
149
+ import { prisma } from '@driveflux/db';
150
+ import { userForEmailPreferencesQuery } from './extract-email-preferences';
151
+ export var updateEmailPreferences = function(idOrUserForEmailPreferences, preferences) {
152
+ return _async_to_generator(function() {
153
+ var user, _tmp, merged, updated;
154
+ return _ts_generator(this, function(_state) {
155
+ switch(_state.label){
156
+ case 0:
157
+ if (!(typeof idOrUserForEmailPreferences === 'string')) return [
158
+ 3,
159
+ 2
160
+ ];
161
+ return [
162
+ 4,
163
+ prisma.user.findUnique(_object_spread({
164
+ where: {
165
+ id: idOrUserForEmailPreferences
166
+ }
167
+ }, userForEmailPreferencesQuery))
168
+ ];
169
+ case 1:
170
+ _tmp = _state.sent();
171
+ return [
172
+ 3,
173
+ 3
174
+ ];
175
+ case 2:
176
+ _tmp = idOrUserForEmailPreferences;
177
+ _state.label = 3;
178
+ case 3:
179
+ user = _tmp;
180
+ if (!user) {
181
+ return [
182
+ 2,
183
+ null
184
+ ];
185
+ }
186
+ merged = _object_spread({}, user.emailPreferences, preferences);
187
+ return [
188
+ 4,
189
+ prisma.user.update(_object_spread({
190
+ where: {
191
+ id: user.id
192
+ },
193
+ data: {
194
+ emailPreferences: {
195
+ upsert: {
196
+ set: merged,
197
+ update: merged
198
+ }
199
+ }
200
+ }
201
+ }, userForEmailPreferencesQuery))
202
+ ];
203
+ case 4:
204
+ updated = _state.sent();
205
+ return [
206
+ 2,
207
+ updated
208
+ ];
209
+ }
210
+ });
211
+ })();
30
212
  };
31
- //# sourceMappingURL=update-email-references.js.map
@@ -1,63 +1,212 @@
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 { slackLater } from '@driveflux/api-functions/slack';
2
122
  import { config } from '@driveflux/config/backend';
3
123
  import { initSingleton } from '@driveflux/singleton';
4
124
  import { Client } from '@notionhq/client';
5
- export const getNotion = () => {
6
- return initSingleton('notionClient', () => new Client({
7
- auth: config.notion.secret,
8
- }));
9
- };
10
- export const announceFluxstersAnniversaries = async (property, constructMessage) => {
11
- if (!config.notion.fluxstersDatabaseId) {
12
- return { counts: -1, message: 'No fluxsters database id configured' };
13
- }
14
- const notion = getNotion();
15
- const { results } = await notion.databases.query({
16
- database_id: config.notion.fluxstersDatabaseId,
125
+ export var getNotion = function() {
126
+ return initSingleton('notionClient', function() {
127
+ return new Client({
128
+ auth: config.notion.secret
129
+ });
17
130
  });
18
- const relevantPeople = results.filter((result) => {
19
- const resultPropperty = result.properties[property];
20
- if (resultPropperty.type !== 'date' || !resultPropperty.date?.start) {
21
- return false;
22
- }
23
- if (calculateYears(result, property) < 1) {
24
- return false;
25
- }
26
- const date = new Date(resultPropperty.date.start);
27
- const todayDate = new Date();
28
- if (todayDate.getDate() === date.getDate() &&
29
- todayDate.getMonth() === date.getMonth()) {
30
- return true;
31
- }
32
- // leap year
33
- if (todayDate.getDate() === 28 &&
34
- date.getDate() === 29 &&
35
- todayDate.getMonth() === 1 &&
36
- date.getMonth() === 1) {
37
- return true;
38
- }
39
- });
40
- if (relevantPeople.length > 0) {
41
- const message = constructMessage(relevantPeople);
42
- slackLater(message, config.slack.mainFluxChannel);
43
- return { counts: relevantPeople.length, message };
44
- }
45
- return { counts: relevantPeople.length };
46
131
  };
47
- export const getNameFrom = (person) => {
48
- const nameProperty = person.properties.Name;
132
+ export var announceFluxstersAnniversaries = function(property, constructMessage) {
133
+ return _async_to_generator(function() {
134
+ var notion, results, relevantPeople, message;
135
+ return _ts_generator(this, function(_state) {
136
+ switch(_state.label){
137
+ case 0:
138
+ if (!config.notion.fluxstersDatabaseId) {
139
+ return [
140
+ 2,
141
+ {
142
+ counts: -1,
143
+ message: 'No fluxsters database id configured'
144
+ }
145
+ ];
146
+ }
147
+ notion = getNotion();
148
+ return [
149
+ 4,
150
+ notion.databases.query({
151
+ database_id: config.notion.fluxstersDatabaseId
152
+ })
153
+ ];
154
+ case 1:
155
+ results = _state.sent().results;
156
+ relevantPeople = results.filter(function(result) {
157
+ var _resultPropperty_date;
158
+ var resultPropperty = result.properties[property];
159
+ if (resultPropperty.type !== 'date' || !((_resultPropperty_date = resultPropperty.date) === null || _resultPropperty_date === void 0 ? void 0 : _resultPropperty_date.start)) {
160
+ return false;
161
+ }
162
+ if (calculateYears(result, property) < 1) {
163
+ return false;
164
+ }
165
+ var date = new Date(resultPropperty.date.start);
166
+ var todayDate = new Date();
167
+ if (todayDate.getDate() === date.getDate() && todayDate.getMonth() === date.getMonth()) {
168
+ return true;
169
+ }
170
+ // leap year
171
+ if (todayDate.getDate() === 28 && date.getDate() === 29 && todayDate.getMonth() === 1 && date.getMonth() === 1) {
172
+ return true;
173
+ }
174
+ });
175
+ if (relevantPeople.length > 0) {
176
+ message = constructMessage(relevantPeople);
177
+ slackLater(message, config.slack.mainFluxChannel);
178
+ return [
179
+ 2,
180
+ {
181
+ counts: relevantPeople.length,
182
+ message: message
183
+ }
184
+ ];
185
+ }
186
+ return [
187
+ 2,
188
+ {
189
+ counts: relevantPeople.length
190
+ }
191
+ ];
192
+ }
193
+ });
194
+ })();
195
+ };
196
+ export var getNameFrom = function(person) {
197
+ var nameProperty = person.properties.Name;
49
198
  if (nameProperty.type !== 'title') {
50
199
  return '';
51
200
  }
52
201
  return nameProperty.title[0].plain_text;
53
202
  };
54
- export const calculateYears = (person, property) => {
55
- const joinedDateProperty = person.properties[property];
56
- if (joinedDateProperty.type !== 'date' || !joinedDateProperty.date?.start) {
203
+ export var calculateYears = function(person, property) {
204
+ var _joinedDateProperty_date, _joinedDateProperty_date1;
205
+ var joinedDateProperty = person.properties[property];
206
+ if (joinedDateProperty.type !== 'date' || !((_joinedDateProperty_date = joinedDateProperty.date) === null || _joinedDateProperty_date === void 0 ? void 0 : _joinedDateProperty_date.start)) {
57
207
  return 0;
58
208
  }
59
- const today = new Date();
60
- const joinedDate = new Date(joinedDateProperty.date?.start);
209
+ var today = new Date();
210
+ var joinedDate = new Date((_joinedDateProperty_date1 = joinedDateProperty.date) === null || _joinedDateProperty_date1 === void 0 ? void 0 : _joinedDateProperty_date1.start);
61
211
  return today.getFullYear() - joinedDate.getFullYear();
62
212
  };
63
- //# sourceMappingURL=client.js.map