@almaviacx/gge-toolkit-service 1.0.4 → 1.0.7
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/index.d.ts +1 -0
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/models/Context.d.ts +1 -0
- package/dist/models/FlexFlow.d.ts +5 -0
- package/dist/utils/flexFlows.d.ts +4 -0
- package/dist/utils/flexFlows.js +117 -0
- package/dist/utils/flexFlows.js.map +1 -0
- package/dist/utils/video.js +24 -27
- package/dist/utils/video.js.map +1 -1
- package/package.json +1 -1
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.workerUtil = exports.videoUtil = exports.phonenumber = exports.PhoneCache = exports.getCustomMessage = exports.callReason = void 0;
|
|
3
|
+
exports.flexFlowsUtil = exports.workerUtil = exports.videoUtil = exports.phonenumber = exports.PhoneCache = exports.getCustomMessage = exports.callReason = void 0;
|
|
4
4
|
exports.callReason = require("./utils/callreason");
|
|
5
5
|
var message_1 = require("./utils/message");
|
|
6
6
|
Object.defineProperty(exports, "getCustomMessage", { enumerable: true, get: function () { return message_1.getCustomMessage; } });
|
|
@@ -9,4 +9,5 @@ Object.defineProperty(exports, "PhoneCache", { enumerable: true, get: function (
|
|
|
9
9
|
exports.phonenumber = require("./utils/phonenumber");
|
|
10
10
|
exports.videoUtil = require("./utils/video");
|
|
11
11
|
exports.workerUtil = require("./utils/worker");
|
|
12
|
+
exports.flexFlowsUtil = require("./utils/flexFlows");
|
|
12
13
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,mDAAiD;AACjD,2CAAmD;AAA1C,2GAAA,gBAAgB,OAAA;AACzB,iDAAgD;AAAvC,wGAAA,UAAU,OAAA;AACnB,qDAAmD;AACnD,6CAA2C;AAC3C,+CAA6C"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,mDAAiD;AACjD,2CAAmD;AAA1C,2GAAA,gBAAgB,OAAA;AACzB,iDAAgD;AAAvC,wGAAA,UAAU,OAAA;AACnB,qDAAmD;AACnD,6CAA2C;AAC3C,+CAA6C;AAC7C,qDAAmD"}
|
package/dist/models/Context.d.ts
CHANGED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Twilio } from "twilio";
|
|
2
|
+
import { Context } from "../models";
|
|
3
|
+
export declare const getFlowsConfiguration: (context: Context, client: Twilio, phone: string, channelType: string) => Promise<any>;
|
|
4
|
+
export declare const getWechatFlexFlowSid: (context: Context, client: Twilio, accountId: string) => Promise<any>;
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
+
function step(op) {
|
|
16
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
+
while (_) try {
|
|
18
|
+
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;
|
|
19
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
+
switch (op[0]) {
|
|
21
|
+
case 0: case 1: t = op; break;
|
|
22
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
+
default:
|
|
26
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
+
if (t[2]) _.ops.pop();
|
|
31
|
+
_.trys.pop(); continue;
|
|
32
|
+
}
|
|
33
|
+
op = body.call(thisArg, _);
|
|
34
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.getWechatFlexFlowSid = exports.getFlowsConfiguration = void 0;
|
|
40
|
+
var getDoc = function (context, client) { return __awaiter(void 0, void 0, void 0, function () {
|
|
41
|
+
return __generator(this, function (_a) {
|
|
42
|
+
switch (_a.label) {
|
|
43
|
+
case 0: return [4 /*yield*/, client.sync.services(context.SYNCSERVICE_SID)
|
|
44
|
+
.documents(context.CONFIG_SYNC_SID)
|
|
45
|
+
.fetch()];
|
|
46
|
+
case 1: return [2 /*return*/, _a.sent()];
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
}); };
|
|
50
|
+
var getFlexFlow = function (list, phone) {
|
|
51
|
+
var conf = list.find(function (p) { return p.phone === phone; });
|
|
52
|
+
return conf === null || conf === void 0 ? void 0 : conf.studioFlow;
|
|
53
|
+
};
|
|
54
|
+
var getFlowsConfiguration = function (context, client, phone, channelType) { return __awaiter(void 0, void 0, void 0, function () {
|
|
55
|
+
var camp, _a, doc, doc, doc, item;
|
|
56
|
+
var _b, _c;
|
|
57
|
+
return __generator(this, function (_d) {
|
|
58
|
+
switch (_d.label) {
|
|
59
|
+
case 0:
|
|
60
|
+
camp = phone;
|
|
61
|
+
_a = channelType;
|
|
62
|
+
switch (_a) {
|
|
63
|
+
case "video": return [3 /*break*/, 1];
|
|
64
|
+
case "facebook": return [3 /*break*/, 4];
|
|
65
|
+
case "wechat": return [3 /*break*/, 6];
|
|
66
|
+
}
|
|
67
|
+
return [3 /*break*/, 8];
|
|
68
|
+
case 1:
|
|
69
|
+
if (!(phone === "default" && channelType === "video")) return [3 /*break*/, 3];
|
|
70
|
+
return [4 /*yield*/, getDoc(context, client)];
|
|
71
|
+
case 2:
|
|
72
|
+
doc = _d.sent();
|
|
73
|
+
camp = (_c = (_b = doc === null || doc === void 0 ? void 0 : doc.data) === null || _b === void 0 ? void 0 : _b.video) === null || _c === void 0 ? void 0 : _c.defaultPhone;
|
|
74
|
+
_d.label = 3;
|
|
75
|
+
case 3: return [3 /*break*/, 8];
|
|
76
|
+
case 4: return [4 /*yield*/, getDoc(context, client)];
|
|
77
|
+
case 5:
|
|
78
|
+
doc = _d.sent();
|
|
79
|
+
if (doc && doc.data && doc.data.facebook && doc.data.facebook.pages) {
|
|
80
|
+
return [2 /*return*/, { studioFlow: getFlexFlow(doc.data.facebook.pages, phone) }];
|
|
81
|
+
}
|
|
82
|
+
return [2 /*return*/, undefined];
|
|
83
|
+
case 6: return [4 /*yield*/, getDoc(context, client)];
|
|
84
|
+
case 7:
|
|
85
|
+
doc = _d.sent();
|
|
86
|
+
if (doc && doc.data && doc.data.wechat && doc.data.wechat.accounts) {
|
|
87
|
+
return [2 /*return*/, { studioFlow: getFlexFlow(doc.data.wechat.accounts, phone) }];
|
|
88
|
+
}
|
|
89
|
+
return [2 /*return*/, undefined];
|
|
90
|
+
case 8: return [4 /*yield*/, client.sync.services(context.SYNCSERVICE_SID)
|
|
91
|
+
.syncMaps(context.SYNC_PHONE_MAP_SID)
|
|
92
|
+
.syncMapItems(camp)
|
|
93
|
+
.fetch()];
|
|
94
|
+
case 9:
|
|
95
|
+
item = _d.sent();
|
|
96
|
+
return [2 /*return*/, item === null || item === void 0 ? void 0 : item.data[channelType]];
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
}); };
|
|
100
|
+
exports.getFlowsConfiguration = getFlowsConfiguration;
|
|
101
|
+
var getWechatFlexFlowSid = function (context, client, accountId) { return __awaiter(void 0, void 0, void 0, function () {
|
|
102
|
+
var doc, account;
|
|
103
|
+
return __generator(this, function (_a) {
|
|
104
|
+
switch (_a.label) {
|
|
105
|
+
case 0: return [4 /*yield*/, getDoc(context, client)];
|
|
106
|
+
case 1:
|
|
107
|
+
doc = _a.sent();
|
|
108
|
+
if (doc && doc.data && doc.data.wechat && doc.data.wechat.accounts) {
|
|
109
|
+
account = doc.data.wechat.accounts.find(function (a) { return a.id === accountId; });
|
|
110
|
+
return [2 /*return*/, account === null || account === void 0 ? void 0 : account.flexFlow];
|
|
111
|
+
}
|
|
112
|
+
return [2 /*return*/, undefined];
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
}); };
|
|
116
|
+
exports.getWechatFlexFlowSid = getWechatFlexFlowSid;
|
|
117
|
+
//# sourceMappingURL=flexFlows.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flexFlows.js","sourceRoot":"","sources":["../../src/utils/flexFlows.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/video.js
CHANGED
|
@@ -39,7 +39,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
39
39
|
exports.getVideoUrlTemplated = exports.saveVideoData = exports.findVideoUiBaseUrl = void 0;
|
|
40
40
|
var mustache = require("mustache");
|
|
41
41
|
var nanoid_1 = require("nanoid");
|
|
42
|
-
var twilio_toolkit_service_1 = require("@almaviacx/twilio-toolkit-service");
|
|
43
42
|
var findVideoUiBaseUrl = function (context) { return __awaiter(void 0, void 0, void 0, function () {
|
|
44
43
|
var client, SYNCSERVICE_SID, CONFIG_SYNC_SID, doc, serviceList, service, envList;
|
|
45
44
|
var _a, _b;
|
|
@@ -97,7 +96,7 @@ var getVideoLinkTtl = function (context, attributes, taskCreated) { return __awa
|
|
|
97
96
|
});
|
|
98
97
|
}); };
|
|
99
98
|
var saveVideoData = function (context, attributes, taskCreated, workflowSid, prevKey) { return __awaiter(void 0, void 0, void 0, function () {
|
|
100
|
-
var logger, client, SYNCSERVICE_SID, SYNCMAP_SID, ttlTask, key, data,
|
|
99
|
+
var logger, client, SYNCSERVICE_SID, SYNCMAP_SID, ttlTask, key, data, error_1, ttl;
|
|
101
100
|
return __generator(this, function (_a) {
|
|
102
101
|
switch (_a.label) {
|
|
103
102
|
case 0:
|
|
@@ -106,26 +105,24 @@ var saveVideoData = function (context, attributes, taskCreated, workflowSid, pre
|
|
|
106
105
|
SYNCSERVICE_SID = context.SYNCSERVICE_SID, SYNCMAP_SID = context.SYNCMAP_SID;
|
|
107
106
|
ttlTask = getVideoLinkTtl(context, attributes, taskCreated);
|
|
108
107
|
key = prevKey || (0, nanoid_1.nanoid)(6);
|
|
109
|
-
if (!!prevKey) return [3 /*break*/,
|
|
110
|
-
|
|
111
|
-
var key, data;
|
|
112
|
-
return __generator(this, function (_a) {
|
|
113
|
-
switch (_a.label) {
|
|
114
|
-
case 0:
|
|
115
|
-
key = (0, nanoid_1.nanoid)(6);
|
|
116
|
-
return [4 /*yield*/, client.sync.services(SYNCSERVICE_SID).syncMaps(SYNCMAP_SID).syncMapItems(key).fetch()];
|
|
117
|
-
case 1:
|
|
118
|
-
data = _a.sent();
|
|
119
|
-
return [2 /*return*/, { key: key, data: data }];
|
|
120
|
-
}
|
|
121
|
-
});
|
|
122
|
-
}); }, { retry: 3, time: 100 })];
|
|
108
|
+
if (!!prevKey) return [3 /*break*/, 6];
|
|
109
|
+
_a.label = 1;
|
|
123
110
|
case 1:
|
|
124
|
-
|
|
125
|
-
key = result.key;
|
|
126
|
-
data = result.data;
|
|
111
|
+
key = (0, nanoid_1.nanoid)(6);
|
|
127
112
|
_a.label = 2;
|
|
128
113
|
case 2:
|
|
114
|
+
_a.trys.push([2, 4, , 5]);
|
|
115
|
+
return [4 /*yield*/, client.sync.services(SYNCSERVICE_SID).syncMaps(SYNCMAP_SID).syncMapItems(key).fetch()];
|
|
116
|
+
case 3:
|
|
117
|
+
data = _a.sent();
|
|
118
|
+
return [3 /*break*/, 5];
|
|
119
|
+
case 4:
|
|
120
|
+
error_1 = _a.sent();
|
|
121
|
+
return [3 /*break*/, 5];
|
|
122
|
+
case 5:
|
|
123
|
+
if (data != null) return [3 /*break*/, 1];
|
|
124
|
+
_a.label = 6;
|
|
125
|
+
case 6:
|
|
129
126
|
if (!workflowSid) {
|
|
130
127
|
data = { attributes: attributes, taskCreated: taskCreated };
|
|
131
128
|
}
|
|
@@ -137,19 +134,19 @@ var saveVideoData = function (context, attributes, taskCreated, workflowSid, pre
|
|
|
137
134
|
data = { attributes: attributes, taskCreated: taskCreated, flowSid: workflowSid.sid, flowName: workflowSid.friendlyName };
|
|
138
135
|
}
|
|
139
136
|
return [4 /*yield*/, ttlTask];
|
|
140
|
-
case
|
|
137
|
+
case 7:
|
|
141
138
|
ttl = _a.sent();
|
|
142
139
|
logger.info("Save video data with key ".concat(key, " with an availability of ").concat(ttl, " seconds"), attributes);
|
|
143
|
-
if (!prevKey) return [3 /*break*/,
|
|
140
|
+
if (!prevKey) return [3 /*break*/, 9];
|
|
144
141
|
return [4 /*yield*/, client.sync.services(SYNCSERVICE_SID).syncMaps(SYNCMAP_SID).syncMapItems(key).update({ data: data, ttl: ttl })];
|
|
145
|
-
case
|
|
142
|
+
case 8:
|
|
146
143
|
_a.sent();
|
|
147
|
-
return [3 /*break*/,
|
|
148
|
-
case
|
|
149
|
-
case
|
|
144
|
+
return [3 /*break*/, 11];
|
|
145
|
+
case 9: return [4 /*yield*/, client.sync.services(SYNCSERVICE_SID).syncMaps(SYNCMAP_SID).syncMapItems.create({ key: key, data: data, ttl: ttl })];
|
|
146
|
+
case 10:
|
|
150
147
|
_a.sent();
|
|
151
|
-
_a.label =
|
|
152
|
-
case
|
|
148
|
+
_a.label = 11;
|
|
149
|
+
case 11: return [2 /*return*/, key];
|
|
153
150
|
}
|
|
154
151
|
});
|
|
155
152
|
}); };
|
package/dist/utils/video.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"video.js","sourceRoot":"","sources":["../../src/utils/video.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mCAAqC;AACrC,iCAAgC;
|
|
1
|
+
{"version":3,"file":"video.js","sourceRoot":"","sources":["../../src/utils/video.ts"],"names":[],"mappings":"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"}
|