Skip to content

Commit 6556ce5

Browse files
committed
mcp: NewClient and NewServer take Implementation
Change the name and version arguments to NewClient and NewServer to a *Implementation, to future-proof against the spec. Fixes #109.
1 parent 2b07560 commit 6556ce5

File tree

16 files changed

+59
-58
lines changed

16 files changed

+59
-58
lines changed

examples/completion/main.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@ func main() {
4040

4141
// Create the MCP Server instance and assign the handler.
4242
// No server running, just showing the configuration.
43-
_ = mcp.NewServer("myServer", "v1.0.0", &mcp.ServerOptions{
43+
_ = mcp.NewServer(nil, &mcp.ServerOptions{
4444
CompletionHandler: myCompletionHandler,
4545
})
4646

examples/hello/main.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -42,7 +42,7 @@ func PromptHi(ctx context.Context, ss *mcp.ServerSession, params *mcp.GetPromptP
4242
func main() {
4343
flag.Parse()
4444

45-
server := mcp.NewServer("greeter", "v0.0.1", nil)
45+
server := mcp.NewServer(&mcp.Implementation{Name: "greeter"}, nil)
4646
mcp.AddTool(server, &mcp.Tool{Name: "greet", Description: "say hi"}, SayHi)
4747
server.AddPrompt(&mcp.Prompt{Name: "greet"}, PromptHi)
4848
server.AddResource(&mcp.Resource{

examples/memory/main.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -91,7 +91,7 @@ func main() {
9191
kb := knowledgeBase{s: kbStore}
9292

9393
// Setup MCP server with knowledge base tools
94-
server := mcp.NewServer("memory", "v0.0.1", nil)
94+
server := mcp.NewServer(nil, nil)
9595
mcp.AddTool(server, &mcp.Tool{
9696
Name: "create_entities",
9797
Description: "Create multiple new entities in the knowledge graph",

examples/sse/main.go

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -34,10 +34,10 @@ func main() {
3434
log.Fatal("http address not set")
3535
}
3636

37-
server1 := mcp.NewServer("greeter1", "v0.0.1", nil)
37+
server1 := mcp.NewServer(&mcp.Implementation{Name: "greeter1"}, nil)
3838
mcp.AddTool(server1, &mcp.Tool{Name: "greet1", Description: "say hi"}, SayHi)
3939

40-
server2 := mcp.NewServer("greeter2", "v0.0.1", nil)
40+
server2 := mcp.NewServer(&mcp.Implementation{Name: "greeter2"}, nil)
4141
mcp.AddTool(server2, &mcp.Tool{Name: "greet2", Description: "say hello"}, SayHi)
4242

4343
log.Printf("MCP servers serving at %s", *httpAddr)

internal/readme/client/client.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,7 @@ func main() {
1717
ctx := context.Background()
1818

1919
// Create a new client, with no features.
20-
client := mcp.NewClient("mcp-client", "v1.0.0", nil)
20+
client := mcp.NewClient(nil, nil)
2121

2222
// Connect to a server over stdin/stdout
2323
transport := mcp.NewCommandTransport(exec.Command("myserver"))

internal/readme/server/server.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@ func SayHi(ctx context.Context, cc *mcp.ServerSession, params *mcp.CallToolParam
2424

2525
func main() {
2626
// Create a server with a single tool.
27-
server := mcp.NewServer("greeter", "v1.0.0", nil)
27+
server := mcp.NewServer(&mcp.Implementation{Name: "greeter", Version: "v1.0.0"}, nil)
2828

2929
mcp.AddTool(server, &mcp.Tool{Name: "greet", Description: "say hi"}, SayHi)
3030
// Run the server over stdin/stdout, until the client disconnects

mcp/client.go

Lines changed: 9 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -17,8 +17,7 @@ import (
1717
// A Client is an MCP client, which may be connected to an MCP server
1818
// using the [Client.Connect] method.
1919
type Client struct {
20-
name string
21-
version string
20+
impl *Implementation
2221
opts ClientOptions
2322
mu sync.Mutex
2423
roots *featureSet[*Root]
@@ -27,15 +26,18 @@ type Client struct {
2726
receivingMethodHandler_ MethodHandler[*ClientSession]
2827
}
2928

30-
// NewClient creates a new Client.
29+
// NewClient creates a new [Client].
3130
//
3231
// Use [Client.Connect] to connect it to an MCP server.
3332
//
33+
// If impl is nil, a default name and version are used, and the title is left empty.
3434
// If non-nil, the provided options configure the Client.
35-
func NewClient(name, version string, opts *ClientOptions) *Client {
35+
func NewClient(impl *Implementation, opts *ClientOptions) *Client {
36+
if impl == nil {
37+
impl = &Implementation{Name: "Go MCP SDK Client", Version: "v0.1.0"}
38+
}
3639
c := &Client{
37-
name: name,
38-
version: version,
40+
impl: impl,
3941
roots: newFeatureSet(func(r *Root) string { return r.URI }),
4042
sendingMethodHandler_: defaultSendingMethodHandler[*ClientSession],
4143
receivingMethodHandler_: defaultReceivingMethodHandler[*ClientSession],
@@ -106,7 +108,7 @@ func (c *Client) Connect(ctx context.Context, t Transport) (cs *ClientSession, e
106108
}
107109

108110
params := &InitializeParams{
109-
ClientInfo: &implementation{Name: c.name, Version: c.version},
111+
ClientInfo: c.impl,
110112
Capabilities: caps,
111113
ProtocolVersion: "2025-03-26",
112114
}

mcp/cmd_test.go

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,7 @@ func TestMain(m *testing.M) {
3030
func runServer() {
3131
ctx := context.Background()
3232

33-
server := mcp.NewServer("greeter", "v0.0.1", nil)
33+
server := mcp.NewServer(nil, nil)
3434
mcp.AddTool(server, &mcp.Tool{Name: "greet", Description: "say hi"}, SayHi)
3535
if err := server.Run(ctx, mcp.NewStdioTransport()); err != nil {
3636
log.Fatal(err)
@@ -56,7 +56,7 @@ func TestCmdTransport(t *testing.T) {
5656
cmd := exec.Command(exe)
5757
cmd.Env = append(os.Environ(), runAsServer+"=true")
5858

59-
client := mcp.NewClient("client", "v0.0.1", nil)
59+
client := mcp.NewClient(nil, nil)
6060
session, err := client.Connect(ctx, mcp.NewCommandTransport(cmd))
6161
if err != nil {
6262
log.Fatal(err)

mcp/example_progress_test.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@ var nextProgressToken atomic.Int64
1616
// This middleware function adds a progress token to every outgoing request
1717
// from the client.
1818
func Example_progressMiddleware() {
19-
c := mcp.NewClient("test", "v1", nil)
19+
c := mcp.NewClient(nil, nil)
2020
c.AddSendingMiddleware(addProgressToken[*mcp.ClientSession])
2121
_ = c
2222
}

mcp/mcp_test.go

Lines changed: 14 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -64,7 +64,7 @@ func TestEndToEnd(t *testing.T) {
6464
notificationChans["progress_server"] <- 0
6565
},
6666
}
67-
s := NewServer("testServer", "v1.0.0", sopts)
67+
s := NewServer(nil, sopts)
6868
AddTool(s, &Tool{
6969
Name: "greet",
7070
Description: "say hi",
@@ -125,7 +125,7 @@ func TestEndToEnd(t *testing.T) {
125125
notificationChans["progress_client"] <- 0
126126
},
127127
}
128-
c := NewClient("testClient", "v1.0.0", opts)
128+
c := NewClient(nil, opts)
129129
rootAbs, err := filepath.Abs(filepath.FromSlash("testdata/files"))
130130
if err != nil {
131131
t.Fatal(err)
@@ -510,7 +510,7 @@ func basicConnection(t *testing.T, config func(*Server)) (*ServerSession, *Clien
510510
ctx := context.Background()
511511
ct, st := NewInMemoryTransports()
512512

513-
s := NewServer("testServer", "v1.0.0", nil)
513+
s := NewServer(nil, nil)
514514
if config != nil {
515515
config(s)
516516
}
@@ -519,7 +519,7 @@ func basicConnection(t *testing.T, config func(*Server)) (*ServerSession, *Clien
519519
t.Fatal(err)
520520
}
521521

522-
c := NewClient("testClient", "v1.0.0", nil)
522+
c := NewClient(nil, nil)
523523
cs, err := c.Connect(ctx, ct)
524524
if err != nil {
525525
t.Fatal(err)
@@ -562,13 +562,13 @@ func TestBatching(t *testing.T) {
562562
ctx := context.Background()
563563
ct, st := NewInMemoryTransports()
564564

565-
s := NewServer("testServer", "v1.0.0", nil)
565+
s := NewServer(nil, nil)
566566
_, err := s.Connect(ctx, st)
567567
if err != nil {
568568
t.Fatal(err)
569569
}
570570

571-
c := NewClient("testClient", "v1.0.0", nil)
571+
c := NewClient(nil, nil)
572572
// TODO: this test is broken, because increasing the batch size here causes
573573
// 'initialize' to block. Therefore, we can only test with a size of 1.
574574
// Since batching is being removed, we can probably just delete this.
@@ -632,7 +632,7 @@ func TestMiddleware(t *testing.T) {
632632
ctx := context.Background()
633633
ct, st := NewInMemoryTransports()
634634

635-
s := NewServer("testServer", "v1.0.0", nil)
635+
s := NewServer(nil, nil)
636636
ss, err := s.Connect(ctx, st)
637637
if err != nil {
638638
t.Fatal(err)
@@ -656,7 +656,7 @@ func TestMiddleware(t *testing.T) {
656656
s.AddSendingMiddleware(traceCalls[*ServerSession](&sbuf, "S1"), traceCalls[*ServerSession](&sbuf, "S2"))
657657
s.AddReceivingMiddleware(traceCalls[*ServerSession](&sbuf, "R1"), traceCalls[*ServerSession](&sbuf, "R2"))
658658

659-
c := NewClient("testClient", "v1.0.0", nil)
659+
c := NewClient(nil, nil)
660660
c.AddSendingMiddleware(traceCalls[*ClientSession](&cbuf, "S1"), traceCalls[*ClientSession](&cbuf, "S2"))
661661
c.AddReceivingMiddleware(traceCalls[*ClientSession](&cbuf, "R1"), traceCalls[*ClientSession](&cbuf, "R2"))
662662

@@ -741,13 +741,13 @@ func TestNoJSONNull(t *testing.T) {
741741
var logbuf safeBuffer
742742
ct = NewLoggingTransport(ct, &logbuf)
743743

744-
s := NewServer("testServer", "v1.0.0", nil)
744+
s := NewServer(nil, nil)
745745
ss, err := s.Connect(ctx, st)
746746
if err != nil {
747747
t.Fatal(err)
748748
}
749749

750-
c := NewClient("testClient", "v1.0.0", nil)
750+
c := NewClient(nil, nil)
751751
cs, err := c.Connect(ctx, ct)
752752
if err != nil {
753753
t.Fatal(err)
@@ -810,7 +810,7 @@ func TestKeepAlive(t *testing.T) {
810810
serverOpts := &ServerOptions{
811811
KeepAlive: 100 * time.Millisecond,
812812
}
813-
s := NewServer("testServer", "v1.0.0", serverOpts)
813+
s := NewServer(nil, serverOpts)
814814
AddTool(s, greetTool(), sayHi)
815815

816816
ss, err := s.Connect(ctx, st)
@@ -822,7 +822,7 @@ func TestKeepAlive(t *testing.T) {
822822
clientOpts := &ClientOptions{
823823
KeepAlive: 100 * time.Millisecond,
824824
}
825-
c := NewClient("testClient", "v1.0.0", clientOpts)
825+
c := NewClient(nil, clientOpts)
826826
cs, err := c.Connect(ctx, ct)
827827
if err != nil {
828828
t.Fatal(err)
@@ -855,7 +855,7 @@ func TestKeepAliveFailure(t *testing.T) {
855855
ct, st := NewInMemoryTransports()
856856

857857
// Server without keepalive (to test one-sided keepalive)
858-
s := NewServer("testServer", "v1.0.0", nil)
858+
s := NewServer(nil, nil)
859859
AddTool(s, greetTool(), sayHi)
860860
ss, err := s.Connect(ctx, st)
861861
if err != nil {
@@ -866,7 +866,7 @@ func TestKeepAliveFailure(t *testing.T) {
866866
clientOpts := &ClientOptions{
867867
KeepAlive: 50 * time.Millisecond,
868868
}
869-
c := NewClient("testClient", "v1.0.0", clientOpts)
869+
c := NewClient(nil, clientOpts)
870870
cs, err := c.Connect(ctx, ct)
871871
if err != nil {
872872
t.Fatal(err)

0 commit comments

Comments
 (0)