From 604a869096f8953fb37bc81b8189842402dbb981 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Yusufhan=20Sa=C3=A7ak?= Date: Fri, 10 Apr 2026 11:55:47 +0300 Subject: [PATCH] feat(publisher): copy version from package.json and prefer mcpName in init - Copy `version` from package.json to both top-level and package version fields, falling back to "1.0.0" when unavailable (#736) - Prefer `mcpName` over `name` from package.json when detecting server name, as the server name must match mcpName (#737) --- cmd/publisher/commands/init.go | 32 +++++++++++++++++++++++++++++--- 1 file changed, 29 insertions(+), 3 deletions(-) diff --git a/cmd/publisher/commands/init.go b/cmd/publisher/commands/init.go index 27cb664ac..69f2055e2 100644 --- a/cmd/publisher/commands/init.go +++ b/cmd/publisher/commands/init.go @@ -27,7 +27,10 @@ func InitCommand() error { // Try to detect values from environment name := detectServerName(subfolder) description := detectDescription() - version := "1.0.0" + version := getVersionFromPackageJSON() + if version == "" { + version = "1.0.0" + } repoURL := detectRepoURL() repoSource := MethodGitHub if repoURL != "" && !strings.Contains(repoURL, "github.com") { @@ -140,9 +143,13 @@ func getNameFromPackageJSON() string { return "" } - name, ok := pkg["name"].(string) + // Prefer mcpName over name, as the server name must match mcpName + name, ok := pkg["mcpName"].(string) if !ok || name == "" { - return "" + name, ok = pkg["name"].(string) + if !ok || name == "" { + return "" + } } // Convert npm package name to MCP server name @@ -156,6 +163,25 @@ func getNameFromPackageJSON() string { return fmt.Sprintf("io.github./%s", name) } +func getVersionFromPackageJSON() string { + data, err := os.ReadFile("package.json") + if err != nil { + return "" + } + + var pkg map[string]any + if err := json.Unmarshal(data, &pkg); err != nil { + return "" + } + + version, ok := pkg["version"].(string) + if !ok || version == "" { + return "" + } + + return version +} + func detectServerName(subfolder string) string { // Try to get from git remote repoURL := detectRepoURL()