Skip to content

Commit b5624ed

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 bfa5e30 commit b5624ed

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
@@ -19,8 +19,7 @@ import (
1919
// A Client is an MCP client, which may be connected to an MCP server
2020
// using the [Client.Connect] method.
2121
type Client struct {
22-
name string
23-
version string
22+
impl *Implementation
2423
opts ClientOptions
2524
mu sync.Mutex
2625
roots *featureSet[*Root]
@@ -29,15 +28,18 @@ type Client struct {
2928
receivingMethodHandler_ MethodHandler[*ClientSession]
3029
}
3130

32-
// NewClient creates a new Client.
31+
// NewClient creates a new [Client].
3332
//
3433
// Use [Client.Connect] to connect it to an MCP server.
3534
//
35+
// If impl is nil, a default name and version are used, and the title is left empty.
3636
// If non-nil, the provided options configure the Client.
37-
func NewClient(name, version string, opts *ClientOptions) *Client {
37+
func NewClient(impl *Implementation, opts *ClientOptions) *Client {
38+
if impl == nil {
39+
impl = &Implementation{Name: "Go MCP SDK Client", Version: "v0.1.0"}
40+
}
3841
c := &Client{
39-
name: name,
40-
version: version,
42+
impl: impl,
4143
roots: newFeatureSet(func(r *Root) string { return r.URI }),
4244
sendingMethodHandler_: defaultSendingMethodHandler[*ClientSession],
4345
receivingMethodHandler_: defaultReceivingMethodHandler[*ClientSession],
@@ -118,7 +120,7 @@ func (c *Client) Connect(ctx context.Context, t Transport) (cs *ClientSession, e
118120

119121
params := &InitializeParams{
120122
ProtocolVersion: latestProtocolVersion,
121-
ClientInfo: &implementation{Name: c.name, Version: c.version},
123+
ClientInfo: c.impl,
122124
Capabilities: caps,
123125
}
124126
res, err := handleSend[*InitializeResult](ctx, cs, methodInitialize, params)

mcp/cmd_test.go

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

35-
server := mcp.NewServer("greeter", "v0.0.1", nil)
35+
server := mcp.NewServer(nil, nil)
3636
mcp.AddTool(server, &mcp.Tool{Name: "greet", Description: "say hi"}, SayHi)
3737
if err := server.Run(ctx, mcp.NewStdioTransport()); err != nil {
3838
log.Fatal(err)
@@ -87,7 +87,7 @@ func TestServerInterrupt(t *testing.T) {
8787

8888
cmd := createServerCommand(t)
8989

90-
client := mcp.NewClient("client", "v0.0.1", nil)
90+
client := mcp.NewClient(nil, nil)
9191
session, err := client.Connect(ctx, mcp.NewCommandTransport(cmd))
9292
if err != nil {
9393
t.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)