@auxiora/webhooks 1.0.0 → 1.3.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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@auxiora/webhooks",
3
- "version": "1.0.0",
3
+ "version": "1.3.0",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -14,9 +14,15 @@
14
14
  "node": ">=22.0.0"
15
15
  },
16
16
  "dependencies": {
17
- "@auxiora/audit": "1.0.0",
18
- "@auxiora/logger": "1.0.0"
17
+ "@auxiora/logger": "1.3.0",
18
+ "@auxiora/audit": "1.3.0"
19
19
  },
20
+ "publishConfig": {
21
+ "access": "public"
22
+ },
23
+ "files": [
24
+ "dist/"
25
+ ],
20
26
  "scripts": {
21
27
  "build": "tsc",
22
28
  "clean": "rm -rf dist",
package/src/index.ts DELETED
@@ -1,5 +0,0 @@
1
- export type { WebhookDefinition, WebhookConfig } from './types.js';
2
- export { DEFAULT_WEBHOOK_CONFIG } from './types.js';
3
- export { WebhookStore } from './store.js';
4
- export { verifyHmacSha256, verifyTwilioSignature } from './verify.js';
5
- export { WebhookManager, type WebhookManagerOptions, type CreateWebhookOptions, type WebhookResult } from './webhook-manager.js';
package/src/store.ts DELETED
@@ -1,78 +0,0 @@
1
- import * as fs from 'node:fs/promises';
2
- import * as path from 'node:path';
3
- import { getLogger } from '@auxiora/logger';
4
- import type { WebhookDefinition } from './types.js';
5
-
6
- const logger = getLogger('webhooks:store');
7
-
8
- export class WebhookStore {
9
- private filePath: string;
10
-
11
- constructor(filePath: string) {
12
- this.filePath = filePath;
13
- }
14
-
15
- async save(webhook: WebhookDefinition): Promise<void> {
16
- const webhooks = await this.readFile();
17
- const existing = webhooks.find((w) => w.name === webhook.name && w.id !== webhook.id);
18
- if (existing) {
19
- throw new Error(`Webhook with name '${webhook.name}' already exists`);
20
- }
21
-
22
- const index = webhooks.findIndex((w) => w.id === webhook.id);
23
- if (index >= 0) {
24
- webhooks[index] = webhook;
25
- } else {
26
- webhooks.push(webhook);
27
- }
28
-
29
- await this.writeFile(webhooks);
30
- logger.debug('Saved webhook', { id: webhook.id, name: webhook.name });
31
- }
32
-
33
- async get(id: string): Promise<WebhookDefinition | undefined> {
34
- const webhooks = await this.readFile();
35
- return webhooks.find((w) => w.id === id);
36
- }
37
-
38
- async getByName(name: string): Promise<WebhookDefinition | undefined> {
39
- const webhooks = await this.readFile();
40
- return webhooks.find((w) => w.name === name);
41
- }
42
-
43
- async getAll(): Promise<WebhookDefinition[]> {
44
- return this.readFile();
45
- }
46
-
47
- async listEnabled(): Promise<WebhookDefinition[]> {
48
- const webhooks = await this.readFile();
49
- return webhooks.filter((w) => w.enabled);
50
- }
51
-
52
- async remove(id: string): Promise<boolean> {
53
- const webhooks = await this.readFile();
54
- const filtered = webhooks.filter((w) => w.id !== id);
55
- if (filtered.length === webhooks.length) return false;
56
- await this.writeFile(filtered);
57
- logger.debug('Removed webhook', { id });
58
- return true;
59
- }
60
-
61
- private async readFile(): Promise<WebhookDefinition[]> {
62
- try {
63
- const content = await fs.readFile(this.filePath, 'utf-8');
64
- return JSON.parse(content) as WebhookDefinition[];
65
- } catch (error) {
66
- if ((error as NodeJS.ErrnoException).code === 'ENOENT') {
67
- return [];
68
- }
69
- throw error;
70
- }
71
- }
72
-
73
- private async writeFile(webhooks: WebhookDefinition[]): Promise<void> {
74
- const dir = path.dirname(this.filePath);
75
- await fs.mkdir(dir, { recursive: true });
76
- await fs.writeFile(this.filePath, JSON.stringify(webhooks, null, 2), 'utf-8');
77
- }
78
- }
package/src/types.ts DELETED
@@ -1,25 +0,0 @@
1
- export interface WebhookDefinition {
2
- id: string;
3
- name: string;
4
- type: 'channel' | 'generic';
5
- channelType?: string;
6
- secret: string;
7
- behaviorId?: string;
8
- transform?: string;
9
- enabled: boolean;
10
- createdAt: string;
11
- }
12
-
13
- export interface WebhookConfig {
14
- enabled: boolean;
15
- basePath: string;
16
- signatureHeader: string;
17
- maxPayloadSize: number;
18
- }
19
-
20
- export const DEFAULT_WEBHOOK_CONFIG: WebhookConfig = {
21
- enabled: false,
22
- basePath: '/api/v1/webhooks',
23
- signatureHeader: 'x-webhook-signature',
24
- maxPayloadSize: 65536,
25
- };
package/src/verify.ts DELETED
@@ -1,47 +0,0 @@
1
- import * as crypto from 'node:crypto';
2
-
3
- /**
4
- * Verify HMAC-SHA256 signature using timing-safe comparison.
5
- * Handles optional "sha256=" prefix (GitHub style).
6
- */
7
- export function verifyHmacSha256(body: Buffer, secret: string, signature: string): boolean {
8
- if (!signature) return false;
9
-
10
- const sig = signature.startsWith('sha256=') ? signature.slice(7) : signature;
11
-
12
- let sigBuffer: Buffer;
13
- try {
14
- sigBuffer = Buffer.from(sig, 'hex');
15
- } catch {
16
- return false;
17
- }
18
-
19
- const expected = crypto.createHmac('sha256', secret).update(body).digest();
20
-
21
- if (sigBuffer.length !== expected.length) return false;
22
-
23
- return crypto.timingSafeEqual(sigBuffer, expected);
24
- }
25
-
26
- /**
27
- * Verify Twilio webhook signature (HMAC-SHA1, base64).
28
- * Twilio signs: URL + sorted(key+value pairs), HMAC-SHA1, base64.
29
- */
30
- export function verifyTwilioSignature(
31
- url: string,
32
- params: Record<string, string>,
33
- authToken: string,
34
- signature: string
35
- ): boolean {
36
- if (!signature) return false;
37
-
38
- const data = url + Object.keys(params).sort().reduce((acc, key) => acc + key + params[key], '');
39
- const expected = crypto.createHmac('sha1', authToken).update(data).digest('base64');
40
-
41
- const sigBuffer = Buffer.from(signature);
42
- const expectedBuffer = Buffer.from(expected);
43
-
44
- if (sigBuffer.length !== expectedBuffer.length) return false;
45
-
46
- return crypto.timingSafeEqual(sigBuffer, expectedBuffer);
47
- }
@@ -1,147 +0,0 @@
1
- import * as crypto from 'node:crypto';
2
- import { getLogger } from '@auxiora/logger';
3
- import { audit } from '@auxiora/audit';
4
- import { WebhookStore } from './store.js';
5
- import type { WebhookDefinition, WebhookConfig } from './types.js';
6
- import { DEFAULT_WEBHOOK_CONFIG } from './types.js';
7
- import { verifyHmacSha256 } from './verify.js';
8
-
9
- const logger = getLogger('webhooks:manager');
10
-
11
- export interface WebhookManagerOptions {
12
- storePath: string;
13
- config?: WebhookConfig;
14
- onBehaviorTrigger?: (behaviorId: string, payload: string) => Promise<{ success: boolean; error?: string }>;
15
- }
16
-
17
- export interface CreateWebhookOptions {
18
- name: string;
19
- type: 'channel' | 'generic';
20
- secret: string;
21
- channelType?: string;
22
- behaviorId?: string;
23
- enabled?: boolean;
24
- }
25
-
26
- export interface WebhookResult {
27
- accepted: boolean;
28
- status: number;
29
- error?: string;
30
- }
31
-
32
- export class WebhookManager {
33
- private store: WebhookStore;
34
- private config: WebhookConfig;
35
- private behaviorTrigger?: (behaviorId: string, payload: string) => Promise<{ success: boolean; error?: string }>;
36
-
37
- constructor(options: WebhookManagerOptions) {
38
- this.store = new WebhookStore(options.storePath);
39
- this.config = options.config ?? DEFAULT_WEBHOOK_CONFIG;
40
- this.behaviorTrigger = options.onBehaviorTrigger;
41
- }
42
-
43
- async create(options: CreateWebhookOptions): Promise<WebhookDefinition> {
44
- const webhook: WebhookDefinition = {
45
- id: crypto.randomUUID(),
46
- name: options.name,
47
- type: options.type,
48
- secret: options.secret,
49
- channelType: options.channelType,
50
- behaviorId: options.behaviorId,
51
- enabled: options.enabled ?? true,
52
- createdAt: new Date().toISOString(),
53
- };
54
-
55
- await this.store.save(webhook);
56
- void audit('webhook.created', { name: webhook.name, type: webhook.type });
57
- logger.info('Webhook created', { id: webhook.id, name: webhook.name });
58
- return webhook;
59
- }
60
-
61
- async list(): Promise<WebhookDefinition[]> {
62
- return this.store.getAll();
63
- }
64
-
65
- async update(
66
- id: string,
67
- updates: Partial<Pick<WebhookDefinition, 'name' | 'enabled' | 'secret' | 'behaviorId'>>,
68
- ): Promise<WebhookDefinition | null> {
69
- const webhook = await this.store.get(id);
70
- if (!webhook) return null;
71
-
72
- const updated: WebhookDefinition = { ...webhook, ...updates };
73
- await this.store.save(updated);
74
- void audit('webhook.updated', { id, name: updated.name });
75
- logger.info('Webhook updated', { id, name: updated.name });
76
- return updated;
77
- }
78
-
79
- async delete(id: string): Promise<boolean> {
80
- const webhook = await this.store.get(id);
81
- const removed = await this.store.remove(id);
82
- if (removed && webhook) {
83
- void audit('webhook.deleted', { name: webhook.name });
84
- logger.info('Webhook deleted', { id, name: webhook.name });
85
- }
86
- return removed;
87
- }
88
-
89
- async handleGenericWebhook(
90
- name: string,
91
- body: Buffer,
92
- headers: Record<string, string>
93
- ): Promise<WebhookResult> {
94
- // Check payload size
95
- if (body.length > this.config.maxPayloadSize) {
96
- logger.warn('Webhook payload too large', { name, size: body.length });
97
- return { accepted: false, status: 413, error: 'Payload too large' };
98
- }
99
-
100
- // Find webhook
101
- const webhook = await this.store.getByName(name);
102
- if (!webhook || !webhook.enabled) {
103
- return { accepted: false, status: 404, error: 'Not found' };
104
- }
105
-
106
- // Verify signature
107
- const signature = headers[this.config.signatureHeader] ?? '';
108
- if (!verifyHmacSha256(body, webhook.secret, signature)) {
109
- void audit('webhook.signature_failed', { name });
110
- logger.warn('Webhook signature verification failed', { name });
111
- return { accepted: false, status: 401, error: 'Unauthorized' };
112
- }
113
-
114
- void audit('webhook.received', {
115
- name,
116
- type: webhook.type,
117
- payloadSize: body.length,
118
- });
119
-
120
- // Trigger behavior asynchronously
121
- if (webhook.behaviorId && this.behaviorTrigger) {
122
- const payload = body.toString('utf-8');
123
- this.triggerBehavior(webhook.name, webhook.behaviorId, payload);
124
- }
125
-
126
- return { accepted: true, status: 202 };
127
- }
128
-
129
- private triggerBehavior(webhookName: string, behaviorId: string, payload: string): void {
130
- if (!this.behaviorTrigger) return;
131
-
132
- this.behaviorTrigger(behaviorId, payload)
133
- .then(() => {
134
- void audit('webhook.triggered', { name: webhookName, behaviorId });
135
- logger.info('Webhook triggered behavior', { webhookName, behaviorId });
136
- })
137
- .catch((error) => {
138
- const message = error instanceof Error ? error.message : String(error);
139
- void audit('webhook.error', { name: webhookName, error: message });
140
- logger.error('Webhook behavior trigger failed', { error: new Error(message), webhookName, behaviorId });
141
- });
142
- }
143
-
144
- setBehaviorTrigger(trigger: (behaviorId: string, payload: string) => Promise<{ success: boolean; error?: string }>): void {
145
- this.behaviorTrigger = trigger;
146
- }
147
- }
@@ -1,83 +0,0 @@
1
- import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
2
- import * as fs from 'node:fs/promises';
3
- import * as path from 'node:path';
4
- import * as os from 'node:os';
5
- import * as crypto from 'node:crypto';
6
- import { WebhookManager } from '../src/webhook-manager.js';
7
- import { DEFAULT_WEBHOOK_CONFIG } from '../src/types.js';
8
-
9
- describe('Webhook integration', () => {
10
- let manager: WebhookManager;
11
- let tmpDir: string;
12
- let mockBehaviorTrigger: ReturnType<typeof vi.fn>;
13
-
14
- beforeEach(async () => {
15
- tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), 'webhook-int-'));
16
- mockBehaviorTrigger = vi.fn().mockResolvedValue({ success: true });
17
-
18
- manager = new WebhookManager({
19
- storePath: path.join(tmpDir, 'webhooks.json'),
20
- config: { ...DEFAULT_WEBHOOK_CONFIG, enabled: true },
21
- onBehaviorTrigger: mockBehaviorTrigger,
22
- });
23
- });
24
-
25
- afterEach(async () => {
26
- await fs.rm(tmpDir, { recursive: true, force: true });
27
- });
28
-
29
- it('should handle full create → receive → trigger flow', async () => {
30
- // 1. Create webhook
31
- const secret = 'integration-test-secret';
32
- const webhook = await manager.create({
33
- name: 'github-push',
34
- type: 'generic',
35
- secret,
36
- behaviorId: 'summarize-commits',
37
- });
38
- expect(webhook.name).toBe('github-push');
39
-
40
- // 2. Simulate incoming webhook
41
- const payload = JSON.stringify({ ref: 'refs/heads/main', commits: [{ message: 'fix bug' }] });
42
- const body = Buffer.from(payload);
43
- const signature = crypto.createHmac('sha256', secret).update(body).digest('hex');
44
-
45
- const result = await manager.handleGenericWebhook('github-push', body, {
46
- 'x-webhook-signature': signature,
47
- });
48
-
49
- expect(result.accepted).toBe(true);
50
- expect(result.status).toBe(202);
51
-
52
- // 3. Wait for async behavior trigger
53
- await new Promise((resolve) => setTimeout(resolve, 10));
54
- expect(mockBehaviorTrigger).toHaveBeenCalledWith('summarize-commits', payload);
55
- });
56
-
57
- it('should reject webhook after deletion', async () => {
58
- const secret = 'temp-secret';
59
- const webhook = await manager.create({ name: 'temp', type: 'generic', secret });
60
- await manager.delete(webhook.id);
61
-
62
- const body = Buffer.from('{}');
63
- const signature = crypto.createHmac('sha256', secret).update(body).digest('hex');
64
-
65
- const result = await manager.handleGenericWebhook('temp', body, {
66
- 'x-webhook-signature': signature,
67
- });
68
-
69
- expect(result.accepted).toBe(false);
70
- expect(result.status).toBe(404);
71
- });
72
-
73
- it('should handle signature failure with audit trail', async () => {
74
- await manager.create({ name: 'secure', type: 'generic', secret: 'real-secret' });
75
-
76
- const result = await manager.handleGenericWebhook('secure', Buffer.from('{}'), {
77
- 'x-webhook-signature': 'forged-signature',
78
- });
79
-
80
- expect(result.accepted).toBe(false);
81
- expect(result.status).toBe(401);
82
- });
83
- });
@@ -1,69 +0,0 @@
1
- import { describe, it, expect, beforeEach, afterEach } from 'vitest';
2
- import * as fs from 'node:fs/promises';
3
- import * as path from 'node:path';
4
- import * as os from 'node:os';
5
- import { WebhookStore } from '../src/store.js';
6
- import type { WebhookDefinition } from '../src/types.js';
7
-
8
- function makeWebhook(overrides: Partial<WebhookDefinition> = {}): WebhookDefinition {
9
- return {
10
- id: 'wh-1',
11
- name: 'test-webhook',
12
- type: 'generic',
13
- secret: 'test-secret',
14
- enabled: true,
15
- createdAt: new Date().toISOString(),
16
- ...overrides,
17
- };
18
- }
19
-
20
- describe('WebhookStore', () => {
21
- let store: WebhookStore;
22
- let tmpDir: string;
23
- let filePath: string;
24
-
25
- beforeEach(async () => {
26
- tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), 'webhook-store-'));
27
- filePath = path.join(tmpDir, 'webhooks.json');
28
- store = new WebhookStore(filePath);
29
- });
30
-
31
- afterEach(async () => {
32
- await fs.rm(tmpDir, { recursive: true, force: true });
33
- });
34
-
35
- it('should save and retrieve a webhook', async () => {
36
- const webhook = makeWebhook();
37
- await store.save(webhook);
38
- const result = await store.get('wh-1');
39
- expect(result).toEqual(webhook);
40
- });
41
-
42
- it('should retrieve by name', async () => {
43
- await store.save(makeWebhook());
44
- const result = await store.getByName('test-webhook');
45
- expect(result?.id).toBe('wh-1');
46
- });
47
-
48
- it('should reject duplicate names', async () => {
49
- await store.save(makeWebhook());
50
- await expect(
51
- store.save(makeWebhook({ id: 'wh-2', name: 'test-webhook' }))
52
- ).rejects.toThrow('already exists');
53
- });
54
-
55
- it('should remove a webhook', async () => {
56
- await store.save(makeWebhook());
57
- const removed = await store.remove('wh-1');
58
- expect(removed).toBe(true);
59
- expect(await store.get('wh-1')).toBeUndefined();
60
- });
61
-
62
- it('should list only enabled webhooks', async () => {
63
- await store.save(makeWebhook({ id: 'wh-1', name: 'enabled', enabled: true }));
64
- await store.save(makeWebhook({ id: 'wh-2', name: 'disabled', enabled: false }));
65
- const enabled = await store.listEnabled();
66
- expect(enabled).toHaveLength(1);
67
- expect(enabled[0].name).toBe('enabled');
68
- });
69
- });
@@ -1,60 +0,0 @@
1
- import { describe, it, expect } from 'vitest';
2
- import * as crypto from 'node:crypto';
3
- import { verifyHmacSha256, verifyTwilioSignature } from '../src/verify.js';
4
-
5
- describe('verifyHmacSha256', () => {
6
- const secret = 'my-webhook-secret';
7
-
8
- it('should accept valid HMAC-SHA256 signature', () => {
9
- const body = Buffer.from('{"event":"push"}');
10
- const signature = crypto.createHmac('sha256', secret).update(body).digest('hex');
11
- expect(verifyHmacSha256(body, secret, signature)).toBe(true);
12
- });
13
-
14
- it('should reject invalid signature', () => {
15
- const body = Buffer.from('{"event":"push"}');
16
- expect(verifyHmacSha256(body, secret, 'invalid-signature')).toBe(false);
17
- });
18
-
19
- it('should reject tampered body', () => {
20
- const body = Buffer.from('{"event":"push"}');
21
- const signature = crypto.createHmac('sha256', secret).update(body).digest('hex');
22
- const tampered = Buffer.from('{"event":"hack"}');
23
- expect(verifyHmacSha256(tampered, secret, signature)).toBe(false);
24
- });
25
-
26
- it('should handle sha256= prefix in signature', () => {
27
- const body = Buffer.from('test');
28
- const hash = crypto.createHmac('sha256', secret).update(body).digest('hex');
29
- expect(verifyHmacSha256(body, secret, `sha256=${hash}`)).toBe(true);
30
- });
31
-
32
- it('should reject empty signature', () => {
33
- const body = Buffer.from('test');
34
- expect(verifyHmacSha256(body, secret, '')).toBe(false);
35
- });
36
- });
37
-
38
- describe('verifyTwilioSignature', () => {
39
- const authToken = 'twilio-auth-token';
40
-
41
- it('should accept valid Twilio signature', () => {
42
- const url = 'https://example.com/api/v1/webhooks/twilio';
43
- const params: Record<string, string> = {
44
- Body: 'Hello',
45
- From: '+1234567890',
46
- To: '+0987654321',
47
- };
48
-
49
- // Build expected signature the Twilio way:
50
- // Sort params by key, concatenate key+value, append to URL, HMAC-SHA1, base64
51
- const data = url + Object.keys(params).sort().reduce((acc, key) => acc + key + params[key], '');
52
- const expected = crypto.createHmac('sha1', authToken).update(data).digest('base64');
53
-
54
- expect(verifyTwilioSignature(url, params, authToken, expected)).toBe(true);
55
- });
56
-
57
- it('should reject invalid Twilio signature', () => {
58
- expect(verifyTwilioSignature('https://example.com', {}, authToken, 'bad-sig')).toBe(false);
59
- });
60
- });
@@ -1,159 +0,0 @@
1
- import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
2
- import * as fs from 'node:fs/promises';
3
- import * as path from 'node:path';
4
- import * as os from 'node:os';
5
- import * as crypto from 'node:crypto';
6
- import { WebhookManager } from '../src/webhook-manager.js';
7
- import type { WebhookDefinition } from '../src/types.js';
8
- import { DEFAULT_WEBHOOK_CONFIG } from '../src/types.js';
9
-
10
- function makeWebhook(overrides: Partial<WebhookDefinition> = {}): WebhookDefinition {
11
- return {
12
- id: 'wh-1',
13
- name: 'test-hook',
14
- type: 'generic',
15
- secret: 'test-secret-key',
16
- behaviorId: 'beh-1',
17
- enabled: true,
18
- createdAt: new Date().toISOString(),
19
- ...overrides,
20
- };
21
- }
22
-
23
- describe('WebhookManager', () => {
24
- let manager: WebhookManager;
25
- let tmpDir: string;
26
- let filePath: string;
27
- let mockBehaviorTrigger: ReturnType<typeof vi.fn>;
28
-
29
- beforeEach(async () => {
30
- tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), 'webhook-mgr-'));
31
- filePath = path.join(tmpDir, 'webhooks.json');
32
- mockBehaviorTrigger = vi.fn().mockResolvedValue({ success: true });
33
-
34
- manager = new WebhookManager({
35
- storePath: filePath,
36
- config: { ...DEFAULT_WEBHOOK_CONFIG, enabled: true },
37
- onBehaviorTrigger: mockBehaviorTrigger,
38
- });
39
- });
40
-
41
- afterEach(async () => {
42
- await fs.rm(tmpDir, { recursive: true, force: true });
43
- });
44
-
45
- describe('webhook CRUD', () => {
46
- it('should create a webhook', async () => {
47
- const webhook = await manager.create({
48
- name: 'github-push',
49
- type: 'generic',
50
- secret: 'my-secret',
51
- behaviorId: 'beh-1',
52
- });
53
- expect(webhook.id).toBeDefined();
54
- expect(webhook.name).toBe('github-push');
55
- expect(webhook.enabled).toBe(true);
56
- });
57
-
58
- it('should list all webhooks', async () => {
59
- await manager.create({ name: 'hook-1', type: 'generic', secret: 's1' });
60
- await manager.create({ name: 'hook-2', type: 'generic', secret: 's2' });
61
- const all = await manager.list();
62
- expect(all).toHaveLength(2);
63
- });
64
-
65
- it('should update a webhook', async () => {
66
- const wh = await manager.create({ name: 'original', type: 'generic', secret: 's' });
67
- const updated = await manager.update(wh.id, { name: 'renamed', enabled: false });
68
- expect(updated).not.toBeNull();
69
- expect(updated!.name).toBe('renamed');
70
- expect(updated!.enabled).toBe(false);
71
-
72
- const all = await manager.list();
73
- expect(all[0].name).toBe('renamed');
74
- });
75
-
76
- it('should return null when updating non-existent webhook', async () => {
77
- const result = await manager.update('nonexistent', { name: 'test' });
78
- expect(result).toBeNull();
79
- });
80
-
81
- it('should delete a webhook', async () => {
82
- const wh = await manager.create({ name: 'to-delete', type: 'generic', secret: 's' });
83
- const deleted = await manager.delete(wh.id);
84
- expect(deleted).toBe(true);
85
- const all = await manager.list();
86
- expect(all).toHaveLength(0);
87
- });
88
- });
89
-
90
- describe('generic webhook handling', () => {
91
- it('should verify signature and trigger behavior', async () => {
92
- const secret = 'my-secret';
93
- await manager.create({ name: 'test', type: 'generic', secret, behaviorId: 'beh-1' });
94
-
95
- const body = Buffer.from('{"event":"push"}');
96
- const signature = crypto.createHmac('sha256', secret).update(body).digest('hex');
97
-
98
- const result = await manager.handleGenericWebhook('test', body, {
99
- 'x-webhook-signature': signature,
100
- });
101
-
102
- expect(result.accepted).toBe(true);
103
- expect(mockBehaviorTrigger).toHaveBeenCalledWith('beh-1', expect.stringContaining('push'));
104
- });
105
-
106
- it('should reject invalid signature', async () => {
107
- await manager.create({ name: 'test', type: 'generic', secret: 'real-secret' });
108
-
109
- const body = Buffer.from('{}');
110
- const result = await manager.handleGenericWebhook('test', body, {
111
- 'x-webhook-signature': 'bad-sig',
112
- });
113
-
114
- expect(result.accepted).toBe(false);
115
- expect(result.status).toBe(401);
116
- });
117
-
118
- it('should reject unknown webhook name', async () => {
119
- const result = await manager.handleGenericWebhook('nonexistent', Buffer.from('{}'), {});
120
- expect(result.accepted).toBe(false);
121
- expect(result.status).toBe(404);
122
- });
123
-
124
- it('should reject disabled webhook', async () => {
125
- const wh = await manager.create({ name: 'disabled', type: 'generic', secret: 's', enabled: false });
126
-
127
- const result = await manager.handleGenericWebhook('disabled', Buffer.from('{}'), {});
128
- expect(result.accepted).toBe(false);
129
- expect(result.status).toBe(404);
130
- });
131
-
132
- it('should handle missing behavior gracefully', async () => {
133
- mockBehaviorTrigger.mockRejectedValueOnce(new Error('Behavior not found'));
134
- const secret = 'my-secret';
135
- await manager.create({ name: 'orphan', type: 'generic', secret, behaviorId: 'missing' });
136
-
137
- const body = Buffer.from('{}');
138
- const signature = crypto.createHmac('sha256', secret).update(body).digest('hex');
139
-
140
- const result = await manager.handleGenericWebhook('orphan', body, {
141
- 'x-webhook-signature': signature,
142
- });
143
-
144
- // Still accepted (202) — don't leak internal state
145
- expect(result.accepted).toBe(true);
146
- });
147
- });
148
-
149
- describe('payload size', () => {
150
- it('should reject oversized payloads', async () => {
151
- await manager.create({ name: 'test', type: 'generic', secret: 's' });
152
- const oversized = Buffer.alloc(DEFAULT_WEBHOOK_CONFIG.maxPayloadSize + 1);
153
-
154
- const result = await manager.handleGenericWebhook('test', oversized, {});
155
- expect(result.accepted).toBe(false);
156
- expect(result.status).toBe(413);
157
- });
158
- });
159
- });
package/tsconfig.json DELETED
@@ -1,12 +0,0 @@
1
- {
2
- "extends": "../../tsconfig.base.json",
3
- "compilerOptions": {
4
- "outDir": "./dist",
5
- "rootDir": "./src"
6
- },
7
- "include": ["src/**/*"],
8
- "references": [
9
- { "path": "../logger" },
10
- { "path": "../audit" }
11
- ]
12
- }
@@ -1 +0,0 @@
1
- {"fileNames":["../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es5.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2023.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.core.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.collection.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.generator.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.iterable.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.promise.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.proxy.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.reflect.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.symbol.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.symbol.wellknown.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.array.include.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.arraybuffer.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.date.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.object.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.sharedmemory.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.typedarrays.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.asyncgenerator.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.asynciterable.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.promise.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.regexp.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.array.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.object.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.symbol.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.bigint.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.date.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.promise.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.sharedmemory.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.symbol.wellknown.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.number.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.promise.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.weakref.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.array.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.error.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.object.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.string.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.regexp.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2023.array.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2023.collection.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2023.intl.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.disposable.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.float16.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.decorators.d.ts","../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.decorators.legacy.d.ts","./src/types.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/compatibility/iterators.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/globals.typedarray.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/buffer.buffer.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/globals.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/abortcontroller.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/blob.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/console.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/crypto.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/domexception.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/encoding.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/events.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/utility.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/header.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/readable.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/fetch.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/formdata.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/connector.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/client-stats.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/client.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/errors.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/dispatcher.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/global-dispatcher.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/global-origin.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/pool-stats.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/pool.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/handlers.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/balanced-pool.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/h2c-client.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/agent.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/mock-interceptor.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/mock-call-history.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/mock-agent.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/mock-client.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/mock-pool.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/snapshot-agent.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/mock-errors.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/proxy-agent.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/env-http-proxy-agent.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/retry-handler.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/retry-agent.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/api.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/cache-interceptor.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/interceptors.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/util.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/cookies.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/patch.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/websocket.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/eventsource.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/diagnostics-channel.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/content-type.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/cache.d.ts","../../node_modules/.pnpm/undici-types@7.16.0/node_modules/undici-types/index.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/fetch.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/importmeta.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/messaging.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/navigator.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/performance.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/storage.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/streams.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/timers.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/web-globals/url.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/assert.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/assert/strict.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/async_hooks.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/buffer.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/child_process.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/cluster.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/console.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/constants.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/crypto.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/dgram.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/diagnostics_channel.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/dns.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/dns/promises.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/domain.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/events.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/fs.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/fs/promises.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/http.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/http2.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/https.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/inspector.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/inspector.generated.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/inspector/promises.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/module.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/net.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/os.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/path.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/path/posix.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/path/win32.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/perf_hooks.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/process.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/punycode.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/querystring.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/quic.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/readline.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/readline/promises.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/repl.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/sea.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/sqlite.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/stream.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/stream/consumers.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/stream/promises.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/stream/web.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/string_decoder.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/test.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/test/reporters.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/timers.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/timers/promises.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/tls.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/trace_events.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/tty.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/url.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/util.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/util/types.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/v8.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/vm.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/wasi.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/worker_threads.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/zlib.d.ts","../../node_modules/.pnpm/@types+node@25.1.0/node_modules/@types/node/index.d.ts","../../node_modules/.pnpm/pino-std-serializers@7.1.0/node_modules/pino-std-serializers/index.d.ts","../../node_modules/.pnpm/sonic-boom@4.2.0/node_modules/sonic-boom/types/index.d.ts","../../node_modules/.pnpm/pino@9.14.0/node_modules/pino/pino.d.ts","../logger/dist/index.d.ts","./src/store.ts","./src/verify.ts","../audit/dist/index.d.ts","./src/webhook-manager.ts","./src/index.ts"],"fileIdsList":[[67,126,127,129,137,141,144,146,147,148,160],[67,128,129,137,141,144,146,147,148,160],[129,137,141,144,146,147,148,160],[67,129,137,141,144,146,147,148,160,168],[67,129,130,135,137,140,141,144,146,147,148,150,160,165,177],[67,129,130,131,137,140,141,144,146,147,148,160],[67,129,137,141,144,146,147,148,160],[67,129,132,137,141,144,146,147,148,160,178],[67,129,133,134,137,141,144,146,147,148,151,160],[67,129,134,137,141,144,146,147,148,160,165,174],[67,129,135,137,140,141,144,146,147,148,150,160],[67,128,129,136,137,141,144,146,147,148,160],[67,129,137,138,141,144,146,147,148,160],[67,129,137,139,140,141,144,146,147,148,160],[67,128,129,137,140,141,144,146,147,148,160],[67,129,137,140,141,142,144,146,147,148,160,165,177],[67,129,137,140,141,142,144,146,147,148,160,165,168],[67,116,129,137,140,141,143,144,146,147,148,150,160,165,177],[67,129,137,140,141,143,144,146,147,148,150,160,165,174,177],[67,129,137,141,143,144,145,146,147,148,160,165,174,177],[65,66,67,68,69,70,71,72,73,74,75,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184],[67,129,137,140,141,144,146,147,148,160],[67,129,137,141,144,146,148,160],[67,129,137,141,144,146,147,148,149,160,177],[67,129,137,140,141,144,146,147,148,150,160,165],[67,129,137,141,144,146,147,148,151,160],[67,129,137,141,144,146,147,148,152,160],[67,129,137,140,141,144,146,147,148,155,160],[67,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184],[67,129,137,141,144,146,147,148,157,160],[67,129,137,141,144,146,147,148,158,160],[67,129,134,137,141,144,146,147,148,150,160,168],[67,129,137,140,141,144,146,147,148,160,161],[67,129,137,141,144,146,147,148,160,162,178,181],[67,129,137,140,141,144,146,147,148,160,165,167,168],[67,129,137,141,144,146,147,148,160,166,168],[67,129,137,141,144,146,147,148,160,168,178],[67,129,137,141,144,146,147,148,160,169],[67,126,129,137,141,144,146,147,148,160,165,171],[67,129,137,141,144,146,147,148,160,165,170],[67,129,137,140,141,144,146,147,148,160,172,173],[67,129,137,141,144,146,147,148,160,172,173],[67,129,134,137,141,144,146,147,148,150,160,165,174],[67,129,137,141,144,146,147,148,160,175],[67,129,137,141,144,146,147,148,150,160,176],[67,129,137,141,143,144,146,147,148,158,160,177],[67,129,137,141,144,146,147,148,160,178,179],[67,129,134,137,141,144,146,147,148,160,179],[67,129,137,141,144,146,147,148,160,165,180],[67,129,137,141,144,146,147,148,149,160,181],[67,129,137,141,144,146,147,148,160,182],[67,129,132,137,141,144,146,147,148,160],[67,129,134,137,141,144,146,147,148,160],[67,129,137,141,144,146,147,148,160,178],[67,116,129,137,141,144,146,147,148,160],[67,129,137,141,144,146,147,148,160,177],[67,129,137,141,144,146,147,148,160,183],[67,129,137,141,144,146,147,148,155,160],[67,129,137,141,144,146,147,148,160,173],[67,116,129,137,140,141,142,144,146,147,148,155,160,165,168,177,180,181,183],[67,129,137,141,144,146,147,148,160,165,184],[67,129,137,141,143,144,146,147,148,160,185],[67,129,137,140,141,144,146,147,148,160,183,186,187],[67,129,137,140,141,144,146,147,148,160,185],[67,82,85,88,89,129,137,141,144,146,147,148,160,177],[67,85,129,137,141,144,146,147,148,160,165,177],[67,85,89,129,137,141,144,146,147,148,160,177],[67,129,137,141,144,146,147,148,160,165],[67,79,129,137,141,144,146,147,148,160],[67,83,129,137,141,144,146,147,148,160],[67,81,82,85,129,137,141,144,146,147,148,160,177],[67,129,137,141,144,146,147,148,150,160,174],[67,129,137,141,144,146,147,148,160,185],[67,79,129,137,141,144,146,147,148,160,185],[67,81,85,129,137,141,144,146,147,148,150,160,177],[67,76,77,78,80,84,129,137,140,141,144,146,147,148,160,165,177],[67,85,93,101,129,137,141,144,146,147,148,160],[67,77,83,129,137,141,144,146,147,148,160],[67,85,110,111,129,137,141,144,146,147,148,160],[67,77,80,85,129,137,141,144,146,147,148,160,168,177,185],[67,85,129,137,141,144,146,147,148,160],[67,81,85,129,137,141,144,146,147,148,160,177],[67,76,129,137,141,144,146,147,148,160],[67,79,80,81,83,84,85,86,87,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,111,112,113,114,115,129,137,141,144,146,147,148,160],[67,85,103,106,129,137,141,144,146,147,148,160],[67,85,93,94,95,129,137,141,144,146,147,148,160],[67,83,85,94,96,129,137,141,144,146,147,148,160],[67,84,129,137,141,144,146,147,148,160],[67,77,79,85,129,137,141,144,146,147,148,160],[67,85,89,94,96,129,137,141,144,146,147,148,160],[67,89,129,137,141,144,146,147,148,160],[67,83,85,88,129,137,141,144,146,147,148,160,177],[67,77,81,85,93,129,137,141,144,146,147,148,160],[67,85,103,129,137,141,144,146,147,148,160],[67,96,129,137,141,144,146,147,148,160],[67,79,85,110,129,137,141,144,146,147,148,160,168,183,185],[67,129,137,141,144,146,147,148,160,188],[64,67,129,137,141,144,146,147,148,160,190,191,193],[64,67,129,137,141,142,144,146,147,148,152,160,189],[64,67,129,134,137,141,144,146,147,148,160,189,190,191,192]],"fileInfos":[{"version":"c430d44666289dae81f30fa7b2edebf186ecc91a2d4c71266ea6ae76388792e1","affectsGlobalScope":true,"impliedFormat":1},{"version":"45b7ab580deca34ae9729e97c13cfd999df04416a79116c3bfb483804f85ded4","impliedFormat":1},{"version":"3facaf05f0c5fc569c5649dd359892c98a85557e3e0c847964caeb67076f4d75","impliedFormat":1},{"version":"e44bb8bbac7f10ecc786703fe0a6a4b952189f908707980ba8f3c8975a760962","impliedFormat":1},{"version":"5e1c4c362065a6b95ff952c0eab010f04dcd2c3494e813b493ecfd4fcb9fc0d8","impliedFormat":1},{"version":"68d73b4a11549f9c0b7d352d10e91e5dca8faa3322bfb77b661839c42b1ddec7","impliedFormat":1},{"version":"5efce4fc3c29ea84e8928f97adec086e3dc876365e0982cc8479a07954a3efd4","impliedFormat":1},{"version":"feecb1be483ed332fad555aff858affd90a48ab19ba7272ee084704eb7167569","impliedFormat":1},{"version":"ee7bad0c15b58988daa84371e0b89d313b762ab83cb5b31b8a2d1162e8eb41c2","impliedFormat":1},{"version":"27bdc30a0e32783366a5abeda841bc22757c1797de8681bbe81fbc735eeb1c10","impliedFormat":1},{"version":"c57796738e7f83dbc4b8e65132f11a377649c00dd3eee333f672b8f0a6bea671","affectsGlobalScope":true,"impliedFormat":1},{"version":"dc2df20b1bcdc8c2d34af4926e2c3ab15ffe1160a63e58b7e09833f616efff44","affectsGlobalScope":true,"impliedFormat":1},{"version":"515d0b7b9bea2e31ea4ec968e9edd2c39d3eebf4a2d5cbd04e88639819ae3b71","affectsGlobalScope":true,"impliedFormat":1},{"version":"0559b1f683ac7505ae451f9a96ce4c3c92bdc71411651ca6ddb0e88baaaad6a3","affectsGlobalScope":true,"impliedFormat":1},{"version":"0dc1e7ceda9b8b9b455c3a2d67b0412feab00bd2f66656cd8850e8831b08b537","affectsGlobalScope":true,"impliedFormat":1},{"version":"ce691fb9e5c64efb9547083e4a34091bcbe5bdb41027e310ebba8f7d96a98671","affectsGlobalScope":true,"impliedFormat":1},{"version":"8d697a2a929a5fcb38b7a65594020fcef05ec1630804a33748829c5ff53640d0","affectsGlobalScope":true,"impliedFormat":1},{"version":"4ff2a353abf8a80ee399af572debb8faab2d33ad38c4b4474cff7f26e7653b8d","affectsGlobalScope":true,"impliedFormat":1},{"version":"fb0f136d372979348d59b3f5020b4cdb81b5504192b1cacff5d1fbba29378aa1","affectsGlobalScope":true,"impliedFormat":1},{"version":"d15bea3d62cbbdb9797079416b8ac375ae99162a7fba5de2c6c505446486ac0a","affectsGlobalScope":true,"impliedFormat":1},{"version":"68d18b664c9d32a7336a70235958b8997ebc1c3b8505f4f1ae2b7e7753b87618","affectsGlobalScope":true,"impliedFormat":1},{"version":"eb3d66c8327153d8fa7dd03f9c58d351107fe824c79e9b56b462935176cdf12a","affectsGlobalScope":true,"impliedFormat":1},{"version":"38f0219c9e23c915ef9790ab1d680440d95419ad264816fa15009a8851e79119","affectsGlobalScope":true,"impliedFormat":1},{"version":"69ab18c3b76cd9b1be3d188eaf8bba06112ebbe2f47f6c322b5105a6fbc45a2e","affectsGlobalScope":true,"impliedFormat":1},{"version":"a680117f487a4d2f30ea46f1b4b7f58bef1480456e18ba53ee85c2746eeca012","affectsGlobalScope":true,"impliedFormat":1},{"version":"2f11ff796926e0832f9ae148008138ad583bd181899ab7dd768a2666700b1893","affectsGlobalScope":true,"impliedFormat":1},{"version":"4de680d5bb41c17f7f68e0419412ca23c98d5749dcaaea1896172f06435891fc","affectsGlobalScope":true,"impliedFormat":1},{"version":"954296b30da6d508a104a3a0b5d96b76495c709785c1d11610908e63481ee667","affectsGlobalScope":true,"impliedFormat":1},{"version":"ac9538681b19688c8eae65811b329d3744af679e0bdfa5d842d0e32524c73e1c","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a969edff4bd52585473d24995c5ef223f6652d6ef46193309b3921d65dd4376","affectsGlobalScope":true,"impliedFormat":1},{"version":"9e9fbd7030c440b33d021da145d3232984c8bb7916f277e8ffd3dc2e3eae2bdb","affectsGlobalScope":true,"impliedFormat":1},{"version":"811ec78f7fefcabbda4bfa93b3eb67d9ae166ef95f9bff989d964061cbf81a0c","affectsGlobalScope":true,"impliedFormat":1},{"version":"717937616a17072082152a2ef351cb51f98802fb4b2fdabd32399843875974ca","affectsGlobalScope":true,"impliedFormat":1},{"version":"d7e7d9b7b50e5f22c915b525acc5a49a7a6584cf8f62d0569e557c5cfc4b2ac2","affectsGlobalScope":true,"impliedFormat":1},{"version":"71c37f4c9543f31dfced6c7840e068c5a5aacb7b89111a4364b1d5276b852557","affectsGlobalScope":true,"impliedFormat":1},{"version":"576711e016cf4f1804676043e6a0a5414252560eb57de9faceee34d79798c850","affectsGlobalScope":true,"impliedFormat":1},{"version":"89c1b1281ba7b8a96efc676b11b264de7a8374c5ea1e6617f11880a13fc56dc6","affectsGlobalScope":true,"impliedFormat":1},{"version":"74f7fa2d027d5b33eb0471c8e82a6c87216223181ec31247c357a3e8e2fddc5b","affectsGlobalScope":true,"impliedFormat":1},{"version":"d6d7ae4d1f1f3772e2a3cde568ed08991a8ae34a080ff1151af28b7f798e22ca","affectsGlobalScope":true,"impliedFormat":1},{"version":"063600664504610fe3e99b717a1223f8b1900087fab0b4cad1496a114744f8df","affectsGlobalScope":true,"impliedFormat":1},{"version":"934019d7e3c81950f9a8426d093458b65d5aff2c7c1511233c0fd5b941e608ab","affectsGlobalScope":true,"impliedFormat":1},{"version":"52ada8e0b6e0482b728070b7639ee42e83a9b1c22d205992756fe020fd9f4a47","affectsGlobalScope":true,"impliedFormat":1},{"version":"3bdefe1bfd4d6dee0e26f928f93ccc128f1b64d5d501ff4a8cf3c6371200e5e6","affectsGlobalScope":true,"impliedFormat":1},{"version":"59fb2c069260b4ba00b5643b907ef5d5341b167e7d1dbf58dfd895658bda2867","affectsGlobalScope":true,"impliedFormat":1},{"version":"639e512c0dfc3fad96a84caad71b8834d66329a1f28dc95e3946c9b58176c73a","affectsGlobalScope":true,"impliedFormat":1},{"version":"368af93f74c9c932edd84c58883e736c9e3d53cec1fe24c0b0ff451f529ceab1","affectsGlobalScope":true,"impliedFormat":1},{"version":"af3dd424cf267428f30ccfc376f47a2c0114546b55c44d8c0f1d57d841e28d74","affectsGlobalScope":true,"impliedFormat":1},{"version":"995c005ab91a498455ea8dfb63aa9f83fa2ea793c3d8aa344be4a1678d06d399","affectsGlobalScope":true,"impliedFormat":1},{"version":"959d36cddf5e7d572a65045b876f2956c973a586da58e5d26cde519184fd9b8a","affectsGlobalScope":true,"impliedFormat":1},{"version":"965f36eae237dd74e6cca203a43e9ca801ce38824ead814728a2807b1910117d","affectsGlobalScope":true,"impliedFormat":1},{"version":"3925a6c820dcb1a06506c90b1577db1fdbf7705d65b62b99dce4be75c637e26b","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a3d63ef2b853447ec4f749d3f368ce642264246e02911fcb1590d8c161b8005","affectsGlobalScope":true,"impliedFormat":1},{"version":"8cdf8847677ac7d20486e54dd3fcf09eda95812ac8ace44b4418da1bbbab6eb8","affectsGlobalScope":true,"impliedFormat":1},{"version":"8444af78980e3b20b49324f4a16ba35024fef3ee069a0eb67616ea6ca821c47a","affectsGlobalScope":true,"impliedFormat":1},{"version":"3287d9d085fbd618c3971944b65b4be57859f5415f495b33a6adc994edd2f004","affectsGlobalScope":true,"impliedFormat":1},{"version":"b4b67b1a91182421f5df999988c690f14d813b9850b40acd06ed44691f6727ad","affectsGlobalScope":true,"impliedFormat":1},{"version":"df83c2a6c73228b625b0beb6669c7ee2a09c914637e2d35170723ad49c0f5cd4","affectsGlobalScope":true,"impliedFormat":1},{"version":"436aaf437562f276ec2ddbee2f2cdedac7664c1e4c1d2c36839ddd582eeb3d0a","affectsGlobalScope":true,"impliedFormat":1},{"version":"8e3c06ea092138bf9fa5e874a1fdbc9d54805d074bee1de31b99a11e2fec239d","affectsGlobalScope":true,"impliedFormat":1},{"version":"51ad4c928303041605b4d7ae32e0c1ee387d43a24cd6f1ebf4a2699e1076d4fa","affectsGlobalScope":true,"impliedFormat":1},{"version":"196cb558a13d4533a5163286f30b0509ce0210e4b316c56c38d4c0fd2fb38405","affectsGlobalScope":true,"impliedFormat":1},{"version":"8e7f8264d0fb4c5339605a15daadb037bf238c10b654bb3eee14208f860a32ea","affectsGlobalScope":true,"impliedFormat":1},{"version":"782dec38049b92d4e85c1585fbea5474a219c6984a35b004963b00beb1aab538","affectsGlobalScope":true,"impliedFormat":1},{"version":"a995fd30c77c296c964ee3cbd7a423bd74da85ed88aed5541aa867fe882f417e","signature":"cf564f12e1c38250add7a658961f4b33e47e45aa0a8cb02d9ac2dac64e5e4db2","impliedFormat":99},{"version":"d153a11543fd884b596587ccd97aebbeed950b26933ee000f94009f1ab142848","affectsGlobalScope":true,"impliedFormat":1},{"version":"0ccdaa19852d25ecd84eec365c3bfa16e7859cadecf6e9ca6d0dbbbee439743f","affectsGlobalScope":true,"impliedFormat":1},{"version":"438b41419b1df9f1fbe33b5e1b18f5853432be205991d1b19f5b7f351675541e","affectsGlobalScope":true,"impliedFormat":1},{"version":"096116f8fedc1765d5bd6ef360c257b4a9048e5415054b3bf3c41b07f8951b0b","affectsGlobalScope":true,"impliedFormat":1},{"version":"e5e01375c9e124a83b52ee4b3244ed1a4d214a6cfb54ac73e164a823a4a7860a","affectsGlobalScope":true,"impliedFormat":1},{"version":"f90ae2bbce1505e67f2f6502392e318f5714bae82d2d969185c4a6cecc8af2fc","affectsGlobalScope":true,"impliedFormat":1},{"version":"4b58e207b93a8f1c88bbf2a95ddc686ac83962b13830fe8ad3f404ffc7051fb4","affectsGlobalScope":true,"impliedFormat":1},{"version":"1fefabcb2b06736a66d2904074d56268753654805e829989a46a0161cd8412c5","affectsGlobalScope":true,"impliedFormat":1},{"version":"9798340ffb0d067d69b1ae5b32faa17ab31b82466a3fc00d8f2f2df0c8554aaa","affectsGlobalScope":true,"impliedFormat":1},{"version":"c18a99f01eb788d849ad032b31cafd49de0b19e083fe775370834c5675d7df8e","affectsGlobalScope":true,"impliedFormat":1},{"version":"5247874c2a23b9a62d178ae84f2db6a1d54e6c9a2e7e057e178cc5eea13757fc","affectsGlobalScope":true,"impliedFormat":1},{"version":"cdcf9ea426ad970f96ac930cd176d5c69c6c24eebd9fc580e1572d6c6a88f62c","impliedFormat":1},{"version":"23cd712e2ce083d68afe69224587438e5914b457b8acf87073c22494d706a3d0","impliedFormat":1},{"version":"487b694c3de27ddf4ad107d4007ad304d29effccf9800c8ae23c2093638d906a","impliedFormat":1},{"version":"3a80bc85f38526ca3b08007ee80712e7bb0601df178b23fbf0bf87036fce40ce","impliedFormat":1},{"version":"ccf4552357ce3c159ef75f0f0114e80401702228f1898bdc9402214c9499e8c0","impliedFormat":1},{"version":"c6fd2c5a395f2432786c9cb8deb870b9b0e8ff7e22c029954fabdd692bff6195","impliedFormat":1},{"version":"68834d631c8838c715f225509cfc3927913b9cc7a4870460b5b60c8dbdb99baf","impliedFormat":1},{"version":"2931540c47ee0ff8a62860e61782eb17b155615db61e36986e54645ec67f67c2","impliedFormat":1},{"version":"ccab02f3920fc75c01174c47fcf67882a11daf16baf9e81701d0a94636e94556","impliedFormat":1},{"version":"f6faf5f74e4c4cc309a6c6a6c4da02dbb840be5d3e92905a23dcd7b2b0bd1986","impliedFormat":1},{"version":"ea6bc8de8b59f90a7a3960005fd01988f98fd0784e14bc6922dde2e93305ec7d","impliedFormat":1},{"version":"36107995674b29284a115e21a0618c4c2751b32a8766dd4cb3ba740308b16d59","impliedFormat":1},{"version":"914a0ae30d96d71915fc519ccb4efbf2b62c0ddfb3a3fc6129151076bc01dc60","impliedFormat":1},{"version":"33e981bf6376e939f99bd7f89abec757c64897d33c005036b9a10d9587d80187","impliedFormat":1},{"version":"7fd1b31fd35876b0aa650811c25ec2c97a3c6387e5473eb18004bed86cdd76b6","impliedFormat":1},{"version":"b41767d372275c154c7ea6c9d5449d9a741b8ce080f640155cc88ba1763e35b3","impliedFormat":1},{"version":"3bacf516d686d08682751a3bd2519ea3b8041a164bfb4f1d35728993e70a2426","impliedFormat":1},{"version":"7fb266686238369442bd1719bc0d7edd0199da4fb8540354e1ff7f16669b4323","impliedFormat":1},{"version":"0a60a292b89ca7218b8616f78e5bbd1c96b87e048849469cccb4355e98af959a","impliedFormat":1},{"version":"0b6e25234b4eec6ed96ab138d96eb70b135690d7dd01f3dd8a8ab291c35a683a","impliedFormat":1},{"version":"9666f2f84b985b62400d2e5ab0adae9ff44de9b2a34803c2c5bd3c8325b17dc0","impliedFormat":1},{"version":"40cd35c95e9cf22cfa5bd84e96408b6fcbca55295f4ff822390abb11afbc3dca","impliedFormat":1},{"version":"b1616b8959bf557feb16369c6124a97a0e74ed6f49d1df73bb4b9ddf68acf3f3","impliedFormat":1},{"version":"5b03a034c72146b61573aab280f295b015b9168470f2df05f6080a2122f9b4df","impliedFormat":1},{"version":"40b463c6766ca1b689bfcc46d26b5e295954f32ad43e37ee6953c0a677e4ae2b","impliedFormat":1},{"version":"249b9cab7f5d628b71308c7d9bb0a808b50b091e640ba3ed6e2d0516f4a8d91d","impliedFormat":1},{"version":"80aae6afc67faa5ac0b32b5b8bc8cc9f7fa299cff15cf09cc2e11fd28c6ae29e","impliedFormat":1},{"version":"f473cd2288991ff3221165dcf73cd5d24da30391f87e85b3dd4d0450c787a391","impliedFormat":1},{"version":"499e5b055a5aba1e1998f7311a6c441a369831c70905cc565ceac93c28083d53","impliedFormat":1},{"version":"54c3e2371e3d016469ad959697fd257e5621e16296fa67082c2575d0bf8eced0","impliedFormat":1},{"version":"beb8233b2c220cfa0feea31fbe9218d89fa02faa81ef744be8dce5acb89bb1fd","impliedFormat":1},{"version":"c183b931b68ad184bc8e8372bf663f3d33304772fb482f29fb91b3c391031f3e","impliedFormat":1},{"version":"5d0375ca7310efb77e3ef18d068d53784faf62705e0ad04569597ae0e755c401","impliedFormat":1},{"version":"59af37caec41ecf7b2e76059c9672a49e682c1a2aa6f9d7dc78878f53aa284d6","impliedFormat":1},{"version":"addf417b9eb3f938fddf8d81e96393a165e4be0d4a8b6402292f9c634b1cb00d","impliedFormat":1},{"version":"48cc3ec153b50985fb95153258a710782b25975b10dd4ac8a4f3920632d10790","impliedFormat":1},{"version":"adf27937dba6af9f08a68c5b1d3fce0ca7d4b960c57e6d6c844e7d1a8e53adae","impliedFormat":1},{"version":"e1528ca65ac90f6fa0e4a247eb656b4263c470bb22d9033e466463e13395e599","impliedFormat":1},{"version":"2e85db9e6fd73cfa3d7f28e0ab6b55417ea18931423bd47b409a96e4a169e8e6","impliedFormat":1},{"version":"c46e079fe54c76f95c67fb89081b3e399da2c7d109e7dca8e4b58d83e332e605","impliedFormat":1},{"version":"866078923a56d026e39243b4392e282c1c63159723996fa89243140e1388a98d","impliedFormat":1},{"version":"dd0109710de4cd93e245121ab86d8c66d20f3ead80074b68e9c3e349c4f53342","affectsGlobalScope":true,"impliedFormat":1},{"version":"b3275d55fac10b799c9546804126239baf020d220136163f763b55a74e50e750","affectsGlobalScope":true,"impliedFormat":1},{"version":"fa68a0a3b7cb32c00e39ee3cd31f8f15b80cac97dce51b6ee7fc14a1e8deb30b","affectsGlobalScope":true,"impliedFormat":1},{"version":"1cf059eaf468efcc649f8cf6075d3cb98e9a35a0fe9c44419ec3d2f5428d7123","affectsGlobalScope":true,"impliedFormat":1},{"version":"6c36e755bced82df7fb6ce8169265d0a7bb046ab4e2cb6d0da0cb72b22033e89","affectsGlobalScope":true,"impliedFormat":1},{"version":"e7721c4f69f93c91360c26a0a84ee885997d748237ef78ef665b153e622b36c1","affectsGlobalScope":true,"impliedFormat":1},{"version":"7a93de4ff8a63bafe62ba86b89af1df0ccb5e40bb85b0c67d6bbcfdcf96bf3d4","affectsGlobalScope":true,"impliedFormat":1},{"version":"90e85f9bc549dfe2b5749b45fe734144e96cd5d04b38eae244028794e142a77e","affectsGlobalScope":true,"impliedFormat":1},{"version":"e0a5deeb610b2a50a6350bd23df6490036a1773a8a71d70f2f9549ab009e67ee","affectsGlobalScope":true,"impliedFormat":1},{"version":"435b3711465425770ed2ee2f1cf00ce071835265e0851a7dc4600ab4b007550e","impliedFormat":1},{"version":"7e49f52a159435fc8df4de9dc377ef5860732ca2dc9efec1640531d3cf5da7a3","impliedFormat":1},{"version":"dd4bde4bdc2e5394aed6855e98cf135dfdf5dd6468cad842e03116d31bbcc9bc","impliedFormat":1},{"version":"4d4e879009a84a47c05350b8dca823036ba3a29a3038efed1be76c9f81e45edf","affectsGlobalScope":true,"impliedFormat":1},{"version":"cf83d90d5faf27b994c2e79af02e32b555dbfe42cd9bd1571445f2168d1f4e2d","impliedFormat":1},{"version":"9ba13b47cb450a438e3076c4a3f6afb9dc85e17eae50f26d4b2d72c0688c9251","impliedFormat":1},{"version":"b64cd4401633ea4ecadfd700ddc8323a13b63b106ac7127c1d2726f32424622c","impliedFormat":1},{"version":"37c6e5fe5715814412b43cc9b50b24c67a63c4e04e753e0d1305970d65417a60","impliedFormat":1},{"version":"0e28335ac43f4d94dd2fe6d9e6fa6813570640839addd10d309d7985f33a6308","impliedFormat":1},{"version":"ee0e4946247f842c6dd483cbb60a5e6b484fee07996e3a7bc7343dfb68a04c5d","impliedFormat":1},{"version":"ef051f42b7e0ef5ca04552f54c4552eac84099d64b6c5ad0ef4033574b6035b8","impliedFormat":1},{"version":"853a43154f1d01b0173d9cbd74063507ece57170bad7a3b68f3fa1229ad0a92f","impliedFormat":1},{"version":"56231e3c39a031bfb0afb797690b20ed4537670c93c0318b72d5180833d98b72","impliedFormat":1},{"version":"5cc7c39031bfd8b00ad58f32143d59eb6ffc24f5d41a20931269011dccd36c5e","impliedFormat":1},{"version":"b0b69c61b0f0ec8ca15db4c8c41f6e77f4cacb784d42bca948f42dea33e8757e","affectsGlobalScope":true,"impliedFormat":1},{"version":"f96a48183254c00d24575401f1a761b4ce4927d927407e7862a83e06ce5d6964","impliedFormat":1},{"version":"cc25940cfb27aa538e60d465f98bb5068d4d7d33131861ace43f04fe6947d68f","impliedFormat":1},{"version":"e6f370b5c1d52edabb93ef055d0c0c396a98be77db8aa022fcc3670787b8b5f5","impliedFormat":1},{"version":"01ff95aa1443e3f7248974e5a771f513cb2ac158c8898f470a1792f817bee497","impliedFormat":1},{"version":"9d96a7ce809392ff2cb99691acf7c62e632fe56897356ba013b689277aca3619","impliedFormat":1},{"version":"42a05d8f239f74587d4926aba8cc54792eed8e8a442c7adc9b38b516642aadfe","impliedFormat":1},{"version":"5d21b58d60383cc6ab9ad3d3e265d7d25af24a2c9b506247e0e50b0a884920be","impliedFormat":1},{"version":"101f482fd48cb4c7c0468dcc6d62c843d842977aea6235644b1edd05e81fbf22","impliedFormat":1},{"version":"ae6757460f37078884b1571a3de3ebaf724d827d7e1d53626c02b3c2a408ac63","affectsGlobalScope":true,"impliedFormat":1},{"version":"27c0a08e343c6a0ae17bd13ba6d44a9758236dc904cd5e4b43456996cd51f520","impliedFormat":1},{"version":"3ef397f12387eff17f550bc484ea7c27d21d43816bbe609d495107f44b97e933","impliedFormat":1},{"version":"1023282e2ba810bc07905d3668349fbd37a26411f0c8f94a70ef3c05fe523fcf","impliedFormat":1},{"version":"b214ebcf76c51b115453f69729ee8aa7b7f8eccdae2a922b568a45c2d7ff52f7","impliedFormat":1},{"version":"429c9cdfa7d126255779efd7e6d9057ced2d69c81859bbab32073bad52e9ba76","impliedFormat":1},{"version":"6f80e51ba310608cd71bcdc09a171d7bbfb3b316048601c9ec215ce16a8dcfbc","impliedFormat":1},{"version":"10947bb49601aeec9ea1dddf61ef6e4f8442f949bd40a8008e12b129deb037be","affectsGlobalScope":true,"impliedFormat":1},{"version":"7f2c62938251b45715fd2a9887060ec4fbc8724727029d1cbce373747252bdd7","impliedFormat":1},{"version":"e3ace08b6bbd84655d41e244677b474fd995923ffef7149ddb68af8848b60b05","impliedFormat":1},{"version":"132580b0e86c48fab152bab850fc57a4b74fe915c8958d2ccb052b809a44b61c","impliedFormat":1},{"version":"af4ab0aa8908fc9a655bb833d3bc28e117c4f0e1038c5a891546158beb25accb","impliedFormat":1},{"version":"69c9a5a9392e8564bd81116e1ed93b13205201fb44cb35a7fde8c9f9e21c4b23","impliedFormat":1},{"version":"5f8fc37f8434691ffac1bfd8fc2634647da2c0e84253ab5d2dd19a7718915b35","impliedFormat":1},{"version":"5981c2340fd8b076cae8efbae818d42c11ffc615994cb060b1cd390795f1be2b","impliedFormat":1},{"version":"1641d32611fc7aa82cdd9fa38ff18349aac4eda9e032ced76b21943673887f9a","impliedFormat":1},{"version":"ed4f674fc8c0c993cc7e145069ac44129e03519b910c62be206a0cc777bdc60b","affectsGlobalScope":true,"impliedFormat":1},{"version":"0250da3eb85c99624f974e77ef355cdf86f43980251bc371475c2b397ba55bcd","impliedFormat":1},{"version":"f1c93e046fb3d9b7f8249629f4b63dc068dd839b824dd0aa39a5e68476dc9420","impliedFormat":1},{"version":"3d3a5f27ffbc06c885dd4d5f9ee20de61faf877fe2c3a7051c4825903d9a7fdc","impliedFormat":1},{"version":"12806f9f085598ef930edaf2467a5fa1789a878fba077cd27e85dc5851e11834","impliedFormat":1},{"version":"17d06eb5709839c7ce719f0c38ada6f308fb433f2cd6d8c87b35856e07400950","impliedFormat":1},{"version":"a43fe41c33d0a192a0ecaf9b92e87bef3709c9972e6d53c42c49251ccb962d69","impliedFormat":1},{"version":"a177959203c017fad3ecc4f3d96c8757a840957a4959a3ae00dab9d35961ca6c","affectsGlobalScope":true,"impliedFormat":1},{"version":"6fc727ccf9b36e257ff982ea0badeffbfc2c151802f741bddff00c6af3b784cf","impliedFormat":1},{"version":"2a00d005e3af99cd1cfa75220e60c61b04bfb6be7ca7453bfe2ef6cca37cc03c","impliedFormat":1},{"version":"4844a4c9b4b1e812b257676ed8a80b3f3be0e29bf05e742cc2ea9c3c6865e6c6","impliedFormat":1},{"version":"064878a60367e0407c42fb7ba02a2ea4d83257357dc20088e549bd4d89433e9c","impliedFormat":1},{"version":"14d4bd22d1b05824971b98f7e91b2484c90f1a684805c330476641417c3d9735","impliedFormat":1},{"version":"586eaf66bace2e731cee0ddfbfac326ad74a83c1acfeac4afb2db85ad23226c7","impliedFormat":1},{"version":"b484ec11ba00e3a2235562a41898d55372ccabe607986c6fa4f4aba72093749f","impliedFormat":1},{"version":"d1a14d87cedcf4f0b8173720d6eb29cc02878bf2b6dabf9c9d9cee742f275368","impliedFormat":1},{"version":"41ef7992c555671a8fe54db302788adefa191ded810a50329b79d20a6772d14c","impliedFormat":1},{"version":"041a7781b9127ab568d2cdcce62c58fdea7c7407f40b8c50045d7866a2727130","impliedFormat":1},{"version":"b37f83e7deea729aa9ce5593f78905afb45b7532fdff63041d374f60059e7852","impliedFormat":1},{"version":"e1cb68f3ef3a8dd7b2a9dfb3de482ed6c0f1586ba0db4e7d73c1d2147b6ffc51","impliedFormat":1},{"version":"55cdbeebe76a1fa18bbd7e7bf73350a2173926bd3085bb050cf5a5397025ee4e","impliedFormat":1},{"version":"4fe80f12b1d5189384a219095c2eabadbb389c2d3703aae7c5376dbaa56061df","impliedFormat":1},{"version":"9eb1d2dceae65d1c82fc6be7e9b6b19cf3ca93c364678611107362b6ad4d2d41","impliedFormat":1},{"version":"8065e20ac0ad0536d4f1c8d4c2303272a4d25c450bea8d25deb25697d19300e5","impliedFormat":1},{"version":"cdf4f3357ce01800bffbdf998e6be6acc14f49050de04c9f28878336b0ce3230","impliedFormat":99},{"version":"6d691ba2910758e577da5aeb2e49c285674db35fdac2bae041ade14dcd1bd463","signature":"f90ed2c8ae7307b1b4facc39e56709a50809a50c3c96aaa9f313420f92f6c6d1","impliedFormat":99},{"version":"d2f0e26e25339e7abe5a9256d699d5ab18540093abe4184b78fe595edb6515b1","signature":"70bd00d30cb759398ef38824bc0f22ec1fb2435d46fb3deb7d93945c550709a5","impliedFormat":99},{"version":"e945bd5d454512e63fd31f484f82d267b22a8087fe95bb8d5ffa4102bb9a3510","impliedFormat":99},{"version":"6bf2d5d60dc2dab4f205b00251eabb2169839f47dc5a008ca316e8080c7e60ff","signature":"b9ec647a926cd14658551a0138ce712ef4b43a4e36d5a7d0855f738d72e30703","impliedFormat":99},{"version":"155c5392cffd7b1763a8cb7bbdfcf0fac85f2b2fcb75e64b8bf07324d36e2bb8","impliedFormat":99}],"root":[64,190,191,193,194],"options":{"composite":true,"declaration":true,"declarationMap":true,"esModuleInterop":true,"module":199,"outDir":"./dist","rootDir":"./src","skipLibCheck":true,"sourceMap":true,"strict":true,"target":10},"referencedMap":[[126,1],[127,1],[128,2],[67,3],[129,4],[130,5],[131,6],[65,7],[132,8],[133,9],[134,10],[135,11],[136,12],[137,13],[138,13],[139,14],[140,15],[141,16],[142,17],[68,7],[66,7],[143,18],[144,19],[145,20],[185,21],[146,22],[147,23],[148,22],[149,24],[150,25],[151,26],[152,27],[153,27],[154,27],[155,28],[156,29],[157,30],[158,31],[159,32],[160,33],[161,33],[162,34],[163,7],[164,7],[165,35],[166,36],[167,35],[168,37],[169,38],[170,39],[171,40],[172,41],[173,42],[174,43],[175,44],[176,45],[177,46],[178,47],[179,48],[180,49],[181,50],[182,51],[69,22],[70,7],[71,52],[72,53],[73,7],[74,54],[75,7],[117,55],[118,56],[119,57],[120,57],[121,58],[122,7],[123,4],[124,59],[125,56],[183,60],[184,61],[186,62],[188,63],[187,64],[62,7],[63,7],[12,7],[11,7],[2,7],[13,7],[14,7],[15,7],[16,7],[17,7],[18,7],[19,7],[20,7],[3,7],[21,7],[22,7],[4,7],[23,7],[27,7],[24,7],[25,7],[26,7],[28,7],[29,7],[30,7],[5,7],[31,7],[32,7],[33,7],[34,7],[6,7],[38,7],[35,7],[36,7],[37,7],[39,7],[7,7],[40,7],[45,7],[46,7],[41,7],[42,7],[43,7],[44,7],[8,7],[50,7],[47,7],[48,7],[49,7],[51,7],[9,7],[52,7],[53,7],[54,7],[56,7],[55,7],[57,7],[58,7],[10,7],[59,7],[1,7],[60,7],[61,7],[93,65],[105,66],[91,67],[106,68],[115,69],[82,70],[83,71],[81,72],[114,73],[109,74],[113,75],[85,76],[102,77],[84,78],[112,79],[79,80],[80,74],[86,81],[87,7],[92,82],[90,81],[77,83],[116,84],[107,85],[96,86],[95,81],[97,87],[100,88],[94,89],[98,90],[110,73],[88,91],[89,92],[101,93],[78,68],[104,94],[103,81],[99,95],[108,7],[76,7],[111,96],[192,7],[189,97],[194,98],[190,99],[64,7],[191,53],[193,100]],"latestChangedDtsFile":"./dist/index.d.ts","version":"5.9.3"}