@mcp-ts/sdk 1.5.0 → 1.5.1

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.
@@ -1711,13 +1711,8 @@ var MCPClient = class _MCPClient {
1711
1711
  this.transportType = transportType;
1712
1712
  this.emitStateChange("CONNECTED");
1713
1713
  this.emitProgress("Connected successfully");
1714
- const existingSession = await storage.getSession(this.identity, this.sessionId);
1715
- const needsTransportUpdate = !existingSession || existingSession.transportType !== this.transportType;
1716
- const needsTtlPromotion = !existingSession || existingSession.active !== true;
1717
- if (needsTransportUpdate || needsTtlPromotion) {
1718
- console.log(`[MCPClient] Saving session ${this.sessionId} with 12hr TTL (connect success)`);
1719
- await this.saveSession(SESSION_TTL_SECONDS, true);
1720
- }
1714
+ console.log(`[MCPClient] Saving session ${this.sessionId} with 12hr TTL (connect success)`);
1715
+ await this.saveSession(SESSION_TTL_SECONDS, true);
1721
1716
  } catch (error) {
1722
1717
  if (error instanceof auth_js.UnauthorizedError || error instanceof Error && error.message.toLowerCase().includes("unauthorized")) {
1723
1718
  let authUrl = "";
@@ -1755,6 +1750,13 @@ var MCPClient = class _MCPClient {
1755
1750
  const errorMessage = error instanceof Error ? error.message : "Connection failed";
1756
1751
  this.emitError(errorMessage, "connection");
1757
1752
  this.emitStateChange("FAILED");
1753
+ try {
1754
+ const existingSession = await storage.getSession(this.identity, this.sessionId);
1755
+ if (!existingSession || existingSession.active !== true) {
1756
+ await storage.removeSession(this.identity, this.sessionId);
1757
+ }
1758
+ } catch {
1759
+ }
1758
1760
  throw error;
1759
1761
  }
1760
1762
  }
@@ -1778,6 +1780,7 @@ var MCPClient = class _MCPClient {
1778
1780
  const transportsToTry = this.transportType ? [this.transportType] : ["streamable_http", "sse"];
1779
1781
  let lastError;
1780
1782
  let tokensExchanged = false;
1783
+ let authenticatedStateEmitted = false;
1781
1784
  for (const currentType of transportsToTry) {
1782
1785
  const isLastAttempt = currentType === transportsToTry[transportsToTry.length - 1];
1783
1786
  try {
@@ -1789,8 +1792,10 @@ var MCPClient = class _MCPClient {
1789
1792
  } else {
1790
1793
  this.emitProgress(`Tokens already exchanged, skipping auth step for ${currentType}...`);
1791
1794
  }
1792
- this.transportType = currentType;
1793
- this.emitStateChange("AUTHENTICATED");
1795
+ if (!authenticatedStateEmitted) {
1796
+ this.emitStateChange("AUTHENTICATED");
1797
+ authenticatedStateEmitted = true;
1798
+ }
1794
1799
  this.emitProgress("Creating authenticated client...");
1795
1800
  this.client = new index_js.Client(
1796
1801
  {
@@ -1809,6 +1814,7 @@ var MCPClient = class _MCPClient {
1809
1814
  );
1810
1815
  this.emitStateChange("CONNECTING");
1811
1816
  await this.client.connect(this.transport);
1817
+ this.transportType = currentType;
1812
1818
  this.emitStateChange("CONNECTED");
1813
1819
  console.log(`[MCPClient] Updating session ${this.sessionId} to 12hr TTL (OAuth complete)`);
1814
1820
  await this.saveSession(SESSION_TTL_SECONDS, true);
@@ -2680,9 +2686,23 @@ var SSEConnectionManager = class {
2680
2686
  if (existing) {
2681
2687
  return existing;
2682
2688
  }
2689
+ const session = await storage.getSession(this.identity, sessionId);
2690
+ if (!session) {
2691
+ throw new Error("Session not found");
2692
+ }
2683
2693
  const client = new MCPClient({
2684
2694
  identity: this.identity,
2685
- sessionId
2695
+ sessionId,
2696
+ // These fields are optional in MCPClient, but when rehydrating a known
2697
+ // stored session on the server we pass them explicitly to preserve the
2698
+ // original transport/connection metadata instead of relying on lazy
2699
+ // reloading during initialize().
2700
+ serverId: session.serverId,
2701
+ serverName: session.serverName,
2702
+ serverUrl: session.serverUrl,
2703
+ callbackUrl: session.callbackUrl,
2704
+ transportType: session.transportType,
2705
+ headers: session.headers
2686
2706
  });
2687
2707
  client.onConnectionEvent((event) => this.emitConnectionEvent(event));
2688
2708
  client.onObservabilityEvent((event) => this.sendEvent(event));
@@ -2739,6 +2759,16 @@ var SSEConnectionManager = class {
2739
2759
  const client = new MCPClient({
2740
2760
  identity: this.identity,
2741
2761
  sessionId,
2762
+ // These fields are optional in MCPClient, but when rehydrating a known
2763
+ // stored session on the server we pass them explicitly to preserve the
2764
+ // original transport/connection metadata instead of relying on lazy
2765
+ // reloading during initialize().
2766
+ serverId: session.serverId,
2767
+ serverName: session.serverName,
2768
+ serverUrl: session.serverUrl,
2769
+ callbackUrl: session.callbackUrl,
2770
+ transportType: session.transportType,
2771
+ headers: session.headers,
2742
2772
  ...clientMetadata
2743
2773
  });
2744
2774
  client.onConnectionEvent((event) => this.emitConnectionEvent(event));
@@ -2771,7 +2801,21 @@ var SSEConnectionManager = class {
2771
2801
  try {
2772
2802
  const client = new MCPClient({
2773
2803
  identity: this.identity,
2774
- sessionId
2804
+ sessionId,
2805
+ // These fields are optional in MCPClient, but when rehydrating a known
2806
+ // stored session on the server we pass them explicitly to preserve the
2807
+ // original connection metadata instead of relying on lazy
2808
+ // reloading during initialize().
2809
+ serverId: session.serverId,
2810
+ serverName: session.serverName,
2811
+ serverUrl: session.serverUrl,
2812
+ callbackUrl: session.callbackUrl,
2813
+ // NOTE: transportType is intentionally omitted here.
2814
+ // The session's stored transportType is a placeholder ('streamable_http')
2815
+ // set before transport negotiation. Omitting it lets MCPClient auto-negotiate
2816
+ // (try streamable_http → SSE fallback), which is critical for servers like
2817
+ // Neon that only support SSE transport.
2818
+ headers: session.headers
2775
2819
  });
2776
2820
  client.onConnectionEvent((event) => this.emitConnectionEvent(event));
2777
2821
  await client.finishAuth(code);