fast-mcp 1.3.1 → 1.3.2
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.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -0
- data/lib/mcp/server.rb +4 -4
- data/lib/mcp/transports/rack_transport.rb +4 -4
- data/lib/mcp/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 247f36763da6fd88d9c9e454d5d63eaeb351d08a72de8c2e5dc65919d9e2a9f1
|
4
|
+
data.tar.gz: 846d3427bb33357cfdc6c5387d153d393449792455beab413e36eeb8d0f1bf1d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 8917675ff31b47cd67ddc5171a0c1e853cca9ba8a5853a7a9314ab5b794c9868c7c48b2db17dbd2edb580e81e9b12de8a0318151239babc2a5971cc2d4b10d72
|
7
|
+
data.tar.gz: 926a58cda786415804f88bb7d2cbabe91fe90b6ae84964be9452070f0ac4de7a29705eedd69af79c641c4e4086865b5dda3438108f1cb068457b1b9c2930472e
|
data/CHANGELOG.md
CHANGED
@@ -5,6 +5,12 @@ All notable changes to this project will be documented in this file.
|
|
5
5
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
6
6
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
7
7
|
|
8
|
+
## [1.3.2] - 2025-05-08
|
9
|
+
### Changed
|
10
|
+
- Logs are now less verbose by default [#64 @yjacquin](https://github.com/yjacquin/fast-mcp/pull/64)
|
11
|
+
### Fixed
|
12
|
+
- Fix undefined method `call' for an instance of String error log [#61 @radwo](https://github.com/yjacquin/fast-mcp/pull/61)
|
13
|
+
|
8
14
|
## [1.3.1] - 2025-04-30
|
9
15
|
### Fixed
|
10
16
|
- Allow ipv4 mapped to ipv6 (#56) [#56 @josevalim](https://github.com/yjacquin/fast-mcp/pull/56)
|
data/lib/mcp/server.rb
CHANGED
@@ -52,7 +52,7 @@ module FastMcp
|
|
52
52
|
# Register a tool with the server
|
53
53
|
def register_tool(tool)
|
54
54
|
@tools[tool.tool_name] = tool
|
55
|
-
@logger.
|
55
|
+
@logger.debug("Registered tool: #{tool.tool_name}")
|
56
56
|
tool.server = self
|
57
57
|
end
|
58
58
|
|
@@ -67,7 +67,7 @@ module FastMcp
|
|
67
67
|
# Register a resource with the server
|
68
68
|
def register_resource(resource)
|
69
69
|
@resources[resource.uri] = resource
|
70
|
-
@logger.
|
70
|
+
@logger.debug("Registered resource: #{resource.name} (#{resource.uri})")
|
71
71
|
resource.server = self
|
72
72
|
# Notify subscribers about the list change
|
73
73
|
notify_resource_list_changed if @transport
|
@@ -79,7 +79,7 @@ module FastMcp
|
|
79
79
|
def remove_resource(uri)
|
80
80
|
if @resources.key?(uri)
|
81
81
|
resource = @resources.delete(uri)
|
82
|
-
@logger.
|
82
|
+
@logger.debug("Removed resource: #{resource.name} (#{uri})")
|
83
83
|
|
84
84
|
# Notify subscribers about the list change
|
85
85
|
notify_resource_list_changed if @transport
|
@@ -435,7 +435,7 @@ module FastMcp
|
|
435
435
|
# Send a JSON-RPC response
|
436
436
|
def send_response(response)
|
437
437
|
if @transport
|
438
|
-
@logger.
|
438
|
+
@logger.debug("Sending response: #{response.inspect}")
|
439
439
|
@transport.send_message(response)
|
440
440
|
else
|
441
441
|
@logger.warn("No transport available to send response: #{response.inspect}")
|
@@ -47,7 +47,7 @@ module FastMcp
|
|
47
47
|
# Start the transport
|
48
48
|
def start
|
49
49
|
@logger.debug("Starting Rack transport with path prefix: #{@path_prefix}")
|
50
|
-
@logger.
|
50
|
+
@logger.debug("DNS rebinding protection enabled. Allowed origins: #{allowed_origins.join(', ')}")
|
51
51
|
@running = true
|
52
52
|
end
|
53
53
|
|
@@ -197,7 +197,7 @@ module FastMcp
|
|
197
197
|
return forbidden_response('Forbidden: Origin validation failed') unless validate_origin(request, env)
|
198
198
|
|
199
199
|
subpath = request.path[@path_prefix.length..]
|
200
|
-
@logger.
|
200
|
+
@logger.debug("MCP request subpath: '#{subpath.inspect}'")
|
201
201
|
|
202
202
|
case subpath
|
203
203
|
when "/#{@sse_route}"
|
@@ -205,7 +205,7 @@ module FastMcp
|
|
205
205
|
when "/#{@messages_route}"
|
206
206
|
handle_message_request(request)
|
207
207
|
else
|
208
|
-
@logger.
|
208
|
+
@logger.error('Received unknown request')
|
209
209
|
# Return 404 for unknown MCP endpoints
|
210
210
|
endpoint_not_found_response
|
211
211
|
end
|
@@ -503,7 +503,7 @@ module FastMcp
|
|
503
503
|
# Parse the request body
|
504
504
|
body = request.body.read
|
505
505
|
|
506
|
-
response = process_message(body) ||
|
506
|
+
response = process_message(body) || []
|
507
507
|
@logger.info("Response: #{response}")
|
508
508
|
|
509
509
|
[200, { 'Content-Type' => 'application/json' }, response]
|
data/lib/mcp/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: fast-mcp
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.3.
|
4
|
+
version: 1.3.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Yorick Jacquin
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2025-
|
11
|
+
date: 2025-05-09 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: base64
|