@koggitechorg/koggi-mcp-server 1.0.4 → 1.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -38,7 +38,8 @@ Ejemplo `mcp.json` (útil para ejecutar con orquestadores que esperan ese format
38
38
  "-y", "@koggitechorg/koggi-mcp-server"
39
39
  ],
40
40
  "env": {
41
- "EXTERNAL_URL": "https://external-qa-502142473966.us-central1.run.app"
41
+ "EXTERNAL_URL": "https://external-qa-502142473966.us-central1.run.app",
42
+ "API_TOKEN": "23slKk2..."
42
43
  }
43
44
  }
44
45
  },
@@ -54,7 +55,7 @@ tools = [
54
55
  connection_params=StdioServerParameters(
55
56
  command="npx",
56
57
  args=["-y", "@koggitechorg/koggi-mcp-server"],
57
- env={"EXTERNAL_URL": EXTERNAL_URL},
58
+ env={"EXTERNAL_URL": EXTERNAL_URL, "API_TOKEN": "..."},
58
59
  )
59
60
  ),
60
61
  ]
@@ -0,0 +1,11 @@
1
+ export async function errorHandler(func) {
2
+ try {
3
+ return await func();
4
+ }
5
+ catch (err) {
6
+ console.error('Error:', err);
7
+ return {
8
+ content: [{ type: "text", text: `Ocurrió un error: ${err?.message ?? String(err)}` }]
9
+ };
10
+ }
11
+ }
package/dist/index.js CHANGED
@@ -3,6 +3,7 @@ import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
3
3
  import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
4
4
  import { z } from "zod";
5
5
  import { generateSimulator } from "./handlers/simulator.js";
6
+ import { errorHandler } from "./error/error.handler.js";
6
7
  // Create an MCP server
7
8
  const server = new McpServer({
8
9
  name: "koggi-mcp-server",
@@ -19,15 +20,17 @@ server.tool("generateSimulator", "Genera un simulador financiero para un usuario
19
20
  income_updated: z.number().min(1, "Income is required"),
20
21
  observations: z.string().min(1, "Observations are required"),
21
22
  }, async ({ id_lead, email_requester, income_updated, observations }) => {
22
- const user = await generateSimulator({
23
- idLead: id_lead,
24
- ingresosActualizados: income_updated,
25
- observaciones: observations,
26
- emailRequest: email_requester,
23
+ return errorHandler(async () => {
24
+ const user = await generateSimulator({
25
+ idLead: id_lead,
26
+ ingresosActualizados: income_updated,
27
+ observaciones: observations,
28
+ emailRequest: email_requester,
29
+ });
30
+ return {
31
+ content: [{ type: "text", text: JSON.stringify(user, null, 2) }]
32
+ };
27
33
  });
28
- return {
29
- content: [{ type: "text", text: JSON.stringify(user, null, 2) }]
30
- };
31
34
  });
32
35
  // Start receiving messages on stdin and sending messages on stdout
33
36
  const transport = new StdioServerTransport();
@@ -2,11 +2,16 @@ import { CONFIG } from "../config/config.js";
2
2
  import { apiFetch } from "../utils/apiClient.js";
3
3
  async function validateRequestToken(func) {
4
4
  const token = CONFIG.token;
5
- const isValid = await validateToken(token);
6
- if (!isValid) {
7
- return [{ type: "text", text: "Invalid request token." }];
5
+ try {
6
+ const isValid = await validateToken(token);
7
+ if (!isValid) {
8
+ throw new Error("Invalid request token.");
9
+ }
10
+ return await func();
11
+ }
12
+ catch (err) {
13
+ return [{ type: "text", text: `Error al validar token o ejecutando la acción: ${err?.message ?? String(err)}` }];
8
14
  }
9
- return await func();
10
15
  }
11
16
  async function validateToken(token) {
12
17
  const response = await apiFetch(`/api/mcp/validate`, {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@koggitechorg/koggi-mcp-server",
3
- "version": "1.0.4",
3
+ "version": "1.0.5",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "bin": {
@@ -0,0 +1,10 @@
1
+ export async function errorHandler(func: Function) {
2
+ try {
3
+ return await func();
4
+ } catch (err: any) {
5
+ console.error('Error:', err);
6
+ return {
7
+ content: [{ type: "text", text: `Ocurrió un error: ${err?.message ?? String(err)}` }]
8
+ };
9
+ }
10
+ }
@@ -5,7 +5,7 @@ interface SimulatorData {
5
5
  [key: string]: any;
6
6
  }
7
7
 
8
- async function generateSimulator(data: SimulatorData): Promise<void> {
8
+ async function generateSimulator(data: SimulatorData): Promise<any> {
9
9
  return await validateRequestToken(async () => apiFetch(`/api/monitoreo-financiero/simulate-new-calculator-by-id-lead`, {
10
10
  method: "POST",
11
11
  body: JSON.stringify(data),
package/src/index.ts CHANGED
@@ -3,6 +3,7 @@ import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
3
3
  import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
4
4
  import { z } from "zod";
5
5
  import { generateSimulator } from "./handlers/simulator.js";
6
+ import { errorHandler } from "./error/error.handler.js";
6
7
 
7
8
  // Create an MCP server
8
9
  const server = new McpServer({
@@ -26,18 +27,22 @@ server.tool(
26
27
  observations: z.string().min(1, "Observations are required"),
27
28
  },
28
29
  async ({ id_lead, email_requester, income_updated, observations }) => {
29
- const user = await generateSimulator({
30
- idLead: id_lead,
31
- ingresosActualizados: income_updated,
32
- observaciones: observations,
33
- emailRequest: email_requester,
30
+ return errorHandler(async () => {
31
+ const user = await generateSimulator({
32
+ idLead: id_lead,
33
+ ingresosActualizados: income_updated,
34
+ observaciones: observations,
35
+ emailRequest: email_requester,
36
+ });
37
+
38
+ return {
39
+ content: [{ type: "text", text: JSON.stringify(user, null, 2) }]
40
+ };
34
41
  });
35
- return {
36
- content: [{ type: "text", text: JSON.stringify(user, null, 2) }]
37
- };
38
42
  }
39
43
  );
40
44
 
45
+
41
46
  // Start receiving messages on stdin and sending messages on stdout
42
47
  const transport = new StdioServerTransport();
43
48
  await server.connect(transport);
@@ -3,13 +3,18 @@ import { apiFetch } from "../utils/apiClient.js";
3
3
 
4
4
  async function validateRequestToken(func: Function) {
5
5
  const token = CONFIG.token;
6
- const isValid = await validateToken(token);
7
- if (!isValid ) {
8
- return [{ type: "text", text: "Invalid request token." }];
6
+ try {
7
+ const isValid = await validateToken(token);
8
+ if (!isValid) {
9
+ throw new Error("Invalid request token.");
10
+ }
11
+ return await func();
12
+ } catch (err: any) {
13
+ return [{ type: "text", text: `Error al validar token o ejecutando la acción: ${err?.message ?? String(err)}` }];
9
14
  }
10
- return await func();
11
15
  }
12
16
 
17
+
13
18
  async function validateToken(token: string): Promise<boolean> {
14
19
  const response = await apiFetch(`/api/mcp/validate`, {
15
20
  method: "POST",