@segment/action-destinations 3.491.0 → 3.492.1-async

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 (51) hide show
  1. package/dist/destinations/display-video-360/syncAudience/generated-types.d.ts +7 -0
  2. package/dist/destinations/display-video-360/syncAudience/generated-types.js +3 -0
  3. package/dist/destinations/display-video-360/syncAudience/generated-types.js.map +1 -0
  4. package/dist/destinations/display-video-360/syncAudience/index.d.ts +5 -0
  5. package/dist/destinations/display-video-360/syncAudience/index.js +30 -0
  6. package/dist/destinations/display-video-360/syncAudience/index.js.map +1 -0
  7. package/dist/destinations/google-enhanced-conversions/uploadCallConversion/index.js +1 -1
  8. package/dist/destinations/google-enhanced-conversions/uploadCallConversion/index.js.map +1 -1
  9. package/dist/destinations/google-enhanced-conversions/uploadCallConversion2/index.js +2 -2
  10. package/dist/destinations/google-enhanced-conversions/uploadCallConversion2/index.js.map +1 -1
  11. package/dist/destinations/google-enhanced-conversions/uploadClickConversion2/index.js +3 -3
  12. package/dist/destinations/google-enhanced-conversions/uploadClickConversion2/index.js.map +1 -1
  13. package/dist/destinations/google-enhanced-conversions/uploadConversionAdjustment2/index.js +1 -1
  14. package/dist/destinations/google-enhanced-conversions/uploadConversionAdjustment2/index.js.map +1 -1
  15. package/dist/destinations/memora/upsertProfile/index.js +30 -9
  16. package/dist/destinations/memora/upsertProfile/index.js.map +1 -1
  17. package/dist/destinations/salesforce-marketing-cloud/_tests_/asyncDataExtension.async.test.d.ts +1 -0
  18. package/dist/destinations/salesforce-marketing-cloud/_tests_/asyncDataExtension.async.test.js +598 -0
  19. package/dist/destinations/salesforce-marketing-cloud/_tests_/asyncDataExtension.async.test.js.map +1 -0
  20. package/dist/destinations/salesforce-marketing-cloud/asyncDataExtension/fields.d.ts +128 -0
  21. package/dist/destinations/salesforce-marketing-cloud/asyncDataExtension/fields.js +57 -0
  22. package/dist/destinations/salesforce-marketing-cloud/asyncDataExtension/fields.js.map +1 -0
  23. package/dist/destinations/salesforce-marketing-cloud/asyncDataExtension/index.async.d.ts +5 -0
  24. package/dist/destinations/salesforce-marketing-cloud/asyncDataExtension/index.async.js +145 -0
  25. package/dist/destinations/salesforce-marketing-cloud/asyncDataExtension/index.async.js.map +1 -0
  26. package/dist/destinations/salesforce-marketing-cloud/asyncDataExtension/index.js +5 -53
  27. package/dist/destinations/salesforce-marketing-cloud/asyncDataExtension/index.js.map +1 -1
  28. package/dist/destinations/salesforce-marketing-cloud/index.js +6 -2
  29. package/dist/destinations/salesforce-marketing-cloud/index.js.map +1 -1
  30. package/dist/destinations/salesforce-marketing-cloud/sfmc-operations.d.ts +11 -1
  31. package/dist/destinations/salesforce-marketing-cloud/sfmc-operations.js +3 -2
  32. package/dist/destinations/salesforce-marketing-cloud/sfmc-operations.js.map +1 -1
  33. package/dist/destinations/tiktok-audiences/syncAudience/functions.d.ts +10 -0
  34. package/dist/destinations/tiktok-audiences/syncAudience/functions.js +234 -0
  35. package/dist/destinations/tiktok-audiences/syncAudience/functions.js.map +1 -0
  36. package/dist/destinations/tiktok-audiences/syncAudience/generated-types.d.ts +12 -0
  37. package/dist/destinations/tiktok-audiences/syncAudience/generated-types.js +3 -0
  38. package/dist/destinations/tiktok-audiences/syncAudience/generated-types.js.map +1 -0
  39. package/dist/destinations/tiktok-audiences/syncAudience/index.d.ts +5 -0
  40. package/dist/destinations/tiktok-audiences/syncAudience/index.js +36 -0
  41. package/dist/destinations/tiktok-audiences/syncAudience/index.js.map +1 -0
  42. package/dist/destinations/tiktok-audiences/syncAudience/types.d.ts +1 -0
  43. package/dist/destinations/tiktok-audiences/syncAudience/types.js +3 -0
  44. package/dist/destinations/tiktok-audiences/syncAudience/types.js.map +1 -0
  45. package/dist/destinations/webhook/ssrf-utils.d.ts +1 -0
  46. package/dist/destinations/webhook/ssrf-utils.js +75 -0
  47. package/dist/destinations/webhook/ssrf-utils.js.map +1 -0
  48. package/dist/destinations/webhook-extensible/ssrf-utils.d.ts +1 -0
  49. package/dist/destinations/webhook-extensible/ssrf-utils.js +75 -0
  50. package/dist/destinations/webhook-extensible/ssrf-utils.js.map +1 -0
  51. package/package.json +6 -6
@@ -0,0 +1,234 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.send = send;
4
+ exports.sendRequest = sendRequest;
5
+ exports.sendAndCollectResponses = sendAndCollectResponses;
6
+ exports.validate = validate;
7
+ exports.extractUsers = extractUsers;
8
+ exports.normalizeEmail = normalizeEmail;
9
+ const actions_core_1 = require("@segment/actions-core");
10
+ const api_1 = require("../api");
11
+ const functions_1 = require("../functions");
12
+ const hashing_utils_1 = require("../../../lib/hashing-utils");
13
+ async function send(request, payloads, audienceSettings, audienceMembership, isBatch) {
14
+ const multiStatusResponse = new actions_core_1.MultiStatusResponse();
15
+ const { advertiserId } = audienceSettings || {};
16
+ if (!audienceSettings) {
17
+ return returnAllErrors(multiStatusResponse, payloads, 400, 'Bad Request: no audienceSettings found.', isBatch);
18
+ }
19
+ if (!advertiserId) {
20
+ return returnAllErrors(multiStatusResponse, payloads, 400, 'Bad Request: Advertiser ID is required in audienceSettings.', isBatch);
21
+ }
22
+ if (!Array.isArray(audienceMembership) ||
23
+ audienceMembership.length !== payloads.length ||
24
+ audienceMembership.some((m) => typeof m !== 'boolean')) {
25
+ return returnAllErrors(multiStatusResponse, payloads, 400, 'Audience Memberships must be an array of booleans with the same length as payloads.', isBatch);
26
+ }
27
+ const addMap = new Map();
28
+ const deleteMap = new Map();
29
+ payloads.forEach((p, i) => {
30
+ const membership = audienceMembership[i];
31
+ if (!validate(p, multiStatusResponse, i, isBatch)) {
32
+ return;
33
+ }
34
+ if (membership === true) {
35
+ addMap.set(i, p);
36
+ }
37
+ else {
38
+ deleteMap.set(i, p);
39
+ }
40
+ });
41
+ const requests = [];
42
+ if (addMap.size > 0) {
43
+ requests.push(isBatch
44
+ ? sendAndCollectResponses(request, audienceSettings, addMap, 'add', multiStatusResponse)
45
+ : sendRequest(request, audienceSettings, addMap, 'add'));
46
+ }
47
+ if (deleteMap.size > 0) {
48
+ requests.push(isBatch
49
+ ? sendAndCollectResponses(request, audienceSettings, deleteMap, 'delete', multiStatusResponse)
50
+ : sendRequest(request, audienceSettings, deleteMap, 'delete'));
51
+ }
52
+ const responses = await Promise.all(requests);
53
+ if (!isBatch) {
54
+ return responses[0];
55
+ }
56
+ return multiStatusResponse;
57
+ }
58
+ async function sendRequest(request, audienceSettings, payloadMap, action) {
59
+ const payloads = Array.from(payloadMap.values());
60
+ const { advertiserId } = audienceSettings;
61
+ const idSchema = (0, functions_1.getIDSchema)(payloads[0]);
62
+ const batchData = extractUsers(payloads);
63
+ const TikTokApiClient = new api_1.TikTokAudiences(request, advertiserId);
64
+ const response = await TikTokApiClient.batchUpdate({
65
+ advertiser_ids: [advertiserId],
66
+ action,
67
+ id_schema: idSchema,
68
+ batch_data: batchData
69
+ });
70
+ const responseData = response.data;
71
+ if (response.status < 200 || response.status >= 300 || responseData?.code !== 0) {
72
+ const message = responseData?.message ?? 'Unknown TikTok API error';
73
+ const errorStatus = response.status >= 400 ? response.status : 400;
74
+ throw new actions_core_1.IntegrationError(message, String(responseData?.code ?? response.status), errorStatus);
75
+ }
76
+ return response;
77
+ }
78
+ async function sendAndCollectResponses(request, audienceSettings, payloadMap, action, multiStatusResponse) {
79
+ const payloads = Array.from(payloadMap.values());
80
+ if (payloads.length === 0) {
81
+ return;
82
+ }
83
+ const { advertiserId } = audienceSettings;
84
+ const idSchema = (0, functions_1.getIDSchema)(payloads[0]);
85
+ const batchData = extractUsers(payloads);
86
+ try {
87
+ const TikTokApiClient = new api_1.TikTokAudiences(request, advertiserId);
88
+ const response = await TikTokApiClient.batchUpdate({
89
+ advertiser_ids: [advertiserId],
90
+ action,
91
+ id_schema: idSchema,
92
+ batch_data: batchData
93
+ });
94
+ const responseData = response.data;
95
+ const isSuccess = response.status >= 200 && response.status < 300 && responseData?.code === 0;
96
+ if (isSuccess) {
97
+ for (const [index, p] of payloadMap) {
98
+ if (!multiStatusResponse.getResponseAtIndex(index)) {
99
+ multiStatusResponse.setSuccessResponseAtIndex(index, {
100
+ status: 200,
101
+ sent: {
102
+ action,
103
+ advertiser_ids: [advertiserId],
104
+ id_schema: idSchema,
105
+ batch_data: extractUsers([p])
106
+ },
107
+ body: p
108
+ });
109
+ }
110
+ }
111
+ }
112
+ else {
113
+ const status = response.status >= 400 ? response.status : 400;
114
+ const message = responseData?.message ?? 'Unknown TikTok API error';
115
+ for (const [index, p] of payloadMap) {
116
+ if (!multiStatusResponse.getResponseAtIndex(index)) {
117
+ multiStatusResponse.setErrorResponseAtIndex(index, {
118
+ status,
119
+ errormessage: message,
120
+ sent: {
121
+ action,
122
+ advertiser_ids: [advertiserId],
123
+ id_schema: idSchema,
124
+ batch_data: extractUsers([p])
125
+ },
126
+ body: p
127
+ });
128
+ }
129
+ }
130
+ }
131
+ }
132
+ catch (err) {
133
+ const message = err instanceof actions_core_1.IntegrationError ? err.message : 'Unknown error';
134
+ const status = err instanceof actions_core_1.IntegrationError && typeof err.status === 'number' ? err.status : 500;
135
+ for (const [index, p] of payloadMap) {
136
+ if (!multiStatusResponse.getResponseAtIndex(index)) {
137
+ multiStatusResponse.setErrorResponseAtIndex(index, {
138
+ status,
139
+ errormessage: message,
140
+ sent: {
141
+ action,
142
+ advertiser_ids: [advertiserId],
143
+ id_schema: idSchema,
144
+ batch_data: extractUsers([p])
145
+ },
146
+ body: p
147
+ });
148
+ }
149
+ }
150
+ }
151
+ }
152
+ function returnAllErrors(multiStatusResponse, payloads, status, message, isBatch) {
153
+ if (!isBatch) {
154
+ throw new actions_core_1.PayloadValidationError(message);
155
+ }
156
+ payloads.forEach((p, i) => {
157
+ multiStatusResponse.setErrorResponseAtIndex(i, {
158
+ status,
159
+ errormessage: message,
160
+ body: p
161
+ });
162
+ });
163
+ return multiStatusResponse;
164
+ }
165
+ function handleValidationError(multiStatusResponse, index, payload, message, isBatch) {
166
+ if (!isBatch) {
167
+ throw new actions_core_1.PayloadValidationError(message);
168
+ }
169
+ multiStatusResponse.setErrorResponseAtIndex(index, {
170
+ status: 400,
171
+ errortype: 'PAYLOAD_VALIDATION_FAILED',
172
+ errormessage: message,
173
+ body: payload
174
+ });
175
+ return false;
176
+ }
177
+ function validate(payload, multiStatusResponse, index, isBatch) {
178
+ const { email, phone, advertising_id, send_email, send_phone, send_advertising_id, external_audience_id } = payload;
179
+ if (!external_audience_id) {
180
+ return handleValidationError(multiStatusResponse, index, payload, 'Missing required field: external_audience_id.', isBatch);
181
+ }
182
+ if (!send_email && !send_phone && !send_advertising_id) {
183
+ return handleValidationError(multiStatusResponse, index, payload, 'At least one of `Send Email`, `Send Phone` or `Send Advertising ID` must be set to `true`.', isBatch);
184
+ }
185
+ const hasEnabledIdentifier = (send_email && email) || (send_phone && phone) || (send_advertising_id && advertising_id);
186
+ if (!hasEnabledIdentifier) {
187
+ return handleValidationError(multiStatusResponse, index, payload, 'At least one enabled identifier (Email, Phone, or Advertising ID) must have a value.', isBatch);
188
+ }
189
+ return true;
190
+ }
191
+ function extractUsers(payloads) {
192
+ const batchData = [];
193
+ for (const payload of payloads) {
194
+ const userIds = [];
195
+ const audienceIds = [payload.external_audience_id];
196
+ if (payload.send_email) {
197
+ if (payload.email) {
198
+ const normalized = normalizeEmail(payload.email);
199
+ userIds.push({ id: (0, hashing_utils_1.processHashing)(normalized, 'sha256', 'hex'), audience_ids: audienceIds });
200
+ }
201
+ else {
202
+ userIds.push({});
203
+ }
204
+ }
205
+ if (payload.send_phone) {
206
+ if (payload.phone) {
207
+ userIds.push({
208
+ id: (0, hashing_utils_1.processHashing)(payload.phone, 'sha256', 'hex'),
209
+ audience_ids: audienceIds
210
+ });
211
+ }
212
+ else {
213
+ userIds.push({});
214
+ }
215
+ }
216
+ if (payload.send_advertising_id) {
217
+ if (payload.advertising_id) {
218
+ userIds.push({ id: (0, hashing_utils_1.processHashing)(payload.advertising_id, 'sha256', 'hex'), audience_ids: audienceIds });
219
+ }
220
+ else {
221
+ userIds.push({});
222
+ }
223
+ }
224
+ batchData.push(userIds);
225
+ }
226
+ return batchData;
227
+ }
228
+ function normalizeEmail(email) {
229
+ return email
230
+ .replace(/\+.*@/, '@')
231
+ .replace(/\.(?=.*@)/g, '')
232
+ .toLowerCase();
233
+ }
234
+ //# sourceMappingURL=functions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"functions.js","sourceRoot":"","sources":["../../../../src/destinations/tiktok-audiences/syncAudience/functions.ts"],"names":[],"mappings":";;AAiBA,oBAgFC;AAED,kCA2BC;AAED,0DAsFC;AAyCD,4BA0CC;AAED,oCAuCC;AAED,wCAKC;AAzVD,wDAQ8B;AAC9B,gCAAwC;AAGxC,4CAA0C;AAG1C,8DAA2D;AAEpD,KAAK,UAAU,IAAI,CACxB,OAAsB,EACtB,QAAmB,EACnB,gBAAmC,EACnC,kBAAyC,EACzC,OAAiB;IAEjB,MAAM,mBAAmB,GAAG,IAAI,kCAAmB,EAAE,CAAA;IAErD,MAAM,EAAE,YAAY,EAAE,GAAG,gBAAgB,IAAI,EAAE,CAAA;IAE/C,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtB,OAAO,eAAe,CAAC,mBAAmB,EAAE,QAAQ,EAAE,GAAG,EAAE,yCAAyC,EAAE,OAAO,CAAC,CAAA;IAChH,CAAC;IAED,IAAG,CAAC,YAAY,EAAE,CAAC;QACjB,OAAO,eAAe,CACpB,mBAAmB,EACnB,QAAQ,EACR,GAAG,EACH,6DAA6D,EAC7D,OAAO,CACR,CAAA;IACH,CAAC;IAED,IACE,CAAC,KAAK,CAAC,OAAO,CAAC,kBAAkB,CAAC;QAClC,kBAAkB,CAAC,MAAM,KAAK,QAAQ,CAAC,MAAM;QAC7C,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,SAAS,CAAC,EACtD,CAAC;QACD,OAAO,eAAe,CACpB,mBAAmB,EACnB,QAAQ,EACR,GAAG,EACH,qFAAqF,EACrF,OAAO,CACR,CAAA;IACH,CAAC;IAED,MAAM,MAAM,GAAG,IAAI,GAAG,EAAmB,CAAA;IACzC,MAAM,SAAS,GAAG,IAAI,GAAG,EAAmB,CAAA;IAE5C,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACxB,MAAM,UAAU,GAAG,kBAAkB,CAAC,CAAC,CAAC,CAAA;QACxC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,mBAAmB,EAAE,CAAC,EAAE,OAAO,CAAC,EAAE,CAAC;YAClD,OAAM;QACR,CAAC;QAED,IAAI,UAAU,KAAK,IAAI,EAAE,CAAC;YACxB,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QAClB,CAAC;aAAM,CAAC;YACN,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QACrB,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,QAAQ,GAAuC,EAAE,CAAA;IAEvD,IAAI,MAAM,CAAC,IAAI,GAAG,CAAC,EAAE,CAAC;QACpB,QAAQ,CAAC,IAAI,CACX,OAAO;YACL,CAAC,CAAC,uBAAuB,CAAC,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,KAAK,EAAE,mBAAmB,CAAC;YACxF,CAAC,CAAC,WAAW,CAAC,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,KAAK,CAAC,CAC1D,CAAA;IACH,CAAC;IAED,IAAI,SAAS,CAAC,IAAI,GAAG,CAAC,EAAE,CAAC;QACvB,QAAQ,CAAC,IAAI,CACX,OAAO;YACL,CAAC,CAAC,uBAAuB,CAAC,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,QAAQ,EAAE,mBAAmB,CAAC;YAC9F,CAAC,CAAC,WAAW,CAAC,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,QAAQ,CAAC,CAChE,CAAA;IACH,CAAC;IAED,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;IAE7C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,SAAS,CAAC,CAAC,CAAC,CAAA;IACrB,CAAC;IAED,OAAO,mBAAmB,CAAA;AAC5B,CAAC;AAEM,KAAK,UAAU,WAAW,CAC/B,OAAsB,EACtB,gBAAkC,EAClC,UAAgC,EAChC,MAA4B;IAE5B,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAA;IAChD,MAAM,EAAE,YAAY,EAAE,GAAG,gBAAgB,CAAA;IACzC,MAAM,QAAQ,GAAG,IAAA,uBAAW,EAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;IACzC,MAAM,SAAS,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAA;IACxC,MAAM,eAAe,GAAG,IAAI,qBAAe,CAAC,OAAO,EAAE,YAAY,CAAC,CAAA;IAElE,MAAM,QAAQ,GAAG,MAAM,eAAe,CAAC,WAAW,CAAC;QACjD,cAAc,EAAE,CAAC,YAAY,CAAC;QAC9B,MAAM;QACN,SAAS,EAAE,QAAQ;QACnB,UAAU,EAAE,SAAS;KACtB,CAAC,CAAA;IAEF,MAAM,YAAY,GAAG,QAAQ,CAAC,IAA+B,CAAA;IAC7D,IAAI,QAAQ,CAAC,MAAM,GAAG,GAAG,IAAI,QAAQ,CAAC,MAAM,IAAI,GAAG,IAAI,YAAY,EAAE,IAAI,KAAK,CAAC,EAAE,CAAC;QAChF,MAAM,OAAO,GAAG,YAAY,EAAE,OAAO,IAAI,0BAA0B,CAAA;QACnE,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAA;QAClE,MAAM,IAAI,+BAAgB,CAAC,OAAO,EAAE,MAAM,CAAC,YAAY,EAAE,IAAI,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE,WAAW,CAAC,CAAA;IACjG,CAAC;IAED,OAAO,QAAQ,CAAA;AACjB,CAAC;AAEM,KAAK,UAAU,uBAAuB,CAC3C,OAAsB,EACtB,gBAAkC,EAClC,UAAgC,EAChC,MAA4B,EAC5B,mBAAwC;IAExC,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAA;IAEhD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAM;IACR,CAAC;IAED,MAAM,EAAE,YAAY,EAAE,GAAG,gBAAgB,CAAA;IACzC,MAAM,QAAQ,GAAG,IAAA,uBAAW,EAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;IACzC,MAAM,SAAS,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAA;IAExC,IAAI,CAAC;QACH,MAAM,eAAe,GAAG,IAAI,qBAAe,CAAC,OAAO,EAAE,YAAY,CAAC,CAAA;QAElE,MAAM,QAAQ,GAAG,MAAM,eAAe,CAAC,WAAW,CAAC;YACjD,cAAc,EAAE,CAAC,YAAY,CAAC;YAC9B,MAAM;YACN,SAAS,EAAE,QAAQ;YACnB,UAAU,EAAE,SAAS;SACtB,CAAC,CAAA;QAEF,MAAM,YAAY,GAAG,QAAQ,CAAC,IAA+B,CAAA;QAC7D,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,IAAI,GAAG,IAAI,QAAQ,CAAC,MAAM,GAAG,GAAG,IAAI,YAAY,EAAE,IAAI,KAAK,CAAC,CAAA;QAE7F,IAAI,SAAS,EAAE,CAAC;YACd,KAAK,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,UAAU,EAAE,CAAC;gBACpC,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;oBACnD,mBAAmB,CAAC,yBAAyB,CAAC,KAAK,EAAE;wBACnD,MAAM,EAAE,GAAG;wBACX,IAAI,EAAE;4BACJ,MAAM;4BACN,cAAc,EAAE,CAAC,YAAY,CAAC;4BAC9B,SAAS,EAAE,QAAQ;4BACnB,UAAU,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;yBACD;wBAC9B,IAAI,EAAE,CAA8B;qBACrC,CAAC,CAAA;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAA;YAC7D,MAAM,OAAO,GAAG,YAAY,EAAE,OAAO,IAAI,0BAA0B,CAAA;YAEnE,KAAK,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,UAAU,EAAE,CAAC;gBACpC,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;oBACnD,mBAAmB,CAAC,uBAAuB,CAAC,KAAK,EAAE;wBACjD,MAAM;wBACN,YAAY,EAAE,OAAO;wBACrB,IAAI,EAAE;4BACJ,MAAM;4BACN,cAAc,EAAE,CAAC,YAAY,CAAC;4BAC9B,SAAS,EAAE,QAAQ;4BACnB,UAAU,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;yBACD;wBAC9B,IAAI,EAAE,CAA8B;qBACrC,CAAC,CAAA;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,GAAG,YAAY,+BAAgB,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAA;QAC/E,MAAM,MAAM,GAAG,GAAG,YAAY,+BAAgB,IAAI,OAAO,GAAG,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAA;QAEnG,KAAK,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,UAAU,EAAE,CAAC;YACpC,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;gBAEnD,mBAAmB,CAAC,uBAAuB,CAAC,KAAK,EAAE;oBACjD,MAAM;oBACN,YAAY,EAAE,OAAO;oBACrB,IAAI,EAAE;wBACJ,MAAM;wBACN,cAAc,EAAE,CAAC,YAAY,CAAC;wBAC9B,SAAS,EAAE,QAAQ;wBACnB,UAAU,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;qBACD;oBAC9B,IAAI,EAAE,CAA8B;iBACrC,CAAC,CAAA;YACJ,CAAC;QACH,CAAC;IACH,CAAC;AACH,CAAC;AAED,SAAS,eAAe,CACtB,mBAAwC,EACxC,QAAmB,EACnB,MAAc,EACd,OAAe,EACf,OAAiB;IAEjB,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,qCAAsB,CAAC,OAAO,CAAC,CAAA;IAC3C,CAAC;IACD,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACxB,mBAAmB,CAAC,uBAAuB,CAAC,CAAC,EAAE;YAC7C,MAAM;YACN,YAAY,EAAE,OAAO;YACrB,IAAI,EAAE,CAA8B;SACrC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IACF,OAAO,mBAAmB,CAAA;AAC5B,CAAC;AAED,SAAS,qBAAqB,CAC5B,mBAAwC,EACxC,KAAa,EACb,OAAgB,EAChB,OAAe,EACf,OAAiB;IAEjB,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,qCAAsB,CAAC,OAAO,CAAC,CAAA;IAC3C,CAAC;IACD,mBAAmB,CAAC,uBAAuB,CAAC,KAAK,EAAE;QACjD,MAAM,EAAE,GAAG;QACX,SAAS,EAAE,2BAA2B;QACtC,YAAY,EAAE,OAAO;QACrB,IAAI,EAAE,OAAoC;KAC3C,CAAC,CAAA;IACF,OAAO,KAAK,CAAA;AACd,CAAC;AAED,SAAgB,QAAQ,CACtB,OAAgB,EAChB,mBAAwC,EACxC,KAAa,EACb,OAAiB;IAGjB,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,cAAc,EAAE,UAAU,EAAE,UAAU,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,GAAG,OAAO,CAAA;IAEnH,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC1B,OAAO,qBAAqB,CAC1B,mBAAmB,EACnB,KAAK,EACL,OAAO,EACP,+CAA+C,EAC/C,OAAO,CACR,CAAA;IACH,CAAC;IAED,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACvD,OAAO,qBAAqB,CAC1B,mBAAmB,EACnB,KAAK,EACL,OAAO,EACP,4FAA4F,EAC5F,OAAO,CACR,CAAA;IACH,CAAC;IAED,MAAM,oBAAoB,GAAG,CAAC,UAAU,IAAI,KAAK,CAAC,IAAI,CAAC,UAAU,IAAI,KAAK,CAAC,IAAI,CAAC,mBAAmB,IAAI,cAAc,CAAC,CAAA;IAEtH,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC1B,OAAO,qBAAqB,CAC1B,mBAAmB,EACnB,KAAK,EACL,OAAO,EACP,sFAAsF,EACtF,OAAO,CACR,CAAA;IACH,CAAC;IAED,OAAO,IAAI,CAAA;AACb,CAAC;AAED,SAAgB,YAAY,CAAC,QAAmB;IAC9C,MAAM,SAAS,GAAgC,EAAE,CAAA;IAEjD,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,MAAM,OAAO,GAA8B,EAAE,CAAA;QAC7C,MAAM,WAAW,GAAG,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAA;QAElD,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;YACvB,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;gBAClB,MAAM,UAAU,GAAG,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;gBAChD,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAA,8BAAc,EAAC,UAAU,EAAE,QAAQ,EAAE,KAAK,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC,CAAA;YAC9F,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAClB,CAAC;QACH,CAAC;QAED,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;YACvB,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;gBAClB,OAAO,CAAC,IAAI,CAAC;oBACX,EAAE,EAAE,IAAA,8BAAc,EAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,KAAK,CAAC;oBAClD,YAAY,EAAE,WAAW;iBAC1B,CAAC,CAAA;YACJ,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAClB,CAAC;QACH,CAAC;QAED,IAAI,OAAO,CAAC,mBAAmB,EAAE,CAAC;YAChC,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;gBAC3B,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAA,8BAAc,EAAC,OAAO,CAAC,cAAc,EAAE,QAAQ,EAAE,KAAK,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC,CAAA;YAC1G,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAClB,CAAC;QACH,CAAC;QAED,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IACzB,CAAC;IAED,OAAO,SAAS,CAAA;AAClB,CAAC;AAED,SAAgB,cAAc,CAAC,KAAa;IAC1C,OAAO,KAAK;SACT,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC;SACrB,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC;SACzB,WAAW,EAAE,CAAA;AAClB,CAAC"}
@@ -0,0 +1,12 @@
1
+ export interface Payload {
2
+ email?: string;
3
+ phone?: string;
4
+ advertising_id?: string;
5
+ send_email?: boolean;
6
+ send_phone?: boolean;
7
+ send_advertising_id?: boolean;
8
+ event_name?: string;
9
+ enable_batching?: boolean;
10
+ batch_keys?: string[];
11
+ external_audience_id?: string;
12
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=generated-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generated-types.js","sourceRoot":"","sources":["../../../../src/destinations/tiktok-audiences/syncAudience/generated-types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ import { ActionDefinition } from '@segment/actions-core';
2
+ import type { Settings, AudienceSettings } from '../generated-types';
3
+ import type { Payload } from './generated-types';
4
+ declare const action: ActionDefinition<Settings, Payload, AudienceSettings>;
5
+ export default action;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const functions_1 = require("./functions");
4
+ const properties_1 = require("../properties");
5
+ const action = {
6
+ title: 'Sync Audience',
7
+ description: 'Sync an Engage Audience to a TikTok Audience Segment.',
8
+ defaultSubscription: 'type = "track"',
9
+ fields: {
10
+ event_name: { ...properties_1.event_name },
11
+ send_email: { ...properties_1.send_email },
12
+ send_phone: { ...properties_1.send_phone },
13
+ send_advertising_id: { ...properties_1.send_advertising_id },
14
+ email: { ...properties_1.email },
15
+ phone: { ...properties_1.phone },
16
+ advertising_id: { ...properties_1.advertising_id },
17
+ enable_batching: { ...properties_1.enable_batching },
18
+ external_audience_id: { ...properties_1.external_audience_id },
19
+ batch_keys: {
20
+ label: 'Batch Keys',
21
+ description: 'The keys to use for batching the events.',
22
+ type: 'string',
23
+ multiple: true,
24
+ default: ['send_email', 'send_phone', 'send_advertising_id'],
25
+ unsafe_hidden: true
26
+ }
27
+ },
28
+ perform: async (request, { audienceSettings, payload, audienceMembership }) => {
29
+ return (0, functions_1.send)(request, [payload], audienceSettings, [audienceMembership]);
30
+ },
31
+ performBatch: async (request, { payload: payloads, audienceSettings, audienceMembership: audienceMemberships }) => {
32
+ return (0, functions_1.send)(request, payloads, audienceSettings, audienceMemberships, true);
33
+ }
34
+ };
35
+ exports.default = action;
36
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/destinations/tiktok-audiences/syncAudience/index.ts"],"names":[],"mappings":";;AAGA,2CAAkC;AAClC,8CAUsB;AAEtB,MAAM,MAAM,GAA0D;IACpE,KAAK,EAAE,eAAe;IACtB,WAAW,EAAE,uDAAuD;IACpE,mBAAmB,EAAE,gBAAgB;IACrC,MAAM,EAAE;QACN,UAAU,EAAG,EAAE,GAAG,uBAAU,EAAC;QAC7B,UAAU,EAAG,EAAE,GAAG,uBAAU,EAAC;QAC7B,UAAU,EAAG,EAAE,GAAG,uBAAU,EAAC;QAC7B,mBAAmB,EAAG,EAAE,GAAG,gCAAmB,EAAC;QAC/C,KAAK,EAAG,EAAE,GAAG,kBAAK,EAAC;QACnB,KAAK,EAAG,EAAE,GAAG,kBAAK,EAAC;QACnB,cAAc,EAAG,EAAE,GAAG,2BAAc,EAAC;QACrC,eAAe,EAAE,EAAE,GAAG,4BAAe,EAAE;QACvC,oBAAoB,EAAE,EAAE,GAAG,iCAAoB,EAAE;QACjD,UAAU,EAAE;YACV,KAAK,EAAE,YAAY;YACnB,WAAW,EAAE,0CAA0C;YACvD,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,IAAI;YACd,OAAO,EAAE,CAAC,YAAY,EAAE,YAAY,EAAE,qBAAqB,CAAC;YAC5D,aAAa,EAAE,IAAI;SACpB;KACF;IACD,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,gBAAgB,EAAE,OAAO,EAAE,kBAAkB,EAAE,EAAE,EAAE;QAC5E,OAAO,IAAA,gBAAI,EAAC,OAAO,EAAE,CAAC,OAAO,CAAC,EAAE,gBAAgB,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAA;IACzE,CAAC;IACD,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,EAAE,EAAE;QAChH,OAAO,IAAA,gBAAI,EAAC,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,IAAI,CAAC,CAAA;IAC7E,CAAC;CACF,CAAA;AAED,kBAAe,MAAM,CAAA"}
@@ -0,0 +1 @@
1
+ export type TikTokAudienceAction = 'add' | 'delete';
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/destinations/tiktok-audiences/syncAudience/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1 @@
1
+ export declare function isRestrictedUrl(rawUrl: string): boolean;
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isRestrictedUrl = isRestrictedUrl;
4
+ const net_1 = require("net");
5
+ const url_1 = require("url");
6
+ const RESTRICTED_CIDRS_V4 = [
7
+ [0x00000000, 0xff000000, '0.0.0.0/8'],
8
+ [0x0a000000, 0xff000000, '10.0.0.0/8'],
9
+ [0x64400000, 0xffc00000, '100.64.0.0/10'],
10
+ [0x7f000000, 0xff000000, '127.0.0.0/8'],
11
+ [0xa9fe0000, 0xffff0000, '169.254.0.0/16'],
12
+ [0xac100000, 0xfff00000, '172.16.0.0/12'],
13
+ [0xc0000000, 0xffffff00, '192.0.0.0/24'],
14
+ [0xc0000200, 0xffffff00, '192.0.2.0/24'],
15
+ [0xc0a80000, 0xffff0000, '192.168.0.0/16'],
16
+ [0xc6336400, 0xffffff00, '198.51.100.0/24'],
17
+ [0xcb007100, 0xffffff00, '203.0.113.0/24'],
18
+ [0xe0000000, 0xf0000000, '224.0.0.0/4'],
19
+ [0xf0000000, 0xf0000000, '240.0.0.0/4']
20
+ ];
21
+ function ipv4ToInt(ip) {
22
+ return ip.split('.').reduce((acc, octet) => (acc << 8) | parseInt(octet, 10), 0) >>> 0;
23
+ }
24
+ function intToIpv4(n) {
25
+ return [(n >>> 24) & 0xff, (n >>> 16) & 0xff, (n >>> 8) & 0xff, n & 0xff].join('.');
26
+ }
27
+ function isRestrictedIPv4(ip) {
28
+ const int = ipv4ToInt(ip);
29
+ return RESTRICTED_CIDRS_V4.some(([network, mask]) => (int & mask) === network);
30
+ }
31
+ function isRestrictedIPv6(ip) {
32
+ const lower = ip.toLowerCase();
33
+ if (lower === '::1' || lower === '::')
34
+ return true;
35
+ if (lower.startsWith('fe8') || lower.startsWith('fe9') || lower.startsWith('fea') || lower.startsWith('feb')) {
36
+ return true;
37
+ }
38
+ if (lower.startsWith('fc') || lower.startsWith('fd'))
39
+ return true;
40
+ return false;
41
+ }
42
+ function normalizeHostname(hostname) {
43
+ const asInt = parseInt(hostname, 10);
44
+ if (asInt.toString() === hostname) {
45
+ const ip = intToIpv4(asInt);
46
+ return { ip, blocked: false };
47
+ }
48
+ if (/^[\d.x]+$/i.test(hostname) && !(0, net_1.isIPv4)(hostname)) {
49
+ return { ip: null, blocked: true };
50
+ }
51
+ return { ip: hostname, blocked: false };
52
+ }
53
+ function isRestrictedUrl(rawUrl) {
54
+ let parsed;
55
+ try {
56
+ parsed = new url_1.URL(rawUrl);
57
+ }
58
+ catch {
59
+ return true;
60
+ }
61
+ if (parsed.protocol !== 'http:' && parsed.protocol !== 'https:')
62
+ return true;
63
+ const hostname = parsed.hostname.replace(/^\[/, '').replace(/\]$/, '');
64
+ const { ip, blocked } = normalizeHostname(hostname);
65
+ if (blocked)
66
+ return true;
67
+ if (ip === null)
68
+ return true;
69
+ if ((0, net_1.isIPv4)(ip))
70
+ return isRestrictedIPv4(ip);
71
+ if ((0, net_1.isIPv6)(ip))
72
+ return isRestrictedIPv6(ip);
73
+ return false;
74
+ }
75
+ //# sourceMappingURL=ssrf-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ssrf-utils.js","sourceRoot":"","sources":["../../../src/destinations/webhook/ssrf-utils.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare function isRestrictedUrl(rawUrl: string): boolean;
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isRestrictedUrl = isRestrictedUrl;
4
+ const net_1 = require("net");
5
+ const url_1 = require("url");
6
+ const RESTRICTED_CIDRS_V4 = [
7
+ [0x00000000, 0xff000000, '0.0.0.0/8'],
8
+ [0x0a000000, 0xff000000, '10.0.0.0/8'],
9
+ [0x64400000, 0xffc00000, '100.64.0.0/10'],
10
+ [0x7f000000, 0xff000000, '127.0.0.0/8'],
11
+ [0xa9fe0000, 0xffff0000, '169.254.0.0/16'],
12
+ [0xac100000, 0xfff00000, '172.16.0.0/12'],
13
+ [0xc0000000, 0xffffff00, '192.0.0.0/24'],
14
+ [0xc0000200, 0xffffff00, '192.0.2.0/24'],
15
+ [0xc0a80000, 0xffff0000, '192.168.0.0/16'],
16
+ [0xc6336400, 0xffffff00, '198.51.100.0/24'],
17
+ [0xcb007100, 0xffffff00, '203.0.113.0/24'],
18
+ [0xe0000000, 0xf0000000, '224.0.0.0/4'],
19
+ [0xf0000000, 0xf0000000, '240.0.0.0/4']
20
+ ];
21
+ function ipv4ToInt(ip) {
22
+ return ip.split('.').reduce((acc, octet) => (acc << 8) | parseInt(octet, 10), 0) >>> 0;
23
+ }
24
+ function intToIpv4(n) {
25
+ return [(n >>> 24) & 0xff, (n >>> 16) & 0xff, (n >>> 8) & 0xff, n & 0xff].join('.');
26
+ }
27
+ function isRestrictedIPv4(ip) {
28
+ const int = ipv4ToInt(ip);
29
+ return RESTRICTED_CIDRS_V4.some(([network, mask]) => (int & mask) === network);
30
+ }
31
+ function isRestrictedIPv6(ip) {
32
+ const lower = ip.toLowerCase();
33
+ if (lower === '::1' || lower === '::')
34
+ return true;
35
+ if (lower.startsWith('fe8') || lower.startsWith('fe9') || lower.startsWith('fea') || lower.startsWith('feb')) {
36
+ return true;
37
+ }
38
+ if (lower.startsWith('fc') || lower.startsWith('fd'))
39
+ return true;
40
+ return false;
41
+ }
42
+ function normalizeHostname(hostname) {
43
+ const asInt = parseInt(hostname, 10);
44
+ if (asInt.toString() === hostname) {
45
+ const ip = intToIpv4(asInt);
46
+ return { ip, blocked: false };
47
+ }
48
+ if (/^[\d.x]+$/i.test(hostname) && !(0, net_1.isIPv4)(hostname)) {
49
+ return { ip: null, blocked: true };
50
+ }
51
+ return { ip: hostname, blocked: false };
52
+ }
53
+ function isRestrictedUrl(rawUrl) {
54
+ let parsed;
55
+ try {
56
+ parsed = new url_1.URL(rawUrl);
57
+ }
58
+ catch {
59
+ return true;
60
+ }
61
+ if (parsed.protocol !== 'http:' && parsed.protocol !== 'https:')
62
+ return true;
63
+ const hostname = parsed.hostname.replace(/^\[/, '').replace(/\]$/, '');
64
+ const { ip, blocked } = normalizeHostname(hostname);
65
+ if (blocked)
66
+ return true;
67
+ if (ip === null)
68
+ return true;
69
+ if ((0, net_1.isIPv4)(ip))
70
+ return isRestrictedIPv4(ip);
71
+ if ((0, net_1.isIPv6)(ip))
72
+ return isRestrictedIPv6(ip);
73
+ return false;
74
+ }
75
+ //# sourceMappingURL=ssrf-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ssrf-utils.js","sourceRoot":"","sources":["../../../src/destinations/webhook-extensible/ssrf-utils.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@segment/action-destinations",
3
3
  "description": "Destination Actions engine and definitions.",
4
- "version": "3.491.0",
4
+ "version": "3.492.1-async",
5
5
  "repository": {
6
6
  "type": "git",
7
7
  "url": "https://github.com/segmentio/action-destinations",
@@ -47,8 +47,8 @@
47
47
  "@aws-sdk/client-sts": "^3.894.0",
48
48
  "@bufbuild/protobuf": "^2.2.3",
49
49
  "@segment/a1-notation": "^2.1.4",
50
- "@segment/actions-core": "^3.168.0",
51
- "@segment/actions-shared": "^1.153.0",
50
+ "@segment/actions-core": "^3.168.1-async",
51
+ "@segment/actions-shared": "^1.153.1-async",
52
52
  "@types/node": "^22.13.1",
53
53
  "ajv-formats": "^2.1.1",
54
54
  "aws4": "^1.12.0",
@@ -57,8 +57,8 @@
57
57
  "escape-goat": "^3",
58
58
  "google-libphonenumber": "^3.2.31",
59
59
  "kafkajs": "^2.2.4",
60
- "liquidjs": "^10.8.4",
61
- "lodash": "^4.17.21",
60
+ "liquidjs": "^10.25.7",
61
+ "lodash": "^4.18.1",
62
62
  "lru-cache": "10.4.3",
63
63
  "ssh2-sftp-client": "^12.0.1"
64
64
  },
@@ -92,5 +92,5 @@
92
92
  "__tests__/__helpers__/"
93
93
  ]
94
94
  },
95
- "gitHead": "209d253acd73d01875a3bcbe7b6a06af34bf7716"
95
+ "gitHead": "9c04e12c4a0e81f6b68dca0a297fb2c0209d2431"
96
96
  }