@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.
Files changed (33) hide show
  1. package/.turbo/turbo-build.log +33 -33
  2. package/CHANGELOG.md +25 -0
  3. package/dist/browser/connection.sample.js +1 -123
  4. package/dist/browser/docs/index.js +16 -43
  5. package/dist/browser/docs/meeting-recorder-providers.docblock.js +16 -43
  6. package/dist/browser/example.js +1 -33
  7. package/dist/browser/handlers/create-provider.js +1 -67
  8. package/dist/browser/handlers/get-transcript.js +1 -73
  9. package/dist/browser/handlers/list-meetings.js +1 -73
  10. package/dist/browser/handlers/webhook-handler.js +1 -114
  11. package/dist/browser/index.js +18 -351
  12. package/dist/browser/meeting-recorder-providers.feature.js +1 -24
  13. package/dist/connection.sample.js +1 -123
  14. package/dist/docs/index.js +16 -43
  15. package/dist/docs/meeting-recorder-providers.docblock.js +16 -43
  16. package/dist/example.js +1 -33
  17. package/dist/handlers/create-provider.js +1 -67
  18. package/dist/handlers/get-transcript.js +1 -73
  19. package/dist/handlers/list-meetings.js +1 -73
  20. package/dist/handlers/webhook-handler.js +1 -114
  21. package/dist/index.js +18 -351
  22. package/dist/meeting-recorder-providers.feature.js +1 -24
  23. package/dist/node/connection.sample.js +1 -123
  24. package/dist/node/docs/index.js +16 -43
  25. package/dist/node/docs/meeting-recorder-providers.docblock.js +16 -43
  26. package/dist/node/example.js +1 -33
  27. package/dist/node/handlers/create-provider.js +1 -67
  28. package/dist/node/handlers/get-transcript.js +1 -73
  29. package/dist/node/handlers/list-meetings.js +1 -73
  30. package/dist/node/handlers/webhook-handler.js +1 -114
  31. package/dist/node/index.js +18 -351
  32. package/dist/node/meeting-recorder-providers.feature.js +1 -24
  33. package/package.json +8 -8
@@ -1,46 +1,19 @@
1
1
  // @bun
2
- // src/docs/meeting-recorder-providers.docblock.ts
3
- import { registerDocBlocks } from "@contractspec/lib.contracts-spec/docs";
4
- var blocks = [
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
- ` + `## Secrets and config
19
- ` + `- apiKey (all providers)
20
- ` + `- Granola MCP: set transport=mcp and provide mcpAccessToken (or apiKey fallback for MCP proxy).
21
- ` + `- webhookSecret (Fireflies and Fathom)
22
- ` + `- baseUrl overrides for sandbox or proxy setups
23
- ` + `- mcpUrl and mcpHeaders for custom MCP routing
24
- ` + `- pageSize / transcriptsPageSize for pagination
25
- ` + `- Fathom options: includeTranscript, includeSummary, includeActionItems, includeCrmMatches, triggeredFor
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
- ` + `## Guardrails
28
- ` + `- Keep secrets in a dedicated secret provider.
29
- ` + `- Verify webhook signatures before triggering workflows.
30
- ` + "- Treat transcript ingestion as async workflows, not inline writes."
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
- // src/docs/meeting-recorder-providers.docblock.ts
3
- import { registerDocBlocks } from "@contractspec/lib.contracts-spec/docs";
4
- var blocks = [
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
- ` + `## Secrets and config
19
- ` + `- apiKey (all providers)
20
- ` + `- Granola MCP: set transport=mcp and provide mcpAccessToken (or apiKey fallback for MCP proxy).
21
- ` + `- webhookSecret (Fireflies and Fathom)
22
- ` + `- baseUrl overrides for sandbox or proxy setups
23
- ` + `- mcpUrl and mcpHeaders for custom MCP routing
24
- ` + `- pageSize / transcriptsPageSize for pagination
25
- ` + `- Fathom options: includeTranscript, includeSummary, includeActionItems, includeCrmMatches, triggeredFor
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
- ` + `## Guardrails
28
- ` + `- Keep secrets in a dedicated secret provider.
29
- ` + `- Verify webhook signatures before triggering workflows.
30
- ` + "- Treat transcript ingestion as async workflows, not inline writes."
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
- // src/example.ts
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
- // src/handlers/create-provider.ts
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
- // src/handlers/create-provider.ts
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
- // src/handlers/create-provider.ts
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
- // src/handlers/create-provider.ts
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};