@contractspec/example.meeting-recorder-providers 3.7.16 → 3.7.18
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/.turbo/turbo-build.log +33 -33
- package/CHANGELOG.md +25 -0
- package/dist/browser/connection.sample.js +1 -123
- package/dist/browser/docs/index.js +16 -43
- package/dist/browser/docs/meeting-recorder-providers.docblock.js +16 -43
- package/dist/browser/example.js +1 -33
- package/dist/browser/handlers/create-provider.js +1 -67
- package/dist/browser/handlers/get-transcript.js +1 -73
- package/dist/browser/handlers/list-meetings.js +1 -73
- package/dist/browser/handlers/webhook-handler.js +1 -114
- package/dist/browser/index.js +18 -351
- package/dist/browser/meeting-recorder-providers.feature.js +1 -24
- package/dist/connection.sample.js +1 -123
- package/dist/docs/index.js +16 -43
- package/dist/docs/meeting-recorder-providers.docblock.js +16 -43
- package/dist/example.js +1 -33
- package/dist/handlers/create-provider.js +1 -67
- package/dist/handlers/get-transcript.js +1 -73
- package/dist/handlers/list-meetings.js +1 -73
- package/dist/handlers/webhook-handler.js +1 -114
- package/dist/index.js +18 -351
- package/dist/meeting-recorder-providers.feature.js +1 -24
- package/dist/node/connection.sample.js +1 -123
- package/dist/node/docs/index.js +16 -43
- package/dist/node/docs/meeting-recorder-providers.docblock.js +16 -43
- package/dist/node/example.js +1 -33
- package/dist/node/handlers/create-provider.js +1 -67
- package/dist/node/handlers/get-transcript.js +1 -73
- package/dist/node/handlers/list-meetings.js +1 -73
- package/dist/node/handlers/webhook-handler.js +1 -114
- package/dist/node/index.js +18 -351
- package/dist/node/meeting-recorder-providers.feature.js +1 -24
- package/package.json +8 -8
package/dist/docs/index.js
CHANGED
|
@@ -1,46 +1,19 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
id: "docs.examples.meeting-recorder-providers",
|
|
7
|
-
title: "Meeting Recorder Providers (example)",
|
|
8
|
-
summary: "Multi-provider meeting recorder example covering list, transcript fetch, and webhook ingestion.",
|
|
9
|
-
kind: "reference",
|
|
10
|
-
visibility: "public",
|
|
11
|
-
route: "/docs/examples/meeting-recorder-providers",
|
|
12
|
-
tags: ["meeting-recorder", "integration", "example", "transcripts"],
|
|
13
|
-
body: `## What this example shows
|
|
14
|
-
` + `- Provider selection for Granola (API and MCP), tl;dv, Fireflies, and Fathom.
|
|
15
|
-
` + `- List meetings + fetch transcripts using the MeetingRecorderProvider interface.
|
|
16
|
-
` + `- Webhook verification and normalization into a single event shape.
|
|
2
|
+
import{registerDocBlocks as f}from"@contractspec/lib.contracts-spec/docs";var h=[{id:"docs.examples.meeting-recorder-providers",title:"Meeting Recorder Providers (example)",summary:"Multi-provider meeting recorder example covering list, transcript fetch, and webhook ingestion.",kind:"reference",visibility:"public",route:"/docs/examples/meeting-recorder-providers",tags:["meeting-recorder","integration","example","transcripts"],body:`## What this example shows
|
|
3
|
+
- Provider selection for Granola (API and MCP), tl;dv, Fireflies, and Fathom.
|
|
4
|
+
- List meetings + fetch transcripts using the MeetingRecorderProvider interface.
|
|
5
|
+
- Webhook verification and normalization into a single event shape.
|
|
17
6
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
7
|
+
## Secrets and config
|
|
8
|
+
- apiKey (all providers)
|
|
9
|
+
- Granola MCP: set transport=mcp and provide mcpAccessToken (or apiKey fallback for MCP proxy).
|
|
10
|
+
- webhookSecret (Fireflies and Fathom)
|
|
11
|
+
- baseUrl overrides for sandbox or proxy setups
|
|
12
|
+
- mcpUrl and mcpHeaders for custom MCP routing
|
|
13
|
+
- pageSize / transcriptsPageSize for pagination
|
|
14
|
+
- Fathom options: includeTranscript, includeSummary, includeActionItems, includeCrmMatches, triggeredFor
|
|
26
15
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
},
|
|
32
|
-
{
|
|
33
|
-
id: "docs.examples.meeting-recorder-providers.usage",
|
|
34
|
-
title: "Meeting Recorder Providers - Usage",
|
|
35
|
-
summary: "How to wire the provider factory and handlers in a runtime.",
|
|
36
|
-
kind: "usage",
|
|
37
|
-
visibility: "public",
|
|
38
|
-
route: "/docs/examples/meeting-recorder-providers/usage",
|
|
39
|
-
tags: ["meeting-recorder", "usage"],
|
|
40
|
-
body: `## Usage
|
|
41
|
-
` + "- Call `createMeetingRecorderProvider` with an integration key, secrets, and config.\n" + "- Use `listMeetingRecorderMeetings` to fetch metadata pages.\n" + "- Use `getMeetingRecorderTranscript` to fetch transcript content.\n" + "- Wire `handleMeetingRecorderWebhook` to your webhook endpoint.\n\n" + `## Notes
|
|
42
|
-
` + `- Replace the placeholder stores with your app persistence.
|
|
43
|
-
` + "- Record the raw webhook payload for replay or debugging."
|
|
44
|
-
}
|
|
45
|
-
];
|
|
46
|
-
registerDocBlocks(blocks);
|
|
16
|
+
## Guardrails
|
|
17
|
+
- Keep secrets in a dedicated secret provider.
|
|
18
|
+
- Verify webhook signatures before triggering workflows.
|
|
19
|
+
- Treat transcript ingestion as async workflows, not inline writes.`},{id:"docs.examples.meeting-recorder-providers.usage",title:"Meeting Recorder Providers - Usage",summary:"How to wire the provider factory and handlers in a runtime.",kind:"usage",visibility:"public",route:"/docs/examples/meeting-recorder-providers/usage",tags:["meeting-recorder","usage"],body:"## Usage\n- Call `createMeetingRecorderProvider` with an integration key, secrets, and config.\n- Use `listMeetingRecorderMeetings` to fetch metadata pages.\n- Use `getMeetingRecorderTranscript` to fetch transcript content.\n- Wire `handleMeetingRecorderWebhook` to your webhook endpoint.\n\n## Notes\n- Replace the placeholder stores with your app persistence.\n- Record the raw webhook payload for replay or debugging."}];f(h);
|
|
@@ -1,46 +1,19 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
id: "docs.examples.meeting-recorder-providers",
|
|
7
|
-
title: "Meeting Recorder Providers (example)",
|
|
8
|
-
summary: "Multi-provider meeting recorder example covering list, transcript fetch, and webhook ingestion.",
|
|
9
|
-
kind: "reference",
|
|
10
|
-
visibility: "public",
|
|
11
|
-
route: "/docs/examples/meeting-recorder-providers",
|
|
12
|
-
tags: ["meeting-recorder", "integration", "example", "transcripts"],
|
|
13
|
-
body: `## What this example shows
|
|
14
|
-
` + `- Provider selection for Granola (API and MCP), tl;dv, Fireflies, and Fathom.
|
|
15
|
-
` + `- List meetings + fetch transcripts using the MeetingRecorderProvider interface.
|
|
16
|
-
` + `- Webhook verification and normalization into a single event shape.
|
|
2
|
+
import{registerDocBlocks as f}from"@contractspec/lib.contracts-spec/docs";var h=[{id:"docs.examples.meeting-recorder-providers",title:"Meeting Recorder Providers (example)",summary:"Multi-provider meeting recorder example covering list, transcript fetch, and webhook ingestion.",kind:"reference",visibility:"public",route:"/docs/examples/meeting-recorder-providers",tags:["meeting-recorder","integration","example","transcripts"],body:`## What this example shows
|
|
3
|
+
- Provider selection for Granola (API and MCP), tl;dv, Fireflies, and Fathom.
|
|
4
|
+
- List meetings + fetch transcripts using the MeetingRecorderProvider interface.
|
|
5
|
+
- Webhook verification and normalization into a single event shape.
|
|
17
6
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
7
|
+
## Secrets and config
|
|
8
|
+
- apiKey (all providers)
|
|
9
|
+
- Granola MCP: set transport=mcp and provide mcpAccessToken (or apiKey fallback for MCP proxy).
|
|
10
|
+
- webhookSecret (Fireflies and Fathom)
|
|
11
|
+
- baseUrl overrides for sandbox or proxy setups
|
|
12
|
+
- mcpUrl and mcpHeaders for custom MCP routing
|
|
13
|
+
- pageSize / transcriptsPageSize for pagination
|
|
14
|
+
- Fathom options: includeTranscript, includeSummary, includeActionItems, includeCrmMatches, triggeredFor
|
|
26
15
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
},
|
|
32
|
-
{
|
|
33
|
-
id: "docs.examples.meeting-recorder-providers.usage",
|
|
34
|
-
title: "Meeting Recorder Providers - Usage",
|
|
35
|
-
summary: "How to wire the provider factory and handlers in a runtime.",
|
|
36
|
-
kind: "usage",
|
|
37
|
-
visibility: "public",
|
|
38
|
-
route: "/docs/examples/meeting-recorder-providers/usage",
|
|
39
|
-
tags: ["meeting-recorder", "usage"],
|
|
40
|
-
body: `## Usage
|
|
41
|
-
` + "- Call `createMeetingRecorderProvider` with an integration key, secrets, and config.\n" + "- Use `listMeetingRecorderMeetings` to fetch metadata pages.\n" + "- Use `getMeetingRecorderTranscript` to fetch transcript content.\n" + "- Wire `handleMeetingRecorderWebhook` to your webhook endpoint.\n\n" + `## Notes
|
|
42
|
-
` + `- Replace the placeholder stores with your app persistence.
|
|
43
|
-
` + "- Record the raw webhook payload for replay or debugging."
|
|
44
|
-
}
|
|
45
|
-
];
|
|
46
|
-
registerDocBlocks(blocks);
|
|
16
|
+
## Guardrails
|
|
17
|
+
- Keep secrets in a dedicated secret provider.
|
|
18
|
+
- Verify webhook signatures before triggering workflows.
|
|
19
|
+
- Treat transcript ingestion as async workflows, not inline writes.`},{id:"docs.examples.meeting-recorder-providers.usage",title:"Meeting Recorder Providers - Usage",summary:"How to wire the provider factory and handlers in a runtime.",kind:"usage",visibility:"public",route:"/docs/examples/meeting-recorder-providers/usage",tags:["meeting-recorder","usage"],body:"## Usage\n- Call `createMeetingRecorderProvider` with an integration key, secrets, and config.\n- Use `listMeetingRecorderMeetings` to fetch metadata pages.\n- Use `getMeetingRecorderTranscript` to fetch transcript content.\n- Wire `handleMeetingRecorderWebhook` to your webhook endpoint.\n\n## Notes\n- Replace the placeholder stores with your app persistence.\n- Record the raw webhook payload for replay or debugging."}];f(h);
|
package/dist/example.js
CHANGED
|
@@ -1,34 +1,2 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
|
|
3
|
-
import { defineExample } from "@contractspec/lib.contracts-spec";
|
|
4
|
-
var example = defineExample({
|
|
5
|
-
meta: {
|
|
6
|
-
key: "meeting-recorder-providers",
|
|
7
|
-
version: "1.0.0",
|
|
8
|
-
title: "Meeting Recorder Providers",
|
|
9
|
-
description: "Multi-provider meeting recorder integration example with list, transcript, and webhook handling.",
|
|
10
|
-
kind: "integration",
|
|
11
|
-
visibility: "public",
|
|
12
|
-
stability: "experimental",
|
|
13
|
-
owners: ["@platform.integrations"],
|
|
14
|
-
tags: ["meeting-recorder", "transcripts", "webhooks", "integrations"]
|
|
15
|
-
},
|
|
16
|
-
docs: {
|
|
17
|
-
rootDocId: "docs.examples.meeting-recorder-providers",
|
|
18
|
-
usageDocId: "docs.examples.meeting-recorder-providers.usage"
|
|
19
|
-
},
|
|
20
|
-
entrypoints: {
|
|
21
|
-
packageName: "@contractspec/example.meeting-recorder-providers",
|
|
22
|
-
docs: "./docs"
|
|
23
|
-
},
|
|
24
|
-
surfaces: {
|
|
25
|
-
templates: true,
|
|
26
|
-
sandbox: { enabled: true, modes: ["markdown", "specs"] },
|
|
27
|
-
studio: { enabled: true, installable: true },
|
|
28
|
-
mcp: { enabled: true }
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
var example_default = example;
|
|
32
|
-
export {
|
|
33
|
-
example_default as default
|
|
34
|
-
};
|
|
2
|
+
import{defineExample as g}from"@contractspec/lib.contracts-spec";var h=g({meta:{key:"meeting-recorder-providers",version:"1.0.0",title:"Meeting Recorder Providers",description:"Multi-provider meeting recorder integration example with list, transcript, and webhook handling.",kind:"integration",visibility:"public",stability:"experimental",owners:["@platform.integrations"],tags:["meeting-recorder","transcripts","webhooks","integrations"]},docs:{rootDocId:"docs.examples.meeting-recorder-providers",usageDocId:"docs.examples.meeting-recorder-providers.usage"},entrypoints:{packageName:"@contractspec/example.meeting-recorder-providers",docs:"./docs"},surfaces:{templates:!0,sandbox:{enabled:!0,modes:["markdown","specs"]},studio:{enabled:!0,installable:!0},mcp:{enabled:!0}}}),q=h;export{q as default};
|
|
@@ -1,68 +1,2 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
|
|
3
|
-
import { FathomMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/fathom-meeting-recorder";
|
|
4
|
-
import { FirefliesMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/fireflies-meeting-recorder";
|
|
5
|
-
import { GranolaMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/granola-meeting-recorder";
|
|
6
|
-
import { TldvMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/tldv-meeting-recorder";
|
|
7
|
-
function createMeetingRecorderProvider(input) {
|
|
8
|
-
const { integrationKey, secrets, config } = input;
|
|
9
|
-
switch (integrationKey) {
|
|
10
|
-
case "meeting-recorder.granola":
|
|
11
|
-
if (config?.transport === "mcp") {
|
|
12
|
-
return new GranolaMeetingRecorderProvider({
|
|
13
|
-
transport: "mcp",
|
|
14
|
-
mcpUrl: config?.mcpUrl,
|
|
15
|
-
mcpHeaders: config?.mcpHeaders,
|
|
16
|
-
mcpAccessToken: secrets.mcpAccessToken ?? secrets.apiKey,
|
|
17
|
-
pageSize: config?.pageSize
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
if (!secrets.apiKey) {
|
|
21
|
-
throw new Error("Granola apiKey is required for API transport.");
|
|
22
|
-
}
|
|
23
|
-
return new GranolaMeetingRecorderProvider({
|
|
24
|
-
apiKey: secrets.apiKey,
|
|
25
|
-
baseUrl: config?.baseUrl,
|
|
26
|
-
pageSize: config?.pageSize
|
|
27
|
-
});
|
|
28
|
-
case "meeting-recorder.tldv":
|
|
29
|
-
if (!secrets.apiKey) {
|
|
30
|
-
throw new Error("tl;dv apiKey is required.");
|
|
31
|
-
}
|
|
32
|
-
return new TldvMeetingRecorderProvider({
|
|
33
|
-
apiKey: secrets.apiKey,
|
|
34
|
-
baseUrl: config?.baseUrl,
|
|
35
|
-
pageSize: config?.pageSize
|
|
36
|
-
});
|
|
37
|
-
case "meeting-recorder.fireflies":
|
|
38
|
-
if (!secrets.apiKey) {
|
|
39
|
-
throw new Error("Fireflies apiKey is required.");
|
|
40
|
-
}
|
|
41
|
-
return new FirefliesMeetingRecorderProvider({
|
|
42
|
-
apiKey: secrets.apiKey,
|
|
43
|
-
baseUrl: config?.baseUrl,
|
|
44
|
-
pageSize: config?.transcriptsPageSize ?? config?.pageSize,
|
|
45
|
-
webhookSecret: secrets.webhookSecret
|
|
46
|
-
});
|
|
47
|
-
case "meeting-recorder.fathom":
|
|
48
|
-
if (!secrets.apiKey) {
|
|
49
|
-
throw new Error("Fathom apiKey is required.");
|
|
50
|
-
}
|
|
51
|
-
return new FathomMeetingRecorderProvider({
|
|
52
|
-
apiKey: secrets.apiKey,
|
|
53
|
-
baseUrl: config?.baseUrl,
|
|
54
|
-
includeTranscript: config?.includeTranscript,
|
|
55
|
-
includeSummary: config?.includeSummary,
|
|
56
|
-
includeActionItems: config?.includeActionItems,
|
|
57
|
-
includeCrmMatches: config?.includeCrmMatches,
|
|
58
|
-
triggeredFor: config?.triggeredFor,
|
|
59
|
-
maxPages: config?.maxPages,
|
|
60
|
-
webhookSecret: secrets.webhookSecret
|
|
61
|
-
});
|
|
62
|
-
default:
|
|
63
|
-
throw new Error(`Unsupported meeting recorder provider: ${integrationKey}`);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
export {
|
|
67
|
-
createMeetingRecorderProvider
|
|
68
|
-
};
|
|
2
|
+
import{FathomMeetingRecorderProvider as q}from"@contractspec/integration.providers-impls/impls/fathom-meeting-recorder";import{FirefliesMeetingRecorderProvider as w}from"@contractspec/integration.providers-impls/impls/fireflies-meeting-recorder";import{GranolaMeetingRecorderProvider as k}from"@contractspec/integration.providers-impls/impls/granola-meeting-recorder";import{TldvMeetingRecorderProvider as x}from"@contractspec/integration.providers-impls/impls/tldv-meeting-recorder";function D(m){let{integrationKey:j,secrets:h,config:b}=m;switch(j){case"meeting-recorder.granola":if(b?.transport==="mcp")return new k({transport:"mcp",mcpUrl:b?.mcpUrl,mcpHeaders:b?.mcpHeaders,mcpAccessToken:h.mcpAccessToken??h.apiKey,pageSize:b?.pageSize});if(!h.apiKey)throw Error("Granola apiKey is required for API transport.");return new k({apiKey:h.apiKey,baseUrl:b?.baseUrl,pageSize:b?.pageSize});case"meeting-recorder.tldv":if(!h.apiKey)throw Error("tl;dv apiKey is required.");return new x({apiKey:h.apiKey,baseUrl:b?.baseUrl,pageSize:b?.pageSize});case"meeting-recorder.fireflies":if(!h.apiKey)throw Error("Fireflies apiKey is required.");return new w({apiKey:h.apiKey,baseUrl:b?.baseUrl,pageSize:b?.transcriptsPageSize??b?.pageSize,webhookSecret:h.webhookSecret});case"meeting-recorder.fathom":if(!h.apiKey)throw Error("Fathom apiKey is required.");return new q({apiKey:h.apiKey,baseUrl:b?.baseUrl,includeTranscript:b?.includeTranscript,includeSummary:b?.includeSummary,includeActionItems:b?.includeActionItems,includeCrmMatches:b?.includeCrmMatches,triggeredFor:b?.triggeredFor,maxPages:b?.maxPages,webhookSecret:h.webhookSecret});default:throw Error(`Unsupported meeting recorder provider: ${j}`)}}export{D as createMeetingRecorderProvider};
|
|
@@ -1,74 +1,2 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
|
|
3
|
-
import { FathomMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/fathom-meeting-recorder";
|
|
4
|
-
import { FirefliesMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/fireflies-meeting-recorder";
|
|
5
|
-
import { GranolaMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/granola-meeting-recorder";
|
|
6
|
-
import { TldvMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/tldv-meeting-recorder";
|
|
7
|
-
function createMeetingRecorderProvider(input) {
|
|
8
|
-
const { integrationKey, secrets, config } = input;
|
|
9
|
-
switch (integrationKey) {
|
|
10
|
-
case "meeting-recorder.granola":
|
|
11
|
-
if (config?.transport === "mcp") {
|
|
12
|
-
return new GranolaMeetingRecorderProvider({
|
|
13
|
-
transport: "mcp",
|
|
14
|
-
mcpUrl: config?.mcpUrl,
|
|
15
|
-
mcpHeaders: config?.mcpHeaders,
|
|
16
|
-
mcpAccessToken: secrets.mcpAccessToken ?? secrets.apiKey,
|
|
17
|
-
pageSize: config?.pageSize
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
if (!secrets.apiKey) {
|
|
21
|
-
throw new Error("Granola apiKey is required for API transport.");
|
|
22
|
-
}
|
|
23
|
-
return new GranolaMeetingRecorderProvider({
|
|
24
|
-
apiKey: secrets.apiKey,
|
|
25
|
-
baseUrl: config?.baseUrl,
|
|
26
|
-
pageSize: config?.pageSize
|
|
27
|
-
});
|
|
28
|
-
case "meeting-recorder.tldv":
|
|
29
|
-
if (!secrets.apiKey) {
|
|
30
|
-
throw new Error("tl;dv apiKey is required.");
|
|
31
|
-
}
|
|
32
|
-
return new TldvMeetingRecorderProvider({
|
|
33
|
-
apiKey: secrets.apiKey,
|
|
34
|
-
baseUrl: config?.baseUrl,
|
|
35
|
-
pageSize: config?.pageSize
|
|
36
|
-
});
|
|
37
|
-
case "meeting-recorder.fireflies":
|
|
38
|
-
if (!secrets.apiKey) {
|
|
39
|
-
throw new Error("Fireflies apiKey is required.");
|
|
40
|
-
}
|
|
41
|
-
return new FirefliesMeetingRecorderProvider({
|
|
42
|
-
apiKey: secrets.apiKey,
|
|
43
|
-
baseUrl: config?.baseUrl,
|
|
44
|
-
pageSize: config?.transcriptsPageSize ?? config?.pageSize,
|
|
45
|
-
webhookSecret: secrets.webhookSecret
|
|
46
|
-
});
|
|
47
|
-
case "meeting-recorder.fathom":
|
|
48
|
-
if (!secrets.apiKey) {
|
|
49
|
-
throw new Error("Fathom apiKey is required.");
|
|
50
|
-
}
|
|
51
|
-
return new FathomMeetingRecorderProvider({
|
|
52
|
-
apiKey: secrets.apiKey,
|
|
53
|
-
baseUrl: config?.baseUrl,
|
|
54
|
-
includeTranscript: config?.includeTranscript,
|
|
55
|
-
includeSummary: config?.includeSummary,
|
|
56
|
-
includeActionItems: config?.includeActionItems,
|
|
57
|
-
includeCrmMatches: config?.includeCrmMatches,
|
|
58
|
-
triggeredFor: config?.triggeredFor,
|
|
59
|
-
maxPages: config?.maxPages,
|
|
60
|
-
webhookSecret: secrets.webhookSecret
|
|
61
|
-
});
|
|
62
|
-
default:
|
|
63
|
-
throw new Error(`Unsupported meeting recorder provider: ${integrationKey}`);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
// src/handlers/get-transcript.ts
|
|
68
|
-
async function getMeetingRecorderTranscript(input) {
|
|
69
|
-
const provider = createMeetingRecorderProvider(input);
|
|
70
|
-
return provider.getTranscript(input.params);
|
|
71
|
-
}
|
|
72
|
-
export {
|
|
73
|
-
getMeetingRecorderTranscript
|
|
74
|
-
};
|
|
2
|
+
import{FathomMeetingRecorderProvider as m}from"@contractspec/integration.providers-impls/impls/fathom-meeting-recorder";import{FirefliesMeetingRecorderProvider as M}from"@contractspec/integration.providers-impls/impls/fireflies-meeting-recorder";import{GranolaMeetingRecorderProvider as p}from"@contractspec/integration.providers-impls/impls/granola-meeting-recorder";import{TldvMeetingRecorderProvider as R}from"@contractspec/integration.providers-impls/impls/tldv-meeting-recorder";function d(t){let{integrationKey:a,secrets:e,config:r}=t;switch(a){case"meeting-recorder.granola":if(r?.transport==="mcp")return new p({transport:"mcp",mcpUrl:r?.mcpUrl,mcpHeaders:r?.mcpHeaders,mcpAccessToken:e.mcpAccessToken??e.apiKey,pageSize:r?.pageSize});if(!e.apiKey)throw Error("Granola apiKey is required for API transport.");return new p({apiKey:e.apiKey,baseUrl:r?.baseUrl,pageSize:r?.pageSize});case"meeting-recorder.tldv":if(!e.apiKey)throw Error("tl;dv apiKey is required.");return new R({apiKey:e.apiKey,baseUrl:r?.baseUrl,pageSize:r?.pageSize});case"meeting-recorder.fireflies":if(!e.apiKey)throw Error("Fireflies apiKey is required.");return new M({apiKey:e.apiKey,baseUrl:r?.baseUrl,pageSize:r?.transcriptsPageSize??r?.pageSize,webhookSecret:e.webhookSecret});case"meeting-recorder.fathom":if(!e.apiKey)throw Error("Fathom apiKey is required.");return new m({apiKey:e.apiKey,baseUrl:r?.baseUrl,includeTranscript:r?.includeTranscript,includeSummary:r?.includeSummary,includeActionItems:r?.includeActionItems,includeCrmMatches:r?.includeCrmMatches,triggeredFor:r?.triggeredFor,maxPages:r?.maxPages,webhookSecret:e.webhookSecret});default:throw Error(`Unsupported meeting recorder provider: ${a}`)}}async function I(t){return d(t).getTranscript(t.params)}export{I as getMeetingRecorderTranscript};
|
|
@@ -1,74 +1,2 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
|
|
3
|
-
import { FathomMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/fathom-meeting-recorder";
|
|
4
|
-
import { FirefliesMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/fireflies-meeting-recorder";
|
|
5
|
-
import { GranolaMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/granola-meeting-recorder";
|
|
6
|
-
import { TldvMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/tldv-meeting-recorder";
|
|
7
|
-
function createMeetingRecorderProvider(input) {
|
|
8
|
-
const { integrationKey, secrets, config } = input;
|
|
9
|
-
switch (integrationKey) {
|
|
10
|
-
case "meeting-recorder.granola":
|
|
11
|
-
if (config?.transport === "mcp") {
|
|
12
|
-
return new GranolaMeetingRecorderProvider({
|
|
13
|
-
transport: "mcp",
|
|
14
|
-
mcpUrl: config?.mcpUrl,
|
|
15
|
-
mcpHeaders: config?.mcpHeaders,
|
|
16
|
-
mcpAccessToken: secrets.mcpAccessToken ?? secrets.apiKey,
|
|
17
|
-
pageSize: config?.pageSize
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
if (!secrets.apiKey) {
|
|
21
|
-
throw new Error("Granola apiKey is required for API transport.");
|
|
22
|
-
}
|
|
23
|
-
return new GranolaMeetingRecorderProvider({
|
|
24
|
-
apiKey: secrets.apiKey,
|
|
25
|
-
baseUrl: config?.baseUrl,
|
|
26
|
-
pageSize: config?.pageSize
|
|
27
|
-
});
|
|
28
|
-
case "meeting-recorder.tldv":
|
|
29
|
-
if (!secrets.apiKey) {
|
|
30
|
-
throw new Error("tl;dv apiKey is required.");
|
|
31
|
-
}
|
|
32
|
-
return new TldvMeetingRecorderProvider({
|
|
33
|
-
apiKey: secrets.apiKey,
|
|
34
|
-
baseUrl: config?.baseUrl,
|
|
35
|
-
pageSize: config?.pageSize
|
|
36
|
-
});
|
|
37
|
-
case "meeting-recorder.fireflies":
|
|
38
|
-
if (!secrets.apiKey) {
|
|
39
|
-
throw new Error("Fireflies apiKey is required.");
|
|
40
|
-
}
|
|
41
|
-
return new FirefliesMeetingRecorderProvider({
|
|
42
|
-
apiKey: secrets.apiKey,
|
|
43
|
-
baseUrl: config?.baseUrl,
|
|
44
|
-
pageSize: config?.transcriptsPageSize ?? config?.pageSize,
|
|
45
|
-
webhookSecret: secrets.webhookSecret
|
|
46
|
-
});
|
|
47
|
-
case "meeting-recorder.fathom":
|
|
48
|
-
if (!secrets.apiKey) {
|
|
49
|
-
throw new Error("Fathom apiKey is required.");
|
|
50
|
-
}
|
|
51
|
-
return new FathomMeetingRecorderProvider({
|
|
52
|
-
apiKey: secrets.apiKey,
|
|
53
|
-
baseUrl: config?.baseUrl,
|
|
54
|
-
includeTranscript: config?.includeTranscript,
|
|
55
|
-
includeSummary: config?.includeSummary,
|
|
56
|
-
includeActionItems: config?.includeActionItems,
|
|
57
|
-
includeCrmMatches: config?.includeCrmMatches,
|
|
58
|
-
triggeredFor: config?.triggeredFor,
|
|
59
|
-
maxPages: config?.maxPages,
|
|
60
|
-
webhookSecret: secrets.webhookSecret
|
|
61
|
-
});
|
|
62
|
-
default:
|
|
63
|
-
throw new Error(`Unsupported meeting recorder provider: ${integrationKey}`);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
// src/handlers/list-meetings.ts
|
|
68
|
-
async function listMeetingRecorderMeetings(input) {
|
|
69
|
-
const provider = createMeetingRecorderProvider(input);
|
|
70
|
-
return provider.listMeetings(input.params);
|
|
71
|
-
}
|
|
72
|
-
export {
|
|
73
|
-
listMeetingRecorderMeetings
|
|
74
|
-
};
|
|
2
|
+
import{FathomMeetingRecorderProvider as p}from"@contractspec/integration.providers-impls/impls/fathom-meeting-recorder";import{FirefliesMeetingRecorderProvider as R}from"@contractspec/integration.providers-impls/impls/fireflies-meeting-recorder";import{GranolaMeetingRecorderProvider as a}from"@contractspec/integration.providers-impls/impls/granola-meeting-recorder";import{TldvMeetingRecorderProvider as i}from"@contractspec/integration.providers-impls/impls/tldv-meeting-recorder";function d(r){let{integrationKey:M,secrets:t,config:e}=r;switch(M){case"meeting-recorder.granola":if(e?.transport==="mcp")return new a({transport:"mcp",mcpUrl:e?.mcpUrl,mcpHeaders:e?.mcpHeaders,mcpAccessToken:t.mcpAccessToken??t.apiKey,pageSize:e?.pageSize});if(!t.apiKey)throw Error("Granola apiKey is required for API transport.");return new a({apiKey:t.apiKey,baseUrl:e?.baseUrl,pageSize:e?.pageSize});case"meeting-recorder.tldv":if(!t.apiKey)throw Error("tl;dv apiKey is required.");return new i({apiKey:t.apiKey,baseUrl:e?.baseUrl,pageSize:e?.pageSize});case"meeting-recorder.fireflies":if(!t.apiKey)throw Error("Fireflies apiKey is required.");return new R({apiKey:t.apiKey,baseUrl:e?.baseUrl,pageSize:e?.transcriptsPageSize??e?.pageSize,webhookSecret:t.webhookSecret});case"meeting-recorder.fathom":if(!t.apiKey)throw Error("Fathom apiKey is required.");return new p({apiKey:t.apiKey,baseUrl:e?.baseUrl,includeTranscript:e?.includeTranscript,includeSummary:e?.includeSummary,includeActionItems:e?.includeActionItems,includeCrmMatches:e?.includeCrmMatches,triggeredFor:e?.triggeredFor,maxPages:e?.maxPages,webhookSecret:t.webhookSecret});default:throw Error(`Unsupported meeting recorder provider: ${M}`)}}async function l(r){return d(r).listMeetings(r.params)}export{l as listMeetingRecorderMeetings};
|
|
@@ -1,115 +1,2 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
|
|
3
|
-
import { FathomMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/fathom-meeting-recorder";
|
|
4
|
-
import { FirefliesMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/fireflies-meeting-recorder";
|
|
5
|
-
import { GranolaMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/granola-meeting-recorder";
|
|
6
|
-
import { TldvMeetingRecorderProvider } from "@contractspec/integration.providers-impls/impls/tldv-meeting-recorder";
|
|
7
|
-
function createMeetingRecorderProvider(input) {
|
|
8
|
-
const { integrationKey, secrets, config } = input;
|
|
9
|
-
switch (integrationKey) {
|
|
10
|
-
case "meeting-recorder.granola":
|
|
11
|
-
if (config?.transport === "mcp") {
|
|
12
|
-
return new GranolaMeetingRecorderProvider({
|
|
13
|
-
transport: "mcp",
|
|
14
|
-
mcpUrl: config?.mcpUrl,
|
|
15
|
-
mcpHeaders: config?.mcpHeaders,
|
|
16
|
-
mcpAccessToken: secrets.mcpAccessToken ?? secrets.apiKey,
|
|
17
|
-
pageSize: config?.pageSize
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
if (!secrets.apiKey) {
|
|
21
|
-
throw new Error("Granola apiKey is required for API transport.");
|
|
22
|
-
}
|
|
23
|
-
return new GranolaMeetingRecorderProvider({
|
|
24
|
-
apiKey: secrets.apiKey,
|
|
25
|
-
baseUrl: config?.baseUrl,
|
|
26
|
-
pageSize: config?.pageSize
|
|
27
|
-
});
|
|
28
|
-
case "meeting-recorder.tldv":
|
|
29
|
-
if (!secrets.apiKey) {
|
|
30
|
-
throw new Error("tl;dv apiKey is required.");
|
|
31
|
-
}
|
|
32
|
-
return new TldvMeetingRecorderProvider({
|
|
33
|
-
apiKey: secrets.apiKey,
|
|
34
|
-
baseUrl: config?.baseUrl,
|
|
35
|
-
pageSize: config?.pageSize
|
|
36
|
-
});
|
|
37
|
-
case "meeting-recorder.fireflies":
|
|
38
|
-
if (!secrets.apiKey) {
|
|
39
|
-
throw new Error("Fireflies apiKey is required.");
|
|
40
|
-
}
|
|
41
|
-
return new FirefliesMeetingRecorderProvider({
|
|
42
|
-
apiKey: secrets.apiKey,
|
|
43
|
-
baseUrl: config?.baseUrl,
|
|
44
|
-
pageSize: config?.transcriptsPageSize ?? config?.pageSize,
|
|
45
|
-
webhookSecret: secrets.webhookSecret
|
|
46
|
-
});
|
|
47
|
-
case "meeting-recorder.fathom":
|
|
48
|
-
if (!secrets.apiKey) {
|
|
49
|
-
throw new Error("Fathom apiKey is required.");
|
|
50
|
-
}
|
|
51
|
-
return new FathomMeetingRecorderProvider({
|
|
52
|
-
apiKey: secrets.apiKey,
|
|
53
|
-
baseUrl: config?.baseUrl,
|
|
54
|
-
includeTranscript: config?.includeTranscript,
|
|
55
|
-
includeSummary: config?.includeSummary,
|
|
56
|
-
includeActionItems: config?.includeActionItems,
|
|
57
|
-
includeCrmMatches: config?.includeCrmMatches,
|
|
58
|
-
triggeredFor: config?.triggeredFor,
|
|
59
|
-
maxPages: config?.maxPages,
|
|
60
|
-
webhookSecret: secrets.webhookSecret
|
|
61
|
-
});
|
|
62
|
-
default:
|
|
63
|
-
throw new Error(`Unsupported meeting recorder provider: ${integrationKey}`);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
// src/handlers/webhook-handler.ts
|
|
68
|
-
async function handleMeetingRecorderWebhook(input) {
|
|
69
|
-
const { integrationKey, request } = input;
|
|
70
|
-
const provider = createMeetingRecorderProvider(input);
|
|
71
|
-
const rawBody = await request.text();
|
|
72
|
-
const parsedBody = safeJsonParse(rawBody);
|
|
73
|
-
const webhookRequest = {
|
|
74
|
-
headers: toHeaderRecord(request.headers),
|
|
75
|
-
rawBody,
|
|
76
|
-
parsedBody
|
|
77
|
-
};
|
|
78
|
-
if (provider.verifyWebhook) {
|
|
79
|
-
const verified = await provider.verifyWebhook(webhookRequest);
|
|
80
|
-
if (!verified) {
|
|
81
|
-
return new Response("Invalid webhook signature", { status: 401 });
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
const event = provider.parseWebhook ? await provider.parseWebhook(webhookRequest) : fallbackWebhookEvent(integrationKey, parsedBody ?? rawBody);
|
|
85
|
-
return new Response(JSON.stringify({ status: "ok", event }), {
|
|
86
|
-
status: 200,
|
|
87
|
-
headers: { "Content-Type": "application/json" }
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
function toHeaderRecord(headers) {
|
|
91
|
-
const record = {};
|
|
92
|
-
headers.forEach((value, key) => {
|
|
93
|
-
record[key] = value;
|
|
94
|
-
});
|
|
95
|
-
return record;
|
|
96
|
-
}
|
|
97
|
-
function safeJsonParse(payload) {
|
|
98
|
-
if (!payload)
|
|
99
|
-
return;
|
|
100
|
-
try {
|
|
101
|
-
return JSON.parse(payload);
|
|
102
|
-
} catch {
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
function fallbackWebhookEvent(providerKey, payload) {
|
|
107
|
-
return {
|
|
108
|
-
providerKey,
|
|
109
|
-
payload,
|
|
110
|
-
receivedAt: new Date().toISOString()
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
export {
|
|
114
|
-
handleMeetingRecorderWebhook
|
|
115
|
-
};
|
|
2
|
+
import{FathomMeetingRecorderProvider as h}from"@contractspec/integration.providers-impls/impls/fathom-meeting-recorder";import{FirefliesMeetingRecorderProvider as k}from"@contractspec/integration.providers-impls/impls/fireflies-meeting-recorder";import{GranolaMeetingRecorderProvider as i}from"@contractspec/integration.providers-impls/impls/granola-meeting-recorder";import{TldvMeetingRecorderProvider as R}from"@contractspec/integration.providers-impls/impls/tldv-meeting-recorder";function s(t){let{integrationKey:n,secrets:r,config:e}=t;switch(n){case"meeting-recorder.granola":if(e?.transport==="mcp")return new i({transport:"mcp",mcpUrl:e?.mcpUrl,mcpHeaders:e?.mcpHeaders,mcpAccessToken:r.mcpAccessToken??r.apiKey,pageSize:e?.pageSize});if(!r.apiKey)throw Error("Granola apiKey is required for API transport.");return new i({apiKey:r.apiKey,baseUrl:e?.baseUrl,pageSize:e?.pageSize});case"meeting-recorder.tldv":if(!r.apiKey)throw Error("tl;dv apiKey is required.");return new R({apiKey:r.apiKey,baseUrl:e?.baseUrl,pageSize:e?.pageSize});case"meeting-recorder.fireflies":if(!r.apiKey)throw Error("Fireflies apiKey is required.");return new k({apiKey:r.apiKey,baseUrl:e?.baseUrl,pageSize:e?.transcriptsPageSize??e?.pageSize,webhookSecret:r.webhookSecret});case"meeting-recorder.fathom":if(!r.apiKey)throw Error("Fathom apiKey is required.");return new h({apiKey:r.apiKey,baseUrl:e?.baseUrl,includeTranscript:e?.includeTranscript,includeSummary:e?.includeSummary,includeActionItems:e?.includeActionItems,includeCrmMatches:e?.includeCrmMatches,triggeredFor:e?.triggeredFor,maxPages:e?.maxPages,webhookSecret:r.webhookSecret});default:throw Error(`Unsupported meeting recorder provider: ${n}`)}}async function I(t){let{integrationKey:n,request:r}=t,e=s(t),o=await r.text(),d=b(o),a={headers:p(r.headers),rawBody:o,parsedBody:d};if(e.verifyWebhook){if(!await e.verifyWebhook(a))return new Response("Invalid webhook signature",{status:401})}let u=e.parseWebhook?await e.parseWebhook(a):v(n,d??o);return new Response(JSON.stringify({status:"ok",event:u}),{status:200,headers:{"Content-Type":"application/json"}})}function p(t){let n={};return t.forEach((r,e)=>{n[e]=r}),n}function b(t){if(!t)return;try{return JSON.parse(t)}catch{return}}function v(t,n){return{providerKey:t,payload:n,receivedAt:new Date().toISOString()}}export{I as handleMeetingRecorderWebhook};
|