@webhook-platform/node 1.0.0

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.
@@ -0,0 +1,138 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.verifySignature = verifySignature;
37
+ exports.constructEvent = constructEvent;
38
+ exports.generateSignature = generateSignature;
39
+ const crypto = __importStar(require("crypto"));
40
+ const errors_1 = require("./errors");
41
+ const SIGNATURE_HEADER = 'x-signature';
42
+ const TIMESTAMP_HEADER = 'x-timestamp';
43
+ const EVENT_ID_HEADER = 'x-event-id';
44
+ const DELIVERY_ID_HEADER = 'x-delivery-id';
45
+ const DEFAULT_TOLERANCE = 300000; // 5 minutes in milliseconds
46
+ /**
47
+ * Verifies the webhook signature using HMAC-SHA256
48
+ * @param payload - Raw request body as string
49
+ * @param signature - X-Signature header value (format: t=timestamp,v1=signature)
50
+ * @param secret - Endpoint webhook secret
51
+ * @param options - Verification options
52
+ * @returns true if signature is valid
53
+ * @throws WebhookPlatformError if signature is invalid
54
+ */
55
+ function verifySignature(payload, signature, secret, options = {}) {
56
+ const tolerance = options.tolerance ?? DEFAULT_TOLERANCE;
57
+ if (!signature) {
58
+ throw new errors_1.WebhookPlatformError('Missing signature header', 400, 'invalid_signature');
59
+ }
60
+ const parts = signature.split(',');
61
+ let timestamp;
62
+ let sig;
63
+ for (const part of parts) {
64
+ const [key, value] = part.split('=');
65
+ if (key === 't')
66
+ timestamp = value;
67
+ if (key === 'v1')
68
+ sig = value;
69
+ }
70
+ if (!timestamp || !sig) {
71
+ throw new errors_1.WebhookPlatformError('Invalid signature format. Expected: t=timestamp,v1=signature', 400, 'invalid_signature');
72
+ }
73
+ const timestampMs = parseInt(timestamp, 10);
74
+ const now = Date.now();
75
+ if (Math.abs(now - timestampMs) > tolerance) {
76
+ throw new errors_1.WebhookPlatformError('Webhook timestamp is outside tolerance window', 400, 'timestamp_expired');
77
+ }
78
+ const signedPayload = `${timestamp}.${payload}`;
79
+ const expectedSignature = crypto
80
+ .createHmac('sha256', secret)
81
+ .update(signedPayload)
82
+ .digest('hex');
83
+ const sigBuffer = Buffer.from(sig);
84
+ const expectedBuffer = Buffer.from(expectedSignature);
85
+ if (sigBuffer.length !== expectedBuffer.length || !crypto.timingSafeEqual(sigBuffer, expectedBuffer)) {
86
+ throw new errors_1.WebhookPlatformError('Invalid signature', 400, 'invalid_signature');
87
+ }
88
+ return true;
89
+ }
90
+ /**
91
+ * Constructs a webhook event from the request
92
+ * @param payload - Raw request body as string
93
+ * @param headers - Request headers
94
+ * @param secret - Endpoint webhook secret
95
+ * @param options - Verification options
96
+ * @returns Parsed and verified webhook event
97
+ */
98
+ function constructEvent(payload, headers, secret, options = {}) {
99
+ const signature = headers[SIGNATURE_HEADER] || headers['X-Signature'];
100
+ const timestamp = headers[TIMESTAMP_HEADER] || headers['X-Timestamp'];
101
+ const eventId = headers[EVENT_ID_HEADER] || headers['X-Event-Id'];
102
+ const deliveryId = headers[DELIVERY_ID_HEADER] || headers['X-Delivery-Id'];
103
+ if (!signature) {
104
+ throw new errors_1.WebhookPlatformError('Missing X-Signature header', 400, 'missing_header');
105
+ }
106
+ verifySignature(payload, signature, secret, options);
107
+ let data;
108
+ try {
109
+ data = JSON.parse(payload);
110
+ }
111
+ catch {
112
+ throw new errors_1.WebhookPlatformError('Invalid JSON payload', 400, 'invalid_payload');
113
+ }
114
+ return {
115
+ eventId: eventId || '',
116
+ deliveryId: deliveryId || '',
117
+ timestamp: timestamp ? parseInt(timestamp, 10) : Date.now(),
118
+ type: data.type || '',
119
+ data: data.data || data,
120
+ };
121
+ }
122
+ /**
123
+ * Generates a signature for testing purposes
124
+ * @param payload - Request body as string
125
+ * @param secret - Webhook secret
126
+ * @param timestamp - Optional timestamp (defaults to now)
127
+ * @returns Signature string in format t=timestamp,v1=signature
128
+ */
129
+ function generateSignature(payload, secret, timestamp) {
130
+ const ts = timestamp ?? Date.now();
131
+ const signedPayload = `${ts}.${payload}`;
132
+ const signature = crypto
133
+ .createHmac('sha256', secret)
134
+ .update(signedPayload)
135
+ .digest('hex');
136
+ return `t=${ts},v1=${signature}`;
137
+ }
138
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViaG9va3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvd2ViaG9va3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFnQ0EsMENBdURDO0FBVUQsd0NBK0JDO0FBU0QsOENBYUM7QUF0SkQsK0NBQWlDO0FBRWpDLHFDQUFnRDtBQUVoRCxNQUFNLGdCQUFnQixHQUFHLGFBQWEsQ0FBQztBQUN2QyxNQUFNLGdCQUFnQixHQUFHLGFBQWEsQ0FBQztBQUN2QyxNQUFNLGVBQWUsR0FBRyxZQUFZLENBQUM7QUFDckMsTUFBTSxrQkFBa0IsR0FBRyxlQUFlLENBQUM7QUFFM0MsTUFBTSxpQkFBaUIsR0FBRyxNQUFNLENBQUMsQ0FBQyw0QkFBNEI7QUFjOUQ7Ozs7Ozs7O0dBUUc7QUFDSCxTQUFnQixlQUFlLENBQzdCLE9BQWUsRUFDZixTQUFpQixFQUNqQixNQUFjLEVBQ2QsVUFBeUIsRUFBRTtJQUUzQixNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUMsU0FBUyxJQUFJLGlCQUFpQixDQUFDO0lBRXpELElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNmLE1BQU0sSUFBSSw2QkFBb0IsQ0FBQywwQkFBMEIsRUFBRSxHQUFHLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBRUQsTUFBTSxLQUFLLEdBQUcsU0FBUyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNuQyxJQUFJLFNBQTZCLENBQUM7SUFDbEMsSUFBSSxHQUF1QixDQUFDO0lBRTVCLEtBQUssTUFBTSxJQUFJLElBQUksS0FBSyxFQUFFLENBQUM7UUFDekIsTUFBTSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3JDLElBQUksR0FBRyxLQUFLLEdBQUc7WUFBRSxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ25DLElBQUks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QUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRTtRQUMzRCxJQUFJLEVBQUcsSUFBSSxDQUFDLElBQWUsSUFBSSxFQUFFO1FBQ2pDLElBQUksRUFBRyxJQUFJLENBQUMsSUFBZ0MsSUFBSSxJQUFJO0tBQ3JELENBQUM7QUFDSixDQUFDO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsU0FBZ0IsaUJBQWlCLENBQy9CLE9BQWUsRUFDZixNQUFjLEVBQ2QsU0FBa0I7SUFFbEIsTUFBTSxFQUFFLEdBQUcsU0FBUyxJQUFJLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNuQyxNQUFNLGFBQWEsR0FBRyxHQUFHLEVBQUUsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUN6QyxNQUFNLFNBQVMsR0FBRyxNQUFNO1NBQ3JCLFVBQVUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFDO1NBQzVCLE1BQU0sQ0FBQyxhQUFhLENBQUM7U0FDckIsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRWpCLE9BQU8sS0FBSyxFQUFFLE9BQU8sU0FBUyxFQUFFLENBQUM7QUFDbkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNyeXB0byBmcm9tICdjcnlwdG8nO1xuaW1wb3J0IHsgV2ViaG9va0V2ZW50IH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBXZWJob29rUGxhdGZvcm1FcnJvciB9IGZyb20gJy4vZXJyb3JzJztcblxuY29uc3QgU0lHTkFUVVJFX0hFQURFUiA9ICd4LXNpZ25hdHVyZSc7XG5jb25zdCBUSU1FU1RBTVBfSEVBREVSID0gJ3gtdGltZXN0YW1wJztcbmNvbnN0IEVWRU5UX0lEX0hFQURFUiA9ICd4LWV2ZW50LWlkJztcbmNvbnN0IERFTElWRVJZX0lEX0hFQURFUiA9ICd4LWRlbGl2ZXJ5LWlkJztcblxuY29uc3QgREVGQVVMVF9UT0xFUkFOQ0UgPSAzMDAwMDA7IC8vIDUgbWludXRlcyBpbiBtaWxsaXNlY29uZHNcblxuZXhwb3J0IGludGVyZmFjZSBXZWJob29rSGVhZGVycyB7XG4gICd4LXNpZ25hdHVyZSc/OiBzdHJpbmc7XG4gICd4LXRpbWVzdGFtcCc/OiBzdHJpbmc7XG4gICd4LWV2ZW50LWlkJz86IHN0cmluZztcbiAgJ3gtZGVsaXZlcnktaWQnPzogc3RyaW5nO1xuICBba2V5OiBzdHJpbmddOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmVyaWZ5T3B0aW9ucyB7XG4gIHRvbGVyYW5jZT86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBWZXJpZmllcyB0aGUgd2ViaG9vayBzaWduYXR1cmUgdXNpbmcgSE1BQy1TSEEyNTZcbiAqIEBwYXJhbSBwYXlsb2FkIC0gUmF3IHJlcXVlc3QgYm9keSBhcyBzdHJpbmdcbiAqIEBwYXJhbSBzaWduYXR1cmUgLSBYLVNpZ25hdHVyZSBoZWFkZXIgdmFsdWUgKGZvcm1hdDogdD10aW1lc3RhbXAsdjE9c2lnbmF0dXJlKVxuICogQHBhcmFtIHNlY3JldCAtIEVuZHBvaW50IHdlYmhvb2sgc2VjcmV0XG4gKiBAcGFyYW0gb3B0aW9ucyAtIFZlcmlmaWNhdGlvbiBvcHRpb25zXG4gKiBAcmV0dXJucyB0cnVlIGlmIHNpZ25hdHVyZSBpcyB2YWxpZFxuICogQHRocm93cyBXZWJob29rUGxhdGZvcm1FcnJvciBpZiBzaWduYXR1cmUgaXMgaW52YWxpZFxuICovXG5leHBvcnQgZnVuY3Rpb24gdmVyaWZ5U2lnbmF0dXJlKFxuICBwYXlsb2FkOiBzdHJpbmcsXG4gIHNpZ25hdHVyZTogc3RyaW5nLFxuICBzZWNyZXQ6IHN0cmluZyxcbiAgb3B0aW9uczogVmVyaWZ5T3B0aW9ucyA9IHt9XG4pOiBib29sZWFuIHtcbiAgY29uc3QgdG9sZXJhbmNlID0gb3B0aW9ucy50b2xlcmFuY2UgPz8gREVGQVVMVF9UT0xFUkFOQ0U7XG5cbiAgaWYgKCFzaWduYXR1cmUpIHtcbiAgICB0aHJvdyBuZXcgV2ViaG9va1BsYXRmb3JtRXJyb3IoJ01pc3Npbmcgc2lnbmF0dXJlIGhlYWRlcicsIDQwMCwgJ2ludmFsaWRfc2lnbmF0dXJlJyk7XG4gIH1cblxuICBjb25zdCBwYXJ0cyA9IHNpZ25hdHVyZS5zcGxpdCgnLCcpO1xuICBsZXQgdGltZXN0YW1wOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIGxldCBzaWc6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICBmb3IgKGNvbnN0IHBhcnQgb2YgcGFydHMpIHtcbiAgICBjb25zdCBba2V5LCB2YWx1ZV0gPSBwYXJ0LnNwbGl0KCc9Jyk7XG4gICAgaWYgKGtleSA9PT0gJ3QnKSB0aW1lc3RhbXAgPSB2YWx1ZTtcbiAgICBpZiAoa2V5ID09PSAndjEnKSBzaWcgPSB2YWx1ZTtcbiAgfVxuXG4gIGlmICghdGltZXN0YW1wIHx8ICFzaWcpIHtcbiAgICB0aHJvdyBuZXcgV2ViaG9va1BsYXRmb3JtRXJyb3IoXG4gICAgICAnSW52YWxpZCBzaWduYXR1cmUgZm9ybWF0LiBFeHBlY3RlZDogdD10aW1lc3RhbXAsdjE9c2lnbmF0dXJlJyxcbiAgICAgIDQwMCxcbiAgICAgICdpbnZhbGlkX3NpZ25hdHVyZSdcbiAgICApO1xuICB9XG5cbiAgY29uc3QgdGltZXN0YW1wTXMgPSBwYXJzZUludCh0aW1lc3RhbXAsIDEwKTtcbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcblxuICBpZiAoTWF0aC5hYnMobm93IC0gdGltZXN0YW1wTXMpID4gdG9sZXJhbmNlKSB7XG4gICAgdGhyb3cgbmV3IFdlYmhvb2tQbGF0Zm9ybUVycm9yKFxuICAgICAgJ1dlYmhvb2sgdGltZXN0YW1wIGlzIG91dHNpZGUgdG9sZXJhbmNlIHdpbmRvdycsXG4gICAgICA0MDAsXG4gICAgICAndGltZXN0YW1wX2V4cGlyZWQnXG4gICAgKTtcbiAgfVxuXG4gIGNvbnN0IHNpZ25lZFBheWxvYWQgPSBgJHt0aW1lc3RhbXB9LiR7cGF5bG9hZH1gO1xuICBjb25zdCBleHBlY3RlZFNpZ25hdHVyZSA9IGNyeXB0b1xuICAgIC5jcmVhdGVIbWFjKCdzaGEyNTYnLCBzZWNyZXQpXG4gICAgLnVwZGF0ZShzaWduZWRQYXlsb2FkKVxuICAgIC5kaWdlc3QoJ2hleCcpO1xuXG4gIGNvbnN0IHNpZ0J1ZmZlciA9IEJ1ZmZlci5mcm9tKHNpZyk7XG4gIGNvbnN0IGV4cGVjdGVkQnVmZmVyID0gQnVmZmVyLmZyb20oZXhwZWN0ZWRTaWduYXR1cmUpO1xuXG4gIGlmIChzaWdCdWZmZXIubGVuZ3RoICE9PSBleHBlY3RlZEJ1ZmZlci5sZW5ndGggfHwgIWNyeXB0by50aW1pbmdTYWZlRXF1YWwoc2lnQnVmZmVyLCBleHBlY3RlZEJ1ZmZlcikpIHtcbiAgICB0aHJvdyBuZXcgV2ViaG9va1BsYXRmb3JtRXJyb3IoJ0ludmFsaWQgc2lnbmF0dXJlJywgNDAwLCAnaW52YWxpZF9zaWduYXR1cmUnKTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG4vKipcbiAqIENvbnN0cnVjdHMgYSB3ZWJob29rIGV2ZW50IGZyb20gdGhlIHJlcXVlc3RcbiAqIEBwYXJhbSBwYXlsb2FkIC0gUmF3IHJlcXVlc3QgYm9keSBhcyBzdHJpbmdcbiAqIEBwYXJhbSBoZWFkZXJzIC0gUmVxdWVzdCBoZWFkZXJzXG4gKiBAcGFyYW0gc2VjcmV0IC0gRW5kcG9pbnQgd2ViaG9vayBzZWNyZXRcbiAqIEBwYXJhbSBvcHRpb25zIC0gVmVyaWZpY2F0aW9uIG9wdGlvbnNcbiAqIEByZXR1cm5zIFBhcnNlZCBhbmQgdmVyaWZpZWQgd2ViaG9vayBldmVudFxuICovXG5leHBvcnQgZnVuY3Rpb24gY29uc3RydWN0RXZlbnQoXG4gIHBheWxvYWQ6IHN0cmluZyxcbiAgaGVhZGVyczogV2ViaG9va0hlYWRlcnMsXG4gIHNlY3JldDogc3RyaW5nLFxuICBvcHRpb25zOiBWZXJpZnlPcHRpb25zID0ge31cbik6IFdlYmhvb2tFdmVudCB7XG4gIGNvbnN0IHNpZ25hdHVyZSA9IGhlYWRlcnNbU0lHTkFUVVJFX0hFQURFUl0gfHwgaGVhZGVyc1snWC1TaWduYXR1cmUnXTtcbiAgY29uc3QgdGltZXN0YW1wID0gaGVhZGVyc1tUSU1FU1RBTVBfSEVBREVSXSB8fCBoZWFkZXJzWydYLVRpbWVzdGFtcCddO1xuICBjb25zdCBldmVudElkID0gaGVhZGVyc1tFVkVOVF9JRF9IRUFERVJdIHx8IGhlYWRlcnNbJ1gtRXZlbnQtSWQnXTtcbiAgY29uc3QgZGVsaXZlcnlJZCA9IGhlYWRlcnNbREVMSVZFUllfSURfSEVBREVSXSB8fCBoZWFkZXJzWydYLURlbGl2ZXJ5LUlkJ107XG5cbiAgaWYgKCFzaWduYXR1cmUpIHtcbiAgICB0aHJvdyBuZXcgV2ViaG9va1BsYXRmb3JtRXJyb3IoJ01pc3NpbmcgWC1TaWduYXR1cmUgaGVhZGVyJywgNDAwLCAnbWlzc2luZ19oZWFkZXInKTtcbiAgfVxuXG4gIHZlcmlmeVNpZ25hdHVyZShwYXlsb2FkLCBzaWduYXR1cmUsIHNlY3JldCwgb3B0aW9ucyk7XG5cbiAgbGV0IGRhdGE6IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuICB0cnkge1xuICAgIGRhdGEgPSBKU09OLnBhcnNlKHBheWxvYWQpO1xuICB9IGNhdGNoIHtcbiAgICB0aHJvdyBuZXcgV2ViaG9va1BsYXRmb3JtRXJyb3IoJ0ludmFsaWQgSlNPTiBwYXlsb2FkJywgNDAwLCAnaW52YWxpZF9wYXlsb2FkJyk7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGV2ZW50SWQ6IGV2ZW50SWQgfHwgJycsXG4gICAgZGVsaXZlcnlJZDogZGVsaXZlcnlJZCB8fCAnJyxcbiAgICB0aW1lc3RhbXA6IHRpbWVzdGFtcCA/IHBhcnNlSW50KHRpbWVzdGFtcCwgMTApIDogRGF0ZS5ub3coKSxcbiAgICB0eXBlOiAoZGF0YS50eXBlIGFzIHN0cmluZykgfHwgJycsXG4gICAgZGF0YTogKGRhdGEuZGF0YSBhcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPikgfHwgZGF0YSxcbiAgfTtcbn1cblxuLyoqXG4gKiBHZW5lcmF0ZXMgYSBzaWduYXR1cmUgZm9yIHRlc3RpbmcgcHVycG9zZXNcbiAqIEBwYXJhbSBwYXlsb2FkIC0gUmVxdWVzdCBib2R5IGFzIHN0cmluZ1xuICogQHBhcmFtIHNlY3JldCAtIFdlYmhvb2sgc2VjcmV0XG4gKiBAcGFyYW0gdGltZXN0YW1wIC0gT3B0aW9uYWwgdGltZXN0YW1wIChkZWZhdWx0cyB0byBub3cpXG4gKiBAcmV0dXJucyBTaWduYXR1cmUgc3RyaW5nIGluIGZvcm1hdCB0PXRpbWVzdGFtcCx2MT1zaWduYXR1cmVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdlbmVyYXRlU2lnbmF0dXJlKFxuICBwYXlsb2FkOiBzdHJpbmcsXG4gIHNlY3JldDogc3RyaW5nLFxuICB0aW1lc3RhbXA/OiBudW1iZXJcbik6IHN0cmluZyB7XG4gIGNvbnN0IHRzID0gdGltZXN0YW1wID8/IERhdGUubm93KCk7XG4gIGNvbnN0IHNpZ25lZFBheWxvYWQgPSBgJHt0c30uJHtwYXlsb2FkfWA7XG4gIGNvbnN0IHNpZ25hdHVyZSA9IGNyeXB0b1xuICAgIC5jcmVhdGVIbWFjKCdzaGEyNTYnLCBzZWNyZXQpXG4gICAgLnVwZGF0ZShzaWduZWRQYXlsb2FkKVxuICAgIC5kaWdlc3QoJ2hleCcpO1xuXG4gIHJldHVybiBgdD0ke3RzfSx2MT0ke3NpZ25hdHVyZX1gO1xufVxuIl19
package/package.json ADDED
@@ -0,0 +1,42 @@
1
+ {
2
+ "name": "@webhook-platform/node",
3
+ "version": "1.0.0",
4
+ "description": "Official Node.js SDK for Webhook Platform",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "files": [
8
+ "dist"
9
+ ],
10
+ "scripts": {
11
+ "build": "tsc",
12
+ "test": "jest",
13
+ "lint": "eslint src --ext .ts",
14
+ "prepublishOnly": "npm run build"
15
+ },
16
+ "keywords": [
17
+ "webhook",
18
+ "webhooks",
19
+ "api",
20
+ "events",
21
+ "delivery"
22
+ ],
23
+ "author": "Webhook Platform",
24
+ "license": "MIT",
25
+ "repository": {
26
+ "type": "git",
27
+ "url": "https://github.com/vadymkykalo/webhook-platform.git",
28
+ "directory": "sdks/node"
29
+ },
30
+ "engines": {
31
+ "node": ">=16.0.0"
32
+ },
33
+ "dependencies": {},
34
+ "devDependencies": {
35
+ "@types/jest": "^29.5.0",
36
+ "@types/node": "^20.10.0",
37
+ "jest": "^29.7.0",
38
+ "ts-jest": "^29.1.0",
39
+ "typescript": "^5.3.0"
40
+ },
41
+ "peerDependencies": {}
42
+ }