Skip to main content
Glama

BMAD MCP Server

by Dali1789
he.tsโ€ข4.77 kB
import type { $ZodStringFormats } from "../core/checks.js"; import type * as errors from "../core/errors.js"; import * as util from "../core/util.js"; const error: () => errors.$ZodErrorMap = () => { const Sizable: Record<string, { unit: string; verb: string }> = { string: { unit: "ืื•ืชื™ื•ืช", verb: "ืœื›ืœื•ืœ" }, file: { unit: "ื‘ื™ื™ื˜ื™ื", verb: "ืœื›ืœื•ืœ" }, array: { unit: "ืคืจื™ื˜ื™ื", verb: "ืœื›ืœื•ืœ" }, set: { unit: "ืคืจื™ื˜ื™ื", verb: "ืœื›ืœื•ืœ" }, }; function getSizing(origin: string): { unit: string; verb: string } | null { return Sizable[origin] ?? null; } const parsedType = (data: any): string => { const t = typeof data; switch (t) { case "number": { return Number.isNaN(data) ? "NaN" : "number"; } case "object": { if (Array.isArray(data)) { return "array"; } if (data === null) { return "null"; } if (Object.getPrototypeOf(data) !== Object.prototype && data.constructor) { return data.constructor.name; } } } return t; }; const Nouns: { [k in $ZodStringFormats | (string & {})]?: string; } = { regex: "ืงืœื˜", email: "ื›ืชื•ื‘ืช ืื™ืžื™ื™ืœ", url: "ื›ืชื•ื‘ืช ืจืฉืช", emoji: "ืื™ืžื•ื’'ื™", uuid: "UUID", uuidv4: "UUIDv4", uuidv6: "UUIDv6", nanoid: "nanoid", guid: "GUID", cuid: "cuid", cuid2: "cuid2", ulid: "ULID", xid: "XID", ksuid: "KSUID", datetime: "ืชืืจื™ืš ื•ื–ืžืŸ ISO", date: "ืชืืจื™ืš ISO", time: "ื–ืžืŸ ISO", duration: "ืžืฉืš ื–ืžืŸ ISO", ipv4: "ื›ืชื•ื‘ืช IPv4", ipv6: "ื›ืชื•ื‘ืช IPv6", cidrv4: "ื˜ื•ื•ื— IPv4", cidrv6: "ื˜ื•ื•ื— IPv6", base64: "ืžื—ืจื•ื–ืช ื‘ื‘ืกื™ืก 64", base64url: "ืžื—ืจื•ื–ืช ื‘ื‘ืกื™ืก 64 ืœื›ืชื•ื‘ื•ืช ืจืฉืช", json_string: "ืžื—ืจื•ื–ืช JSON", e164: "ืžืกืคืจ E.164", jwt: "JWT", template_literal: "ืงืœื˜", }; return (issue) => { switch (issue.code) { case "invalid_type": return `ืงืœื˜ ืœื ืชืงื™ืŸ: ืฆืจื™ืš ${issue.expected}, ื”ืชืงื‘ืœ ${parsedType(issue.input)}`; // return `Invalid input: expected ${issue.expected}, received ${util.getParsedType(issue.input)}`; case "invalid_value": if (issue.values.length === 1) return `ืงืœื˜ ืœื ืชืงื™ืŸ: ืฆืจื™ืš ${util.stringifyPrimitive(issue.values[0])}`; return `ืงืœื˜ ืœื ืชืงื™ืŸ: ืฆืจื™ืš ืื—ืช ืžื”ืืคืฉืจื•ื™ื•ืช ${util.joinValues(issue.values, "|")}`; case "too_big": { const adj = issue.inclusive ? "<=" : "<"; const sizing = getSizing(issue.origin); if (sizing) return `ื’ื“ื•ืœ ืžื“ื™: ${issue.origin ?? "value"} ืฆืจื™ืš ืœื”ื™ื•ืช ${adj}${issue.maximum.toString()} ${sizing.unit ?? "elements"}`; return `ื’ื“ื•ืœ ืžื“ื™: ${issue.origin ?? "value"} ืฆืจื™ืš ืœื”ื™ื•ืช ${adj}${issue.maximum.toString()}`; } case "too_small": { const adj = issue.inclusive ? ">=" : ">"; const sizing = getSizing(issue.origin); if (sizing) { return `ืงื˜ืŸ ืžื“ื™: ${issue.origin} ืฆืจื™ืš ืœื”ื™ื•ืช ${adj}${issue.minimum.toString()} ${sizing.unit}`; } return `ืงื˜ืŸ ืžื“ื™: ${issue.origin} ืฆืจื™ืš ืœื”ื™ื•ืช ${adj}${issue.minimum.toString()}`; } case "invalid_format": { const _issue = issue as errors.$ZodStringFormatIssues; if (_issue.format === "starts_with") return `ืžื—ืจื•ื–ืช ืœื ืชืงื™ื ื”: ื—ื™ื™ื‘ืช ืœื”ืชื—ื™ืœ ื‘"${_issue.prefix}"`; if (_issue.format === "ends_with") return `ืžื—ืจื•ื–ืช ืœื ืชืงื™ื ื”: ื—ื™ื™ื‘ืช ืœื”ืกืชื™ื™ื ื‘ "${_issue.suffix}"`; if (_issue.format === "includes") return `ืžื—ืจื•ื–ืช ืœื ืชืงื™ื ื”: ื—ื™ื™ื‘ืช ืœื›ืœื•ืœ "${_issue.includes}"`; if (_issue.format === "regex") return `ืžื—ืจื•ื–ืช ืœื ืชืงื™ื ื”: ื—ื™ื™ื‘ืช ืœื”ืชืื™ื ืœืชื‘ื ื™ืช ${_issue.pattern}`; return `${Nouns[_issue.format] ?? issue.format} ืœื ืชืงื™ืŸ`; } case "not_multiple_of": return `ืžืกืคืจ ืœื ืชืงื™ืŸ: ื—ื™ื™ื‘ ืœื”ื™ื•ืช ืžื›ืคืœื” ืฉืœ ${issue.divisor}`; case "unrecognized_keys": return `ืžืคืชื—${issue.keys.length > 1 ? "ื•ืช" : ""} ืœื ืžื–ื•ื”${issue.keys.length > 1 ? "ื™ื" : "ื”"}: ${util.joinValues(issue.keys, ", ")}`; case "invalid_key": return `ืžืคืชื— ืœื ืชืงื™ืŸ ื‘${issue.origin}`; case "invalid_union": return "ืงืœื˜ ืœื ืชืงื™ืŸ"; case "invalid_element": return `ืขืจืš ืœื ืชืงื™ืŸ ื‘${issue.origin}`; default: return `ืงืœื˜ ืœื ืชืงื™ืŸ`; } }; }; export default function (): { localeError: errors.$ZodErrorMap } { return { localeError: error(), }; }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Dali1789/bmad-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server