@gala-chain/launchpad-mcp-server 1.14.2 → 1.14.3

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 (63) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/dist/generated/version.d.ts +1 -1
  3. package/dist/generated/version.js +1 -1
  4. package/dist/tools/pools/fetchPools.js +1 -1
  5. package/dist/tools/pools/fetchPools.js.map +1 -1
  6. package/package.json +1 -1
  7. package/docs/AI-AGENT-PATTERNS.md +0 -555
  8. package/docs/CONSTRAINTS-REFERENCE.md +0 -454
  9. package/docs/PROMPT-TOOL-MAPPING.md +0 -352
  10. package/docs/examples/default-values-pattern.md +0 -240
  11. package/docs/examples/tool-factory-pattern.md +0 -217
  12. package/jest.config.js +0 -94
  13. package/src/__tests__/integration/fetchTokenDetails.integration.test.ts +0 -258
  14. package/src/__tests__/integration/poolTools.integration.test.ts +0 -185
  15. package/src/constants/mcpToolNames.ts +0 -141
  16. package/src/index.ts +0 -19
  17. package/src/prompts/__tests__/promptStructure.test.ts +0 -114
  18. package/src/prompts/__tests__/registry.test.ts +0 -145
  19. package/src/prompts/analysis.ts +0 -429
  20. package/src/prompts/index.ts +0 -127
  21. package/src/prompts/portfolio.ts +0 -242
  22. package/src/prompts/trading.ts +0 -191
  23. package/src/prompts/utility.ts +0 -43
  24. package/src/prompts/utils/workflowTemplates.ts +0 -344
  25. package/src/schemas/common-schemas.ts +0 -393
  26. package/src/scripts/test-all-prompts.ts +0 -184
  27. package/src/server.ts +0 -241
  28. package/src/tools/balance/index.ts +0 -174
  29. package/src/tools/creation/index.ts +0 -182
  30. package/src/tools/index.ts +0 -80
  31. package/src/tools/pools/fetchAllPools.ts +0 -47
  32. package/src/tools/pools/fetchAllPriceHistory.ts +0 -103
  33. package/src/tools/pools/fetchPoolDetails.ts +0 -27
  34. package/src/tools/pools/fetchPoolDetailsForCalculation.ts +0 -22
  35. package/src/tools/pools/fetchPools.ts +0 -47
  36. package/src/tools/pools/fetchPriceHistory.ts +0 -108
  37. package/src/tools/pools/fetchTokenDetails.ts +0 -77
  38. package/src/tools/pools/index.ts +0 -246
  39. package/src/tools/social/index.ts +0 -64
  40. package/src/tools/trading/index.ts +0 -605
  41. package/src/tools/transfers/index.ts +0 -75
  42. package/src/tools/utils/clearCache.ts +0 -36
  43. package/src/tools/utils/createWallet.ts +0 -19
  44. package/src/tools/utils/explainSdkUsage.ts +0 -1277
  45. package/src/tools/utils/getAddress.ts +0 -12
  46. package/src/tools/utils/getCacheInfo.ts +0 -14
  47. package/src/tools/utils/getConfig.ts +0 -11
  48. package/src/tools/utils/getEthereumAddress.ts +0 -12
  49. package/src/tools/utils/getUrlByTokenName.ts +0 -12
  50. package/src/tools/utils/getVersion.ts +0 -25
  51. package/src/tools/utils/index.ts +0 -27
  52. package/src/tools/utils/isTokenGraduated.ts +0 -16
  53. package/src/types/mcp.ts +0 -72
  54. package/src/utils/__tests__/validation.test.ts +0 -147
  55. package/src/utils/constraints.ts +0 -155
  56. package/src/utils/default-values.ts +0 -208
  57. package/src/utils/error-handler.ts +0 -69
  58. package/src/utils/error-templates.ts +0 -273
  59. package/src/utils/response-formatter.ts +0 -51
  60. package/src/utils/tool-factory.ts +0 -257
  61. package/src/utils/tool-registry.ts +0 -296
  62. package/src/utils/validation.ts +0 -336
  63. package/tsconfig.json +0 -23
@@ -1,12 +0,0 @@
1
- /**
2
- * Get Address Tool (45% code reduction via factory pattern)
3
- */
4
-
5
- import { createNoParamTool } from '../../utils/tool-factory.js';
6
-
7
- export const getAddressTool = createNoParamTool({
8
- name: 'gala_launchpad_get_address',
9
- description: 'Get the GalaChain address format (eth|0x...) for the authenticated wallet.',
10
- handler: (sdk) => sdk.getAddress(),
11
- resultKey: 'address',
12
- });
@@ -1,14 +0,0 @@
1
- /**
2
- * Get Cache Info Tool
3
- *
4
- * Returns statistics about the token metadata cache for monitoring and debugging.
5
- * The cache persists entire MCP server lifetime and accumulates metadata across conversations.
6
- */
7
-
8
- import { createNoParamTool } from '../../utils/tool-factory.js';
9
-
10
- export const getCacheInfoTool = createNoParamTool({
11
- name: 'gala_launchpad_get_cache_info',
12
- description: 'Get token metadata cache statistics including total tokens cached, cache size in bytes, and timestamp of oldest entry. The cache persists for the entire MCP server lifetime.',
13
- handler: (sdk) => sdk.getCacheInfo(),
14
- });
@@ -1,11 +0,0 @@
1
- /**
2
- * Get Config Tool (45% code reduction via factory pattern)
3
- */
4
-
5
- import { createNoParamTool } from '../../utils/tool-factory.js';
6
-
7
- export const getConfigTool = createNoParamTool({
8
- name: 'gala_launchpad_get_config',
9
- description: 'Get the current SDK configuration including environment, base URLs, timeouts, feature flags, and effective slippage tolerance factors.',
10
- handler: (sdk) => sdk.getConfig(),
11
- });
@@ -1,12 +0,0 @@
1
- /**
2
- * Get Ethereum Address Tool (45% code reduction via factory pattern)
3
- */
4
-
5
- import { createNoParamTool } from '../../utils/tool-factory.js';
6
-
7
- export const getEthereumAddressTool = createNoParamTool({
8
- name: 'gala_launchpad_get_ethereum_address',
9
- description: 'Get the standard Ethereum address format (0x...) for the authenticated wallet.',
10
- handler: (sdk) => sdk.getEthereumAddress(),
11
- resultKey: 'address',
12
- });
@@ -1,12 +0,0 @@
1
- /**
2
- * Get URL by Token Name Tool (73% code reduction via factory pattern)
3
- */
4
-
5
- import { createResolutionTool } from '../../utils/tool-factory.js';
6
-
7
- export const getUrlByTokenNameTool = createResolutionTool({
8
- name: 'gala_launchpad_get_url_by_token_name',
9
- description: 'Get the launchpad frontend URL for a specific token. Returns the complete URL for viewing/trading the token in the web interface.',
10
- resolver: async (sdk, tokenName) => sdk.getUrlByTokenName(tokenName),
11
- resultKey: 'url',
12
- });
@@ -1,25 +0,0 @@
1
- /**
2
- * Get Version Tool
3
- *
4
- * Returns version information for both the SDK and MCP server.
5
- * Both versions are dynamically read from their respective package.json files.
6
- */
7
-
8
- import { createNoParamTool } from '../../utils/tool-factory.js';
9
- import { MCP_SERVER_VERSION } from '../../generated/version.js';
10
-
11
- export const getVersionTool = createNoParamTool({
12
- name: 'gala_launchpad_get_version',
13
- description: 'Get SDK and MCP server version information. Returns both versions which are dynamically read from package.json files.',
14
- handler: async (sdk) => {
15
- const sdkVersion = sdk.getVersion();
16
- const mcpVersion = MCP_SERVER_VERSION;
17
- const timestamp = new Date().toISOString();
18
-
19
- return {
20
- sdk: sdkVersion,
21
- mcpServer: mcpVersion,
22
- timestamp,
23
- };
24
- },
25
- });
@@ -1,27 +0,0 @@
1
- /**
2
- * Utility Tools
3
- */
4
-
5
- import { createWalletTool } from './createWallet.js';
6
- import { getAddressTool } from './getAddress.js';
7
- import { getEthereumAddressTool } from './getEthereumAddress.js';
8
- import { getConfigTool } from './getConfig.js';
9
- import { getUrlByTokenNameTool } from './getUrlByTokenName.js';
10
- import { explainSdkUsageTool } from './explainSdkUsage.js';
11
- import { isTokenGraduatedTool } from './isTokenGraduated.js';
12
- import { getCacheInfoTool } from './getCacheInfo.js';
13
- import { clearCacheTool } from './clearCache.js';
14
- import { getVersionTool } from './getVersion.js';
15
-
16
- export const utilityTools = [
17
- createWalletTool,
18
- getAddressTool,
19
- getEthereumAddressTool,
20
- getConfigTool,
21
- getUrlByTokenNameTool,
22
- explainSdkUsageTool,
23
- isTokenGraduatedTool,
24
- getCacheInfoTool,
25
- clearCacheTool,
26
- getVersionTool,
27
- ];
@@ -1,16 +0,0 @@
1
- /**
2
- * Check if token has graduated from bonding curve (73% code reduction via factory pattern)
3
- */
4
-
5
- import { createResolutionTool } from '../../utils/tool-factory.js';
6
-
7
- export const isTokenGraduatedTool = createResolutionTool({
8
- name: 'gala_launchpad_is_token_graduated',
9
- description: `Check if a token has completed the bonding curve phase and graduated to full DEX trading.
10
-
11
- RETURNS: Boolean indicating if pool saleStatus is "Completed"
12
-
13
- USAGE: Useful for conditional logic before attempting graduation or checking pool state.`,
14
- resolver: (sdk, tokenName) => sdk.isTokenGraduated(tokenName),
15
- resultKey: 'graduated',
16
- });
package/src/types/mcp.ts DELETED
@@ -1,72 +0,0 @@
1
- /**
2
- * MCP Protocol Types
3
- */
4
-
5
- import type { LaunchpadSDK } from '@gala-chain/launchpad-sdk';
6
-
7
- /**
8
- * MCP Tool Definition
9
- */
10
- export interface MCPTool {
11
- name: string;
12
- description: string;
13
- inputSchema: {
14
- type: 'object';
15
- properties: Record<string, any>;
16
- required?: string[];
17
- };
18
- handler: (sdk: LaunchpadSDK, args: any) => Promise<MCPToolResponse>;
19
- }
20
-
21
- /**
22
- * MCP Tool Response
23
- */
24
- export interface MCPToolResponse {
25
- content: Array<{
26
- type: 'text' | 'image' | 'resource';
27
- text?: string;
28
- data?: string;
29
- mimeType?: string;
30
- }>;
31
- isError?: boolean;
32
- }
33
-
34
- /**
35
- * Tool execution context
36
- */
37
- export interface ToolContext {
38
- sdk: LaunchpadSDK;
39
- debug: boolean;
40
- }
41
-
42
- /**
43
- * MCP Prompt Argument Definition
44
- */
45
- export interface MCPPromptArgument {
46
- name: string;
47
- description: string;
48
- required: boolean;
49
- }
50
-
51
- /**
52
- * MCP Prompt Definition
53
- */
54
- export interface MCPPrompt {
55
- name: string;
56
- description: string;
57
- arguments?: MCPPromptArgument[];
58
- handler: (args: Record<string, string>) => PromptMessage[];
59
- }
60
-
61
- /**
62
- * Prompt Message (from MCP spec)
63
- */
64
- export interface PromptMessage {
65
- role: 'user' | 'assistant';
66
- content: {
67
- type: 'text' | 'image' | 'resource';
68
- text?: string;
69
- data?: string;
70
- mimeType?: string;
71
- };
72
- }
@@ -1,147 +0,0 @@
1
- /**
2
- * Validation Utilities Tests
3
- *
4
- * Tests for input validation functions
5
- */
6
-
7
- import {
8
- validateTokenName,
9
- validateNumericAmount,
10
- validateSlippage,
11
- validateAddress,
12
- validateTokenSymbol,
13
- validatePaginationLimit,
14
- validateTokenList,
15
- safeValidate,
16
- ValidationError,
17
- } from '../validation';
18
-
19
- describe('Validation Utilities', () => {
20
- describe('validateTokenName()', () => {
21
- it('should accept valid token names', () => {
22
- expect(() => validateTokenName('anime')).not.toThrow();
23
- expect(() => validateTokenName('test123')).not.toThrow();
24
- expect(() => validateTokenName('my-token')).not.toThrow();
25
- expect(() => validateTokenName('my_token')).not.toThrow();
26
- expect(() => validateTokenName('TEST-123')).not.toThrow();
27
- });
28
-
29
- it('should reject invalid token names', () => {
30
- expect(() => validateTokenName('')).toThrow(ValidationError);
31
- expect(() => validateTokenName('a')).toThrow(ValidationError);
32
- expect(() => validateTokenName('verylongtokennamethatexceedstwentycharacters')).toThrow(ValidationError);
33
- expect(() => validateTokenName('token@#$')).toThrow(ValidationError);
34
- expect(() => validateTokenName('token with spaces')).toThrow(ValidationError);
35
- });
36
- });
37
-
38
- describe('validateNumericAmount()', () => {
39
- it('should accept valid numeric amounts', () => {
40
- expect(() => validateNumericAmount('100', 'amount')).not.toThrow();
41
- expect(() => validateNumericAmount('0.5', 'amount')).not.toThrow();
42
- expect(() => validateNumericAmount('99999.99', 'amount')).not.toThrow();
43
- expect(() => validateNumericAmount(100, 'amount')).not.toThrow();
44
- });
45
-
46
- it('should reject invalid numeric amounts', () => {
47
- expect(() => validateNumericAmount('', 'amount')).toThrow(ValidationError);
48
- expect(() => validateNumericAmount('abc', 'amount')).toThrow(ValidationError);
49
- expect(() => validateNumericAmount('-5', 'amount')).toThrow(ValidationError);
50
- expect(() => validateNumericAmount('0', 'amount')).toThrow(ValidationError);
51
- expect(() => validateNumericAmount(Infinity, 'amount')).toThrow(ValidationError);
52
- });
53
- });
54
-
55
- describe('validateSlippage()', () => {
56
- it('should accept valid slippage values', () => {
57
- expect(() => validateSlippage('1')).not.toThrow();
58
- expect(() => validateSlippage('0.5')).not.toThrow();
59
- expect(() => validateSlippage('50')).not.toThrow();
60
- expect(() => validateSlippage('0.01')).not.toThrow();
61
- expect(() => validateSlippage('100')).not.toThrow();
62
- });
63
-
64
- it('should reject invalid slippage values', () => {
65
- expect(() => validateSlippage('0')).toThrow(ValidationError);
66
- expect(() => validateSlippage('0.005')).toThrow(ValidationError);
67
- expect(() => validateSlippage('101')).toThrow(ValidationError);
68
- expect(() => validateSlippage('-1')).toThrow(ValidationError);
69
- });
70
- });
71
-
72
- describe('validateAddress()', () => {
73
- it('should accept valid addresses', () => {
74
- expect(() => validateAddress('eth|0x1234567890abcdef1234567890abcdef12345678')).not.toThrow();
75
- expect(() => validateAddress('0x1234567890abcdef1234567890abcdef12345678')).not.toThrow();
76
- expect(() => validateAddress('0xABCDEF1234567890abcdef1234567890ABCDEF12')).not.toThrow();
77
- });
78
-
79
- it('should reject invalid addresses', () => {
80
- expect(() => validateAddress('')).toThrow(ValidationError);
81
- expect(() => validateAddress('invalid')).toThrow(ValidationError);
82
- expect(() => validateAddress('0x123')).toThrow(ValidationError);
83
- expect(() => validateAddress('eth|123')).toThrow(ValidationError);
84
- });
85
- });
86
-
87
- describe('validateTokenSymbol()', () => {
88
- it('should accept valid symbols', () => {
89
- expect(() => validateTokenSymbol('GALA')).not.toThrow();
90
- expect(() => validateTokenSymbol('TEST')).not.toThrow();
91
- expect(() => validateTokenSymbol('A')).not.toThrow();
92
- expect(() => validateTokenSymbol('ABCDEFGH')).not.toThrow();
93
- });
94
-
95
- it('should reject invalid symbols', () => {
96
- expect(() => validateTokenSymbol('')).toThrow(ValidationError);
97
- expect(() => validateTokenSymbol('test')).toThrow(ValidationError);
98
- expect(() => validateTokenSymbol('TOOLONG123')).toThrow(ValidationError);
99
- expect(() => validateTokenSymbol('TEST123')).toThrow(ValidationError);
100
- });
101
- });
102
-
103
- describe('validatePaginationLimit()', () => {
104
- it('should accept valid limits', () => {
105
- expect(() => validatePaginationLimit('1')).not.toThrow();
106
- expect(() => validatePaginationLimit('20')).not.toThrow();
107
- expect(() => validatePaginationLimit('100')).not.toThrow();
108
- expect(() => validatePaginationLimit(50)).not.toThrow();
109
- });
110
-
111
- it('should reject invalid limits', () => {
112
- expect(() => validatePaginationLimit('0')).toThrow(ValidationError);
113
- expect(() => validatePaginationLimit('101')).toThrow(ValidationError);
114
- expect(() => validatePaginationLimit('-1')).toThrow(ValidationError);
115
- expect(() => validatePaginationLimit('abc')).toThrow(ValidationError);
116
- });
117
- });
118
-
119
- describe('validateTokenList()', () => {
120
- it('should accept valid token lists', () => {
121
- const result1 = validateTokenList('anime,test,dragon');
122
- expect(result1).toEqual(['anime', 'test', 'dragon']);
123
-
124
- const result2 = validateTokenList('token1');
125
- expect(result2).toEqual(['token1']);
126
- });
127
-
128
- it('should reject invalid token lists', () => {
129
- expect(() => validateTokenList('')).toThrow(ValidationError);
130
- expect(() => validateTokenList('token1,invalid@#$')).toThrow(ValidationError);
131
- });
132
- });
133
-
134
- describe('safeValidate()', () => {
135
- it('should return success for valid input', () => {
136
- const result = safeValidate(() => validateTokenName('anime'));
137
- expect(result.success).toBe(true);
138
- expect(result.error).toBeUndefined();
139
- });
140
-
141
- it('should return error for invalid input', () => {
142
- const result = safeValidate(() => validateTokenName('invalid@#$'));
143
- expect(result.success).toBe(false);
144
- expect(result.error).toBeDefined();
145
- });
146
- });
147
- });
@@ -1,155 +0,0 @@
1
- /**
2
- * Central Constraints Reference
3
- *
4
- * This file documents the pagination limits enforced by the SDK for different operations.
5
- * These constants are imported from the SDK's internal constraint definitions and serve
6
- * as the single source of truth for MCP tool schema validation.
7
- *
8
- * IMPORTANT: Always keep these in sync with the SDK's actual constraints:
9
- * - TRADE_CONSTRAINTS.PAGINATION.MAX_LIMIT (trade.dto.ts)
10
- * - USER_CONSTRAINTS.PAGINATION.MAX_LIMIT (user.dto.ts)
11
- * - PAGINATION_CONSTRAINTS.MAX_LIMIT (launchpad.dto.ts)
12
- * - COMMENT_CONSTRAINTS.PAGINATION.MAX_LIMIT (comment.dto.ts)
13
- */
14
-
15
- /**
16
- * MCP Tool Constraint Constants
17
- *
18
- * These values MUST match the SDK's internal constraint definitions to prevent
19
- * validation errors when AI agents use the MCP tools.
20
- */
21
- export const MCP_CONSTRAINTS = {
22
- /**
23
- * Trade operations limit (fetchTrades)
24
- * Source: TRADE_CONSTRAINTS.PAGINATION.MAX_LIMIT
25
- * SDK File: packages/sdk/src/types/trade.dto.ts:331
26
- */
27
- TRADE_LIMIT: 20,
28
-
29
- /**
30
- * User operations limit (fetchTokensHeld, fetchTokensCreated)
31
- * Source: USER_CONSTRAINTS.PAGINATION.MAX_LIMIT
32
- * SDK File: packages/sdk/src/types/user.dto.ts:297
33
- */
34
- USER_LIMIT: 20,
35
-
36
- /**
37
- * General pool operations limit (fetchPools)
38
- * Source: PAGINATION_CONSTRAINTS.MAX_LIMIT
39
- * SDK File: packages/sdk/src/types/launchpad.dto.ts:587
40
- */
41
- POOL_LIMIT: 100,
42
-
43
- /**
44
- * Comment operations limit (fetchComments)
45
- * Source: COMMENT_CONSTRAINTS.PAGINATION.MAX_LIMIT
46
- * SDK File: packages/sdk/src/types/comment.dto.ts:149
47
- */
48
- COMMENT_LIMIT: 50,
49
-
50
- /**
51
- * Price history operations limit (fetchPriceHistory, fetchAllPriceHistory)
52
- * Source: DEX Backend API /price-oracle/fetch-price endpoint
53
- * Maximum enforced by DEX API
54
- */
55
- PRICE_HISTORY_LIMIT: 50,
56
-
57
- /**
58
- * Minimum limit for all pagination operations
59
- */
60
- MIN_LIMIT: 1,
61
-
62
- /**
63
- * Minimum page number for all pagination operations
64
- */
65
- MIN_PAGE: 1,
66
-
67
- /**
68
- * Maximum page number for all pagination operations
69
- */
70
- MAX_PAGE: 1000,
71
- } as const;
72
-
73
- /**
74
- * Constraint usage reference for MCP tool developers
75
- *
76
- * @example
77
- * // Trading tools (fetchTrades)
78
- * limit: {
79
- * type: 'number',
80
- * minimum: MCP_CONSTRAINTS.MIN_LIMIT,
81
- * maximum: MCP_CONSTRAINTS.TRADE_LIMIT, // 20
82
- * description: `Results per page (default: 20, maximum: ${MCP_CONSTRAINTS.TRADE_LIMIT})`
83
- * }
84
- *
85
- * @example
86
- * // Balance/User tools (fetchTokensHeld, fetchTokensCreated)
87
- * limit: {
88
- * type: 'number',
89
- * minimum: MCP_CONSTRAINTS.MIN_LIMIT,
90
- * maximum: MCP_CONSTRAINTS.USER_LIMIT, // 20
91
- * description: `Results per page (default: 20, maximum: ${MCP_CONSTRAINTS.USER_LIMIT})`
92
- * }
93
- *
94
- * @example
95
- * // Pool tools (fetchPools)
96
- * limit: {
97
- * type: 'number',
98
- * minimum: MCP_CONSTRAINTS.MIN_LIMIT,
99
- * maximum: MCP_CONSTRAINTS.POOL_LIMIT, // 100
100
- * description: `Results per page (default: 20, maximum: ${MCP_CONSTRAINTS.POOL_LIMIT})`
101
- * }
102
- *
103
- * @example
104
- * // Social tools (fetchComments)
105
- * limit: {
106
- * type: 'number',
107
- * minimum: MCP_CONSTRAINTS.MIN_LIMIT,
108
- * maximum: MCP_CONSTRAINTS.COMMENT_LIMIT, // 50
109
- * description: `Results per page (default: 20, maximum: ${MCP_CONSTRAINTS.COMMENT_LIMIT})`
110
- * }
111
- */
112
-
113
- /**
114
- * Validation helper to check if a limit value is valid for a specific operation type
115
- *
116
- * @param limit The limit value to validate
117
- * @param operationType The type of operation ('trade' | 'user' | 'pool' | 'comment' | 'priceHistory')
118
- * @returns true if valid, false otherwise
119
- */
120
- export function isValidLimit(
121
- limit: number,
122
- operationType: 'trade' | 'user' | 'pool' | 'comment' | 'priceHistory'
123
- ): boolean {
124
- if (!Number.isInteger(limit) || limit < MCP_CONSTRAINTS.MIN_LIMIT) {
125
- return false;
126
- }
127
-
128
- const maxLimits = {
129
- trade: MCP_CONSTRAINTS.TRADE_LIMIT,
130
- user: MCP_CONSTRAINTS.USER_LIMIT,
131
- pool: MCP_CONSTRAINTS.POOL_LIMIT,
132
- comment: MCP_CONSTRAINTS.COMMENT_LIMIT,
133
- priceHistory: MCP_CONSTRAINTS.PRICE_HISTORY_LIMIT,
134
- };
135
-
136
- return limit <= maxLimits[operationType];
137
- }
138
-
139
- /**
140
- * Get the maximum limit for a specific operation type
141
- *
142
- * @param operationType The type of operation
143
- * @returns The maximum limit value
144
- */
145
- export function getMaxLimit(operationType: 'trade' | 'user' | 'pool' | 'comment' | 'priceHistory'): number {
146
- const maxLimits = {
147
- trade: MCP_CONSTRAINTS.TRADE_LIMIT,
148
- user: MCP_CONSTRAINTS.USER_LIMIT,
149
- pool: MCP_CONSTRAINTS.POOL_LIMIT,
150
- comment: MCP_CONSTRAINTS.COMMENT_LIMIT,
151
- priceHistory: MCP_CONSTRAINTS.PRICE_HISTORY_LIMIT,
152
- };
153
-
154
- return maxLimits[operationType];
155
- }