mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-12 21:32:40 +00:00
context_servers: Fix tool/list and prompt/list (#20387)
There are two issues with too/list and prompt/list at the moment. We serialize params to `null`, which is not correct according to context_server spec. While it IS allowed by JSON RPC spec to omit params, it turns out some servers currently missbehave and don't respect this. So we do two things - We omit params if it would be a null value in json. - We explicitly set params to {} for tool/list and prompt/list to avoid it being omitted. Release Notes: - N/A
This commit is contained in:
parent
36fe364c05
commit
30a94fa59b
2 changed files with 17 additions and 2 deletions
|
@ -55,11 +55,20 @@ pub struct Client {
|
|||
#[repr(transparent)]
|
||||
pub struct ContextServerId(pub String);
|
||||
|
||||
fn is_null_value<T: Serialize>(value: &T) -> bool {
|
||||
if let Ok(Value::Null) = serde_json::to_value(value) {
|
||||
true
|
||||
} else {
|
||||
false
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Serialize, Deserialize)]
|
||||
struct Request<'a, T> {
|
||||
jsonrpc: &'static str,
|
||||
id: RequestId,
|
||||
method: &'a str,
|
||||
#[serde(skip_serializing_if = "is_null_value")]
|
||||
params: T,
|
||||
}
|
||||
|
||||
|
|
|
@ -113,7 +113,10 @@ impl InitializedContextServerProtocol {
|
|||
|
||||
let response: types::PromptsListResponse = self
|
||||
.inner
|
||||
.request(types::RequestType::PromptsList.as_str(), ())
|
||||
.request(
|
||||
types::RequestType::PromptsList.as_str(),
|
||||
serde_json::json!({}),
|
||||
)
|
||||
.await?;
|
||||
|
||||
Ok(response.prompts)
|
||||
|
@ -125,7 +128,10 @@ impl InitializedContextServerProtocol {
|
|||
|
||||
let response: types::ResourcesListResponse = self
|
||||
.inner
|
||||
.request(types::RequestType::ResourcesList.as_str(), ())
|
||||
.request(
|
||||
types::RequestType::ResourcesList.as_str(),
|
||||
serde_json::json!({}),
|
||||
)
|
||||
.await?;
|
||||
|
||||
Ok(response)
|
||||
|
|
Loading…
Reference in a new issue