@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.
- package/README.md +252 -0
- package/dist/__tests__/client.test.d.ts +1 -0
- package/dist/__tests__/client.test.js +79 -0
- package/dist/__tests__/webhooks.test.d.ts +1 -0
- package/dist/__tests__/webhooks.test.js +162 -0
- package/dist/client.d.ts +48 -0
- package/dist/client.js +229 -0
- package/dist/errors.d.ts +21 -0
- package/dist/errors.js +46 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +29 -0
- package/dist/types.d.ts +102 -0
- package/dist/types.js +3 -0
- package/dist/webhooks.d.ts +38 -0
- package/dist/webhooks.js +138 -0
- package/package.json +42 -0
package/dist/client.js
ADDED
|
@@ -0,0 +1,229 @@
|
|
|
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.WebhookPlatform = void 0;
|
|
37
|
+
const https = __importStar(require("https"));
|
|
38
|
+
const http = __importStar(require("http"));
|
|
39
|
+
const url_1 = require("url");
|
|
40
|
+
const errors_1 = require("./errors");
|
|
41
|
+
const DEFAULT_BASE_URL = 'http://localhost:8080';
|
|
42
|
+
const DEFAULT_TIMEOUT = 30000;
|
|
43
|
+
const SDK_VERSION = '1.0.0';
|
|
44
|
+
class WebhookPlatform {
|
|
45
|
+
constructor(config) {
|
|
46
|
+
if (!config.apiKey) {
|
|
47
|
+
throw new Error('API key is required');
|
|
48
|
+
}
|
|
49
|
+
this.apiKey = config.apiKey;
|
|
50
|
+
this.baseUrl = config.baseUrl || DEFAULT_BASE_URL;
|
|
51
|
+
this.timeout = config.timeout || DEFAULT_TIMEOUT;
|
|
52
|
+
this.events = new Events(this);
|
|
53
|
+
this.endpoints = new Endpoints(this);
|
|
54
|
+
this.subscriptions = new Subscriptions(this);
|
|
55
|
+
this.deliveries = new Deliveries(this);
|
|
56
|
+
}
|
|
57
|
+
async request(method, path, body, idempotencyKey) {
|
|
58
|
+
const url = new url_1.URL(path, this.baseUrl);
|
|
59
|
+
const isHttps = url.protocol === 'https:';
|
|
60
|
+
const lib = isHttps ? https : http;
|
|
61
|
+
const headers = {
|
|
62
|
+
'X-API-Key': this.apiKey,
|
|
63
|
+
'Content-Type': 'application/json',
|
|
64
|
+
'User-Agent': `webhook-platform-node/${SDK_VERSION}`,
|
|
65
|
+
};
|
|
66
|
+
if (idempotencyKey) {
|
|
67
|
+
headers['Idempotency-Key'] = idempotencyKey;
|
|
68
|
+
}
|
|
69
|
+
const options = {
|
|
70
|
+
method,
|
|
71
|
+
hostname: url.hostname,
|
|
72
|
+
port: url.port || (isHttps ? 443 : 80),
|
|
73
|
+
path: url.pathname + url.search,
|
|
74
|
+
headers,
|
|
75
|
+
timeout: this.timeout,
|
|
76
|
+
};
|
|
77
|
+
return new Promise((resolve, reject) => {
|
|
78
|
+
const req = lib.request(options, (res) => {
|
|
79
|
+
let data = '';
|
|
80
|
+
res.on('data', (chunk) => (data += chunk));
|
|
81
|
+
res.on('end', () => {
|
|
82
|
+
try {
|
|
83
|
+
const rateLimitInfo = this.extractRateLimitInfo(res.headers);
|
|
84
|
+
if (res.statusCode === 204) {
|
|
85
|
+
resolve(undefined);
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
const parsed = data ? JSON.parse(data) : {};
|
|
89
|
+
if (res.statusCode && res.statusCode >= 400) {
|
|
90
|
+
reject(this.handleError(res.statusCode, parsed, rateLimitInfo));
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
resolve(parsed);
|
|
94
|
+
}
|
|
95
|
+
catch (err) {
|
|
96
|
+
reject(new errors_1.WebhookPlatformError('Failed to parse response', 500));
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
req.on('error', (err) => {
|
|
101
|
+
reject(new errors_1.WebhookPlatformError(err.message, 0, 'network_error'));
|
|
102
|
+
});
|
|
103
|
+
req.on('timeout', () => {
|
|
104
|
+
req.destroy();
|
|
105
|
+
reject(new errors_1.WebhookPlatformError('Request timeout', 0, 'timeout'));
|
|
106
|
+
});
|
|
107
|
+
if (body) {
|
|
108
|
+
req.write(JSON.stringify(body));
|
|
109
|
+
}
|
|
110
|
+
req.end();
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
extractRateLimitInfo(headers) {
|
|
114
|
+
const limit = headers['x-ratelimit-limit'];
|
|
115
|
+
const remaining = headers['x-ratelimit-remaining'];
|
|
116
|
+
const reset = headers['x-ratelimit-reset'];
|
|
117
|
+
if (limit && remaining && reset) {
|
|
118
|
+
return {
|
|
119
|
+
limit: parseInt(limit, 10),
|
|
120
|
+
remaining: parseInt(remaining, 10),
|
|
121
|
+
reset: parseInt(reset, 10),
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
return undefined;
|
|
125
|
+
}
|
|
126
|
+
handleError(status, body, rateLimitInfo) {
|
|
127
|
+
const message = body.message || 'Unknown error';
|
|
128
|
+
switch (status) {
|
|
129
|
+
case 401:
|
|
130
|
+
return new errors_1.AuthenticationError(message);
|
|
131
|
+
case 404:
|
|
132
|
+
return new errors_1.NotFoundError(message);
|
|
133
|
+
case 429:
|
|
134
|
+
return new errors_1.RateLimitError(message, rateLimitInfo || { limit: 0, remaining: 0, reset: Date.now() + 60000 });
|
|
135
|
+
case 400:
|
|
136
|
+
return new errors_1.ValidationError(message, body.fieldErrors || {});
|
|
137
|
+
default:
|
|
138
|
+
return new errors_1.WebhookPlatformError(message, status, body.error);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
exports.WebhookPlatform = WebhookPlatform;
|
|
143
|
+
class Events {
|
|
144
|
+
constructor(client) {
|
|
145
|
+
this.client = client;
|
|
146
|
+
}
|
|
147
|
+
async send(event, idempotencyKey) {
|
|
148
|
+
return this.client.request('POST', '/api/v1/events', event, idempotencyKey);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
class Endpoints {
|
|
152
|
+
constructor(client) {
|
|
153
|
+
this.client = client;
|
|
154
|
+
}
|
|
155
|
+
async create(projectId, params) {
|
|
156
|
+
return this.client.request('POST', `/api/v1/projects/${projectId}/endpoints`, params);
|
|
157
|
+
}
|
|
158
|
+
async get(projectId, endpointId) {
|
|
159
|
+
return this.client.request('GET', `/api/v1/projects/${projectId}/endpoints/${endpointId}`);
|
|
160
|
+
}
|
|
161
|
+
async list(projectId) {
|
|
162
|
+
return this.client.request('GET', `/api/v1/projects/${projectId}/endpoints`);
|
|
163
|
+
}
|
|
164
|
+
async update(projectId, endpointId, params) {
|
|
165
|
+
return this.client.request('PUT', `/api/v1/projects/${projectId}/endpoints/${endpointId}`, params);
|
|
166
|
+
}
|
|
167
|
+
async delete(projectId, endpointId) {
|
|
168
|
+
return this.client.request('DELETE', `/api/v1/projects/${projectId}/endpoints/${endpointId}`);
|
|
169
|
+
}
|
|
170
|
+
async rotateSecret(projectId, endpointId) {
|
|
171
|
+
return this.client.request('POST', `/api/v1/projects/${projectId}/endpoints/${endpointId}/rotate-secret`);
|
|
172
|
+
}
|
|
173
|
+
async test(projectId, endpointId) {
|
|
174
|
+
return this.client.request('POST', `/api/v1/projects/${projectId}/endpoints/${endpointId}/test`);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
class Subscriptions {
|
|
178
|
+
constructor(client) {
|
|
179
|
+
this.client = client;
|
|
180
|
+
}
|
|
181
|
+
async create(projectId, params) {
|
|
182
|
+
return this.client.request('POST', `/api/v1/projects/${projectId}/subscriptions`, params);
|
|
183
|
+
}
|
|
184
|
+
async get(projectId, subscriptionId) {
|
|
185
|
+
return this.client.request('GET', `/api/v1/projects/${projectId}/subscriptions/${subscriptionId}`);
|
|
186
|
+
}
|
|
187
|
+
async list(projectId) {
|
|
188
|
+
return this.client.request('GET', `/api/v1/projects/${projectId}/subscriptions`);
|
|
189
|
+
}
|
|
190
|
+
async update(projectId, subscriptionId, params) {
|
|
191
|
+
return this.client.request('PUT', `/api/v1/projects/${projectId}/subscriptions/${subscriptionId}`, params);
|
|
192
|
+
}
|
|
193
|
+
async delete(projectId, subscriptionId) {
|
|
194
|
+
return this.client.request('DELETE', `/api/v1/projects/${projectId}/subscriptions/${subscriptionId}`);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
class Deliveries {
|
|
198
|
+
constructor(client) {
|
|
199
|
+
this.client = client;
|
|
200
|
+
}
|
|
201
|
+
async get(deliveryId) {
|
|
202
|
+
return this.client.request('GET', `/api/v1/deliveries/${deliveryId}`);
|
|
203
|
+
}
|
|
204
|
+
async list(projectId, params = {}) {
|
|
205
|
+
const query = new URLSearchParams();
|
|
206
|
+
if (params.status)
|
|
207
|
+
query.set('status', params.status);
|
|
208
|
+
if (params.endpointId)
|
|
209
|
+
query.set('endpointId', params.endpointId);
|
|
210
|
+
if (params.fromDate)
|
|
211
|
+
query.set('fromDate', params.fromDate);
|
|
212
|
+
if (params.toDate)
|
|
213
|
+
query.set('toDate', params.toDate);
|
|
214
|
+
if (params.page !== undefined)
|
|
215
|
+
query.set('page', params.page.toString());
|
|
216
|
+
if (params.size !== undefined)
|
|
217
|
+
query.set('size', params.size.toString());
|
|
218
|
+
const queryString = query.toString();
|
|
219
|
+
const path = `/api/v1/deliveries/projects/${projectId}${queryString ? `?${queryString}` : ''}`;
|
|
220
|
+
return this.client.request('GET', path);
|
|
221
|
+
}
|
|
222
|
+
async getAttempts(deliveryId) {
|
|
223
|
+
return this.client.request('GET', `/api/v1/deliveries/${deliveryId}/attempts`);
|
|
224
|
+
}
|
|
225
|
+
async replay(deliveryId) {
|
|
226
|
+
return this.client.request('POST', `/api/v1/deliveries/${deliveryId}/replay`);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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","sourcesContent":["import * as https from 'https';\nimport * as http from 'http';\nimport { URL } from 'url';\nimport {\n  WebhookPlatformConfig,\n  Event,\n  EventResponse,\n  Endpoint,\n  EndpointCreateParams,\n  EndpointUpdateParams,\n  Subscription,\n  SubscriptionCreateParams,\n  Delivery,\n  DeliveryAttempt,\n  DeliveryListParams,\n  PaginatedResponse,\n  EndpointTestResult,\n  RateLimitInfo,\n} from './types';\nimport {\n  WebhookPlatformError,\n  AuthenticationError,\n  RateLimitError,\n  ValidationError,\n  NotFoundError,\n} from './errors';\n\nconst DEFAULT_BASE_URL = 'http://localhost:8080';\nconst DEFAULT_TIMEOUT = 30000;\nconst SDK_VERSION = '1.0.0';\n\nexport class WebhookPlatform {\n  private readonly apiKey: string;\n  private readonly baseUrl: string;\n  private readonly timeout: number;\n\n  public readonly events: Events;\n  public readonly endpoints: Endpoints;\n  public readonly subscriptions: Subscriptions;\n  public readonly deliveries: Deliveries;\n\n  constructor(config: WebhookPlatformConfig) {\n    if (!config.apiKey) {\n      throw new Error('API key is required');\n    }\n\n    this.apiKey = config.apiKey;\n    this.baseUrl = config.baseUrl || DEFAULT_BASE_URL;\n    this.timeout = config.timeout || DEFAULT_TIMEOUT;\n\n    this.events = new Events(this);\n    this.endpoints = new Endpoints(this);\n    this.subscriptions = new Subscriptions(this);\n    this.deliveries = new Deliveries(this);\n  }\n\n  async request<T>(\n    method: string,\n    path: string,\n    body?: unknown,\n    idempotencyKey?: string\n  ): Promise<T> {\n    const url = new URL(path, this.baseUrl);\n    const isHttps = url.protocol === 'https:';\n    const lib = isHttps ? https : http;\n\n    const headers: Record<string, string> = {\n      'X-API-Key': this.apiKey,\n      'Content-Type': 'application/json',\n      'User-Agent': `webhook-platform-node/${SDK_VERSION}`,\n    };\n\n    if (idempotencyKey) {\n      headers['Idempotency-Key'] = idempotencyKey;\n    }\n\n    const options: http.RequestOptions = {\n      method,\n      hostname: url.hostname,\n      port: url.port || (isHttps ? 443 : 80),\n      path: url.pathname + url.search,\n      headers,\n      timeout: this.timeout,\n    };\n\n    return new Promise((resolve, reject) => {\n      const req = lib.request(options, (res) => {\n        let data = '';\n        res.on('data', (chunk) => (data += chunk));\n        res.on('end', () => {\n          try {\n            const rateLimitInfo = this.extractRateLimitInfo(res.headers);\n            \n            if (res.statusCode === 204) {\n              resolve(undefined as T);\n              return;\n            }\n\n            const parsed = data ? JSON.parse(data) : {};\n\n            if (res.statusCode && res.statusCode >= 400) {\n              reject(this.handleError(res.statusCode, parsed, rateLimitInfo));\n              return;\n            }\n\n            resolve(parsed as T);\n          } catch (err) {\n            reject(new WebhookPlatformError('Failed to parse response', 500));\n          }\n        });\n      });\n\n      req.on('error', (err) => {\n        reject(new WebhookPlatformError(err.message, 0, 'network_error'));\n      });\n\n      req.on('timeout', () => {\n        req.destroy();\n        reject(new WebhookPlatformError('Request timeout', 0, 'timeout'));\n      });\n\n      if (body) {\n        req.write(JSON.stringify(body));\n      }\n\n      req.end();\n    });\n  }\n\n  private extractRateLimitInfo(headers: http.IncomingHttpHeaders): RateLimitInfo | undefined {\n    const limit = headers['x-ratelimit-limit'];\n    const remaining = headers['x-ratelimit-remaining'];\n    const reset = headers['x-ratelimit-reset'];\n\n    if (limit && remaining && reset) {\n      return {\n        limit: parseInt(limit as string, 10),\n        remaining: parseInt(remaining as string, 10),\n        reset: parseInt(reset as string, 10),\n      };\n    }\n    return undefined;\n  }\n\n  private handleError(\n    status: number,\n    body: Record<string, unknown>,\n    rateLimitInfo?: RateLimitInfo\n  ): WebhookPlatformError {\n    const message = (body.message as string) || 'Unknown error';\n\n    switch (status) {\n      case 401:\n        return new AuthenticationError(message);\n      case 404:\n        return new NotFoundError(message);\n      case 429:\n        return new RateLimitError(\n          message,\n          rateLimitInfo || { limit: 0, remaining: 0, reset: Date.now() + 60000 }\n        );\n      case 400:\n        return new ValidationError(\n          message,\n          (body.fieldErrors as Record<string, string>) || {}\n        );\n      default:\n        return new WebhookPlatformError(message, status, body.error as string);\n    }\n  }\n}\n\nclass Events {\n  constructor(private client: WebhookPlatform) {}\n\n  async send(event: Event, idempotencyKey?: string): Promise<EventResponse> {\n    return this.client.request<EventResponse>(\n      'POST',\n      '/api/v1/events',\n      event,\n      idempotencyKey\n    );\n  }\n}\n\nclass Endpoints {\n  constructor(private client: WebhookPlatform) {}\n\n  async create(projectId: string, params: EndpointCreateParams): Promise<Endpoint> {\n    return this.client.request<Endpoint>(\n      'POST',\n      `/api/v1/projects/${projectId}/endpoints`,\n      params\n    );\n  }\n\n  async get(projectId: string, endpointId: string): Promise<Endpoint> {\n    return this.client.request<Endpoint>(\n      'GET',\n      `/api/v1/projects/${projectId}/endpoints/${endpointId}`\n    );\n  }\n\n  async list(projectId: string): Promise<Endpoint[]> {\n    return this.client.request<Endpoint[]>(\n      'GET',\n      `/api/v1/projects/${projectId}/endpoints`\n    );\n  }\n\n  async update(\n    projectId: string,\n    endpointId: string,\n    params: EndpointUpdateParams\n  ): Promise<Endpoint> {\n    return this.client.request<Endpoint>(\n      'PUT',\n      `/api/v1/projects/${projectId}/endpoints/${endpointId}`,\n      params\n    );\n  }\n\n  async delete(projectId: string, endpointId: string): Promise<void> {\n    return this.client.request<void>(\n      'DELETE',\n      `/api/v1/projects/${projectId}/endpoints/${endpointId}`\n    );\n  }\n\n  async rotateSecret(projectId: string, endpointId: string): Promise<Endpoint> {\n    return this.client.request<Endpoint>(\n      'POST',\n      `/api/v1/projects/${projectId}/endpoints/${endpointId}/rotate-secret`\n    );\n  }\n\n  async test(projectId: string, endpointId: string): Promise<EndpointTestResult> {\n    return this.client.request<EndpointTestResult>(\n      'POST',\n      `/api/v1/projects/${projectId}/endpoints/${endpointId}/test`\n    );\n  }\n}\n\nclass Subscriptions {\n  constructor(private client: WebhookPlatform) {}\n\n  async create(projectId: string, params: SubscriptionCreateParams): Promise<Subscription> {\n    return this.client.request<Subscription>(\n      'POST',\n      `/api/v1/projects/${projectId}/subscriptions`,\n      params\n    );\n  }\n\n  async get(projectId: string, subscriptionId: string): Promise<Subscription> {\n    return this.client.request<Subscription>(\n      'GET',\n      `/api/v1/projects/${projectId}/subscriptions/${subscriptionId}`\n    );\n  }\n\n  async list(projectId: string): Promise<Subscription[]> {\n    return this.client.request<Subscription[]>(\n      'GET',\n      `/api/v1/projects/${projectId}/subscriptions`\n    );\n  }\n\n  async update(\n    projectId: string,\n    subscriptionId: string,\n    params: Partial<SubscriptionCreateParams>\n  ): Promise<Subscription> {\n    return this.client.request<Subscription>(\n      'PUT',\n      `/api/v1/projects/${projectId}/subscriptions/${subscriptionId}`,\n      params\n    );\n  }\n\n  async delete(projectId: string, subscriptionId: string): Promise<void> {\n    return this.client.request<void>(\n      'DELETE',\n      `/api/v1/projects/${projectId}/subscriptions/${subscriptionId}`\n    );\n  }\n}\n\nclass Deliveries {\n  constructor(private client: WebhookPlatform) {}\n\n  async get(deliveryId: string): Promise<Delivery> {\n    return this.client.request<Delivery>('GET', `/api/v1/deliveries/${deliveryId}`);\n  }\n\n  async list(\n    projectId: string,\n    params: DeliveryListParams = {}\n  ): Promise<PaginatedResponse<Delivery>> {\n    const query = new URLSearchParams();\n    if (params.status) query.set('status', params.status);\n    if (params.endpointId) query.set('endpointId', params.endpointId);\n    if (params.fromDate) query.set('fromDate', params.fromDate);\n    if (params.toDate) query.set('toDate', params.toDate);\n    if (params.page !== undefined) query.set('page', params.page.toString());\n    if (params.size !== undefined) query.set('size', params.size.toString());\n\n    const queryString = query.toString();\n    const path = `/api/v1/deliveries/projects/${projectId}${queryString ? `?${queryString}` : ''}`;\n\n    return this.client.request<PaginatedResponse<Delivery>>('GET', path);\n  }\n\n  async getAttempts(deliveryId: string): Promise<DeliveryAttempt[]> {\n    return this.client.request<DeliveryAttempt[]>(\n      'GET',\n      `/api/v1/deliveries/${deliveryId}/attempts`\n    );\n  }\n\n  async replay(deliveryId: string): Promise<void> {\n    return this.client.request<void>('POST', `/api/v1/deliveries/${deliveryId}/replay`);\n  }\n}\n"]}
|
package/dist/errors.d.ts
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { RateLimitInfo } from './types';
|
|
2
|
+
export declare class WebhookPlatformError extends Error {
|
|
3
|
+
readonly status: number;
|
|
4
|
+
readonly code?: string;
|
|
5
|
+
constructor(message: string, status: number, code?: string);
|
|
6
|
+
}
|
|
7
|
+
export declare class AuthenticationError extends WebhookPlatformError {
|
|
8
|
+
constructor(message?: string);
|
|
9
|
+
}
|
|
10
|
+
export declare class RateLimitError extends WebhookPlatformError {
|
|
11
|
+
readonly rateLimitInfo: RateLimitInfo;
|
|
12
|
+
constructor(message: string, rateLimitInfo: RateLimitInfo);
|
|
13
|
+
get retryAfter(): number;
|
|
14
|
+
}
|
|
15
|
+
export declare class ValidationError extends WebhookPlatformError {
|
|
16
|
+
readonly fieldErrors: Record<string, string>;
|
|
17
|
+
constructor(message: string, fieldErrors?: Record<string, string>);
|
|
18
|
+
}
|
|
19
|
+
export declare class NotFoundError extends WebhookPlatformError {
|
|
20
|
+
constructor(message?: string);
|
|
21
|
+
}
|
package/dist/errors.js
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NotFoundError = exports.ValidationError = exports.RateLimitError = exports.AuthenticationError = exports.WebhookPlatformError = void 0;
|
|
4
|
+
class WebhookPlatformError extends Error {
|
|
5
|
+
constructor(message, status, code) {
|
|
6
|
+
super(message);
|
|
7
|
+
this.name = 'WebhookPlatformError';
|
|
8
|
+
this.status = status;
|
|
9
|
+
this.code = code;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
exports.WebhookPlatformError = WebhookPlatformError;
|
|
13
|
+
class AuthenticationError extends WebhookPlatformError {
|
|
14
|
+
constructor(message = 'Invalid API key') {
|
|
15
|
+
super(message, 401, 'authentication_error');
|
|
16
|
+
this.name = 'AuthenticationError';
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.AuthenticationError = AuthenticationError;
|
|
20
|
+
class RateLimitError extends WebhookPlatformError {
|
|
21
|
+
constructor(message, rateLimitInfo) {
|
|
22
|
+
super(message, 429, 'rate_limit_exceeded');
|
|
23
|
+
this.name = 'RateLimitError';
|
|
24
|
+
this.rateLimitInfo = rateLimitInfo;
|
|
25
|
+
}
|
|
26
|
+
get retryAfter() {
|
|
27
|
+
return Math.max(0, this.rateLimitInfo.reset - Date.now());
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.RateLimitError = RateLimitError;
|
|
31
|
+
class ValidationError extends WebhookPlatformError {
|
|
32
|
+
constructor(message, fieldErrors = {}) {
|
|
33
|
+
super(message, 400, 'validation_error');
|
|
34
|
+
this.name = 'ValidationError';
|
|
35
|
+
this.fieldErrors = fieldErrors;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
exports.ValidationError = ValidationError;
|
|
39
|
+
class NotFoundError extends WebhookPlatformError {
|
|
40
|
+
constructor(message = 'Resource not found') {
|
|
41
|
+
super(message, 404, 'not_found');
|
|
42
|
+
this.name = 'NotFoundError';
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.NotFoundError = NotFoundError;
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSxNQUFhLG9CQUFxQixTQUFRLEtBQUs7SUFJN0MsWUFBWSxPQUFlLEVBQUUsTUFBYyxFQUFFLElBQWE7UUFDeEQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxzQkFBc0IsQ0FBQztRQUNuQyxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUNuQixDQUFDO0NBQ0Y7QUFWRCxvREFVQztBQUVELE1BQWEsbUJBQW9CLFNBQVEsb0JBQW9CO0lBQzNELFlBQVksVUFBa0IsaUJBQWlCO1FBQzdDLEtBQUssQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFLHNCQUFzQixDQUFDLENBQUM7UUFDNUMsSUFBSSxDQUFDLElBQUksR0FBRyxxQkFBcUIsQ0FBQztJQUNwQyxDQUFDO0NBQ0Y7QUFMRCxrREFLQztBQUVELE1BQWEsY0FBZSxTQUFRLG9CQUFvQjtJQUd0RCxZQUFZLE9BQWUsRUFBRSxhQUE0QjtRQUN2RCxLQUFLLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxxQkFBcUIsQ0FBQyxDQUFDO1FBQzNDLElBQUksQ0FBQyxJQUFJLEdBQUcsZ0JBQWdCLENBQUM7UUFDN0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxhQUFhLENBQUM7SUFDckMsQ0FBQztJQUVELElBQUksVUFBVTtRQUNaLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDNUQsQ0FBQztDQUNGO0FBWkQsd0NBWUM7QUFFRCxNQUFhLGVBQWdCLFNBQVEsb0JBQW9CO0lBR3ZELFlBQVksT0FBZSxFQUFFLGNBQXNDLEVBQUU7UUFDbkUsS0FBSyxDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztRQUN4QyxJQUFJLENBQUMsSUFBSSxHQUFHLGlCQUFpQixDQUFDO1FBQzlCLElBQUksQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO0lBQ2pDLENBQUM7Q0FDRjtBQVJELDBDQVFDO0FBRUQsTUFBYSxhQUFjLFNBQVEsb0JBQW9CO0lBQ3JELFlBQVksVUFBa0Isb0JBQW9CO1FBQ2hELEtBQUssQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxJQUFJLEdBQUcsZUFBZSxDQUFDO0lBQzlCLENBQUM7Q0FDRjtBQUxELHNDQUtDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmF0ZUxpbWl0SW5mbyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY2xhc3MgV2ViaG9va1BsYXRmb3JtRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIHB1YmxpYyByZWFkb25seSBzdGF0dXM6IG51bWJlcjtcbiAgcHVibGljIHJlYWRvbmx5IGNvZGU/OiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nLCBzdGF0dXM6IG51bWJlciwgY29kZT86IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdXZWJob29rUGxhdGZvcm1FcnJvcic7XG4gICAgdGhpcy5zdGF0dXMgPSBzdGF0dXM7XG4gICAgdGhpcy5jb2RlID0gY29kZTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQXV0aGVudGljYXRpb25FcnJvciBleHRlbmRzIFdlYmhvb2tQbGF0Zm9ybUVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nID0gJ0ludmFsaWQgQVBJIGtleScpIHtcbiAgICBzdXBlcihtZXNzYWdlLCA0MDEsICdhdXRoZW50aWNhdGlvbl9lcnJvcicpO1xuICAgIHRoaXMubmFtZSA9ICdBdXRoZW50aWNhdGlvbkVycm9yJztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgUmF0ZUxpbWl0RXJyb3IgZXh0ZW5kcyBXZWJob29rUGxhdGZvcm1FcnJvciB7XG4gIHB1YmxpYyByZWFkb25seSByYXRlTGltaXRJbmZvOiBSYXRlTGltaXRJbmZvO1xuXG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZywgcmF0ZUxpbWl0SW5mbzogUmF0ZUxpbWl0SW5mbykge1xuICAgIHN1cGVyKG1lc3NhZ2UsIDQyOSwgJ3JhdGVfbGltaXRfZXhjZWVkZWQnKTtcbiAgICB0aGlzLm5hbWUgPSAnUmF0ZUxpbWl0RXJyb3InO1xuICAgIHRoaXMucmF0ZUxpbWl0SW5mbyA9IHJhdGVMaW1pdEluZm87XG4gIH1cblxuICBnZXQgcmV0cnlBZnRlcigpOiBudW1iZXIge1xuICAgIHJldHVybiBNYXRoLm1heCgwLCB0aGlzLnJhdGVMaW1pdEluZm8ucmVzZXQgLSBEYXRlLm5vdygpKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgVmFsaWRhdGlvbkVycm9yIGV4dGVuZHMgV2ViaG9va1BsYXRmb3JtRXJyb3Ige1xuICBwdWJsaWMgcmVhZG9ubHkgZmllbGRFcnJvcnM6IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG5cbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nLCBmaWVsZEVycm9yczogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IHt9KSB7XG4gICAgc3VwZXIobWVzc2FnZSwgNDAwLCAndmFsaWRhdGlvbl9lcnJvcicpO1xuICAgIHRoaXMubmFtZSA9ICdWYWxpZGF0aW9uRXJyb3InO1xuICAgIHRoaXMuZmllbGRFcnJvcnMgPSBmaWVsZEVycm9ycztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgTm90Rm91bmRFcnJvciBleHRlbmRzIFdlYmhvb2tQbGF0Zm9ybUVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nID0gJ1Jlc291cmNlIG5vdCBmb3VuZCcpIHtcbiAgICBzdXBlcihtZXNzYWdlLCA0MDQsICdub3RfZm91bmQnKTtcbiAgICB0aGlzLm5hbWUgPSAnTm90Rm91bmRFcnJvcic7XG4gIH1cbn1cbiJdfQ==
|
package/dist/index.d.ts
ADDED
package/dist/index.js
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.constructEvent = exports.verifySignature = exports.ValidationError = exports.AuthenticationError = exports.RateLimitError = exports.WebhookPlatformError = exports.WebhookPlatform = void 0;
|
|
18
|
+
var client_1 = require("./client");
|
|
19
|
+
Object.defineProperty(exports, "WebhookPlatform", { enumerable: true, get: function () { return client_1.WebhookPlatform; } });
|
|
20
|
+
var errors_1 = require("./errors");
|
|
21
|
+
Object.defineProperty(exports, "WebhookPlatformError", { enumerable: true, get: function () { return errors_1.WebhookPlatformError; } });
|
|
22
|
+
Object.defineProperty(exports, "RateLimitError", { enumerable: true, get: function () { return errors_1.RateLimitError; } });
|
|
23
|
+
Object.defineProperty(exports, "AuthenticationError", { enumerable: true, get: function () { return errors_1.AuthenticationError; } });
|
|
24
|
+
Object.defineProperty(exports, "ValidationError", { enumerable: true, get: function () { return errors_1.ValidationError; } });
|
|
25
|
+
var webhooks_1 = require("./webhooks");
|
|
26
|
+
Object.defineProperty(exports, "verifySignature", { enumerable: true, get: function () { return webhooks_1.verifySignature; } });
|
|
27
|
+
Object.defineProperty(exports, "constructEvent", { enumerable: true, get: function () { return webhooks_1.constructEvent; } });
|
|
28
|
+
__exportStar(require("./types"), exports);
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxtQ0FBMkM7QUFBbEMseUdBQUEsZUFBZSxPQUFBO0FBQ3hCLG1DQUFzRztBQUE3Riw4R0FBQSxvQkFBb0IsT0FBQTtBQUFFLHdHQUFBLGNBQWMsT0FBQTtBQUFFLDZHQUFBLG1CQUFtQixPQUFBO0FBQUUseUdBQUEsZUFBZSxPQUFBO0FBQ25GLHVDQUE2RDtBQUFwRCwyR0FBQSxlQUFlLE9BQUE7QUFBRSwwR0FBQSxjQUFjLE9BQUE7QUFDeEMsMENBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgV2ViaG9va1BsYXRmb3JtIH0gZnJvbSAnLi9jbGllbnQnO1xuZXhwb3J0IHsgV2ViaG9va1BsYXRmb3JtRXJyb3IsIFJhdGVMaW1pdEVycm9yLCBBdXRoZW50aWNhdGlvbkVycm9yLCBWYWxpZGF0aW9uRXJyb3IgfSBmcm9tICcuL2Vycm9ycyc7XG5leHBvcnQgeyB2ZXJpZnlTaWduYXR1cmUsIGNvbnN0cnVjdEV2ZW50IH0gZnJvbSAnLi93ZWJob29rcyc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbiJdfQ==
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
export interface WebhookPlatformConfig {
|
|
2
|
+
apiKey: string;
|
|
3
|
+
baseUrl?: string;
|
|
4
|
+
timeout?: number;
|
|
5
|
+
}
|
|
6
|
+
export interface Event {
|
|
7
|
+
type: string;
|
|
8
|
+
data: Record<string, unknown>;
|
|
9
|
+
}
|
|
10
|
+
export interface EventResponse {
|
|
11
|
+
eventId: string;
|
|
12
|
+
type: string;
|
|
13
|
+
createdAt: string;
|
|
14
|
+
deliveriesCreated: number;
|
|
15
|
+
}
|
|
16
|
+
export interface Endpoint {
|
|
17
|
+
id: string;
|
|
18
|
+
url: string;
|
|
19
|
+
description?: string;
|
|
20
|
+
secret: string;
|
|
21
|
+
enabled: boolean;
|
|
22
|
+
rateLimitPerSecond?: number;
|
|
23
|
+
createdAt: string;
|
|
24
|
+
}
|
|
25
|
+
export interface EndpointCreateParams {
|
|
26
|
+
url: string;
|
|
27
|
+
description?: string;
|
|
28
|
+
enabled?: boolean;
|
|
29
|
+
rateLimitPerSecond?: number;
|
|
30
|
+
}
|
|
31
|
+
export interface EndpointUpdateParams {
|
|
32
|
+
url?: string;
|
|
33
|
+
description?: string;
|
|
34
|
+
enabled?: boolean;
|
|
35
|
+
rateLimitPerSecond?: number;
|
|
36
|
+
}
|
|
37
|
+
export interface Subscription {
|
|
38
|
+
id: string;
|
|
39
|
+
endpointId: string;
|
|
40
|
+
eventTypes: string[];
|
|
41
|
+
enabled: boolean;
|
|
42
|
+
createdAt: string;
|
|
43
|
+
}
|
|
44
|
+
export interface SubscriptionCreateParams {
|
|
45
|
+
endpointId: string;
|
|
46
|
+
eventTypes: string[];
|
|
47
|
+
enabled?: boolean;
|
|
48
|
+
}
|
|
49
|
+
export interface Delivery {
|
|
50
|
+
id: string;
|
|
51
|
+
eventId: string;
|
|
52
|
+
endpointId: string;
|
|
53
|
+
status: DeliveryStatus;
|
|
54
|
+
attemptCount: number;
|
|
55
|
+
maxAttempts: number;
|
|
56
|
+
nextAttemptAt?: string;
|
|
57
|
+
createdAt: string;
|
|
58
|
+
succeededAt?: string;
|
|
59
|
+
}
|
|
60
|
+
export type DeliveryStatus = 'PENDING' | 'SUCCESS' | 'FAILED' | 'DEAD_LETTER';
|
|
61
|
+
export interface DeliveryAttempt {
|
|
62
|
+
id: string;
|
|
63
|
+
attemptNumber: number;
|
|
64
|
+
httpStatus?: number;
|
|
65
|
+
responseBody?: string;
|
|
66
|
+
errorMessage?: string;
|
|
67
|
+
latencyMs: number;
|
|
68
|
+
attemptedAt: string;
|
|
69
|
+
}
|
|
70
|
+
export interface PaginatedResponse<T> {
|
|
71
|
+
content: T[];
|
|
72
|
+
totalElements: number;
|
|
73
|
+
totalPages: number;
|
|
74
|
+
size: number;
|
|
75
|
+
number: number;
|
|
76
|
+
}
|
|
77
|
+
export interface DeliveryListParams {
|
|
78
|
+
status?: DeliveryStatus;
|
|
79
|
+
endpointId?: string;
|
|
80
|
+
fromDate?: string;
|
|
81
|
+
toDate?: string;
|
|
82
|
+
page?: number;
|
|
83
|
+
size?: number;
|
|
84
|
+
}
|
|
85
|
+
export interface EndpointTestResult {
|
|
86
|
+
success: boolean;
|
|
87
|
+
httpStatus?: number;
|
|
88
|
+
latencyMs: number;
|
|
89
|
+
errorMessage?: string;
|
|
90
|
+
}
|
|
91
|
+
export interface RateLimitInfo {
|
|
92
|
+
limit: number;
|
|
93
|
+
remaining: number;
|
|
94
|
+
reset: number;
|
|
95
|
+
}
|
|
96
|
+
export interface WebhookEvent {
|
|
97
|
+
eventId: string;
|
|
98
|
+
deliveryId: string;
|
|
99
|
+
timestamp: number;
|
|
100
|
+
type: string;
|
|
101
|
+
data: Record<string, unknown>;
|
|
102
|
+
}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgV2ViaG9va1BsYXRmb3JtQ29uZmlnIHtcbiAgYXBpS2V5OiBzdHJpbmc7XG4gIGJhc2VVcmw/OiBzdHJpbmc7XG4gIHRpbWVvdXQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnQge1xuICB0eXBlOiBzdHJpbmc7XG4gIGRhdGE6IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50UmVzcG9uc2Uge1xuICBldmVudElkOiBzdHJpbmc7XG4gIHR5cGU6IHN0cmluZztcbiAgY3JlYXRlZEF0OiBzdHJpbmc7XG4gIGRlbGl2ZXJpZXNDcmVhdGVkOiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW5kcG9pbnQge1xuICBpZDogc3RyaW5nO1xuICB1cmw6IHN0cmluZztcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gIHNlY3JldDogc3RyaW5nO1xuICBlbmFibGVkOiBib29sZWFuO1xuICByYXRlTGltaXRQZXJTZWNvbmQ/OiBudW1iZXI7XG4gIGNyZWF0ZWRBdDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVuZHBvaW50Q3JlYXRlUGFyYW1zIHtcbiAgdXJsOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICBlbmFibGVkPzogYm9vbGVhbjtcbiAgcmF0ZUxpbWl0UGVyU2Vjb25kPzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVuZHBvaW50VXBkYXRlUGFyYW1zIHtcbiAgdXJsPzogc3RyaW5nO1xuICBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgZW5hYmxlZD86IGJvb2xlYW47XG4gIHJhdGVMaW1pdFBlclNlY29uZD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdWJzY3JpcHRpb24ge1xuICBpZDogc3RyaW5nO1xuICBlbmRwb2ludElkOiBzdHJpbmc7XG4gIGV2ZW50VHlwZXM6IHN0cmluZ1tdO1xuICBlbmFibGVkOiBib29sZWFuO1xuICBjcmVhdGVkQXQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdWJzY3JpcHRpb25DcmVhdGVQYXJhbXMge1xuICBlbmRwb2ludElkOiBzdHJpbmc7XG4gIGV2ZW50VHlwZXM6IHN0cmluZ1tdO1xuICBlbmFibGVkPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZWxpdmVyeSB7XG4gIGlkOiBzdHJpbmc7XG4gIGV2ZW50SWQ6IHN0cmluZztcbiAgZW5kcG9pbnRJZDogc3RyaW5nO1xuICBzdGF0dXM6IERlbGl2ZXJ5U3RhdHVzO1xuICBhdHRlbXB0Q291bnQ6IG51bWJlcjtcbiAgbWF4QXR0ZW1wdHM6IG51bWJlcjtcbiAgbmV4dEF0dGVtcHRBdD86IHN0cmluZztcbiAgY3JlYXRlZEF0OiBzdHJpbmc7XG4gIHN1Y2NlZWRlZEF0Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBEZWxpdmVyeVN0YXR1cyA9ICdQRU5ESU5HJyB8ICdTVUNDRVNTJyB8ICdGQUlMRUQnIHwgJ0RFQURfTEVUVEVSJztcblxuZXhwb3J0IGludGVyZmFjZSBEZWxpdmVyeUF0dGVtcHQge1xuICBpZDogc3RyaW5nO1xuICBhdHRlbXB0TnVtYmVyOiBudW1iZXI7XG4gIGh0dHBTdGF0dXM/OiBudW1iZXI7XG4gIHJlc3BvbnNlQm9keT86IHN0cmluZztcbiAgZXJyb3JNZXNzYWdlPzogc3RyaW5nO1xuICBsYXRlbmN5TXM6IG51bWJlcjtcbiAgYXR0ZW1wdGVkQXQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0ZWRSZXNwb25zZTxUPiB7XG4gIGNvbnRlbnQ6IFRbXTtcbiAgdG90YWxFbGVtZW50czogbnVtYmVyO1xuICB0b3RhbFBhZ2VzOiBudW1iZXI7XG4gIHNpemU6IG51bWJlcjtcbiAgbnVtYmVyOiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVsaXZlcnlMaXN0UGFyYW1zIHtcbiAgc3RhdHVzPzogRGVsaXZlcnlTdGF0dXM7XG4gIGVuZHBvaW50SWQ/OiBzdHJpbmc7XG4gIGZyb21EYXRlPzogc3RyaW5nO1xuICB0b0RhdGU/OiBzdHJpbmc7XG4gIHBhZ2U/OiBudW1iZXI7XG4gIHNpemU/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW5kcG9pbnRUZXN0UmVzdWx0IHtcbiAgc3VjY2VzczogYm9vbGVhbjtcbiAgaHR0cFN0YXR1cz86IG51bWJlcjtcbiAgbGF0ZW5jeU1zOiBudW1iZXI7XG4gIGVycm9yTWVzc2FnZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSYXRlTGltaXRJbmZvIHtcbiAgbGltaXQ6IG51bWJlcjtcbiAgcmVtYWluaW5nOiBudW1iZXI7XG4gIHJlc2V0OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2ViaG9va0V2ZW50IHtcbiAgZXZlbnRJZDogc3RyaW5nO1xuICBkZWxpdmVyeUlkOiBzdHJpbmc7XG4gIHRpbWVzdGFtcDogbnVtYmVyO1xuICB0eXBlOiBzdHJpbmc7XG4gIGRhdGE6IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xufVxuIl19
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { WebhookEvent } from './types';
|
|
2
|
+
export interface WebhookHeaders {
|
|
3
|
+
'x-signature'?: string;
|
|
4
|
+
'x-timestamp'?: string;
|
|
5
|
+
'x-event-id'?: string;
|
|
6
|
+
'x-delivery-id'?: string;
|
|
7
|
+
[key: string]: string | undefined;
|
|
8
|
+
}
|
|
9
|
+
export interface VerifyOptions {
|
|
10
|
+
tolerance?: number;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Verifies the webhook signature using HMAC-SHA256
|
|
14
|
+
* @param payload - Raw request body as string
|
|
15
|
+
* @param signature - X-Signature header value (format: t=timestamp,v1=signature)
|
|
16
|
+
* @param secret - Endpoint webhook secret
|
|
17
|
+
* @param options - Verification options
|
|
18
|
+
* @returns true if signature is valid
|
|
19
|
+
* @throws WebhookPlatformError if signature is invalid
|
|
20
|
+
*/
|
|
21
|
+
export declare function verifySignature(payload: string, signature: string, secret: string, options?: VerifyOptions): boolean;
|
|
22
|
+
/**
|
|
23
|
+
* Constructs a webhook event from the request
|
|
24
|
+
* @param payload - Raw request body as string
|
|
25
|
+
* @param headers - Request headers
|
|
26
|
+
* @param secret - Endpoint webhook secret
|
|
27
|
+
* @param options - Verification options
|
|
28
|
+
* @returns Parsed and verified webhook event
|
|
29
|
+
*/
|
|
30
|
+
export declare function constructEvent(payload: string, headers: WebhookHeaders, secret: string, options?: VerifyOptions): WebhookEvent;
|
|
31
|
+
/**
|
|
32
|
+
* Generates a signature for testing purposes
|
|
33
|
+
* @param payload - Request body as string
|
|
34
|
+
* @param secret - Webhook secret
|
|
35
|
+
* @param timestamp - Optional timestamp (defaults to now)
|
|
36
|
+
* @returns Signature string in format t=timestamp,v1=signature
|
|
37
|
+
*/
|
|
38
|
+
export declare function generateSignature(payload: string, secret: string, timestamp?: number): string;
|