mirror of
https://github.com/badaix/snapcast.git
synced 2025-06-04 11:51:44 +02:00
cleaned up json rpc exceptions
This commit is contained in:
parent
86a9b6ca90
commit
11a45d3508
4 changed files with 165 additions and 101 deletions
|
@ -50,15 +50,23 @@ void JsonRequest::parse(const std::string& json)
|
||||||
throw JsonRequestException(e.what(), -32700);
|
throw JsonRequestException(e.what(), -32700);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (json_.count("id") == 0)
|
||||||
|
throw JsonInvalidRequestException("id is missing", -1);
|
||||||
id = json_["id"].get<int>();
|
id = json_["id"].get<int>();
|
||||||
|
if (id < 0)
|
||||||
|
throw JsonInvalidRequestException("id must be a positive integer", id);
|
||||||
|
|
||||||
|
if (json_.count("jsonrpc") == 0)
|
||||||
|
throw JsonInvalidRequestException("jsonrpc is missing", id);
|
||||||
string jsonrpc = json_["jsonrpc"].get<string>();
|
string jsonrpc = json_["jsonrpc"].get<string>();
|
||||||
if (jsonrpc != "2.0")
|
if (jsonrpc != "2.0")
|
||||||
throw JsonRequestException("invalid jsonrpc value: " + jsonrpc, -32600);
|
throw JsonInvalidRequestException("invalid jsonrpc value: " + jsonrpc, id);
|
||||||
|
|
||||||
|
if (json_.count("method") == 0)
|
||||||
|
throw JsonInvalidRequestException("method is missing", id);
|
||||||
method = json_["method"].get<string>();
|
method = json_["method"].get<string>();
|
||||||
if (method.empty())
|
if (method.empty())
|
||||||
throw JsonRequestException("method must not be empty", -32600);
|
throw JsonInvalidRequestException("method must not be empty", id);
|
||||||
if (id < 0)
|
|
||||||
throw JsonRequestException("id must be a positive integer", -32600);
|
|
||||||
|
|
||||||
params.clear();
|
params.clear();
|
||||||
try
|
try
|
||||||
|
@ -72,7 +80,7 @@ void JsonRequest::parse(const std::string& json)
|
||||||
}
|
}
|
||||||
catch (const exception& e)
|
catch (const exception& e)
|
||||||
{
|
{
|
||||||
throw JsonRequestException(e.what(), -32602);
|
throw JsonInvalidParamsException(e.what(), id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (const JsonRequestException& e)
|
catch (const JsonRequestException& e)
|
||||||
|
@ -81,7 +89,7 @@ void JsonRequest::parse(const std::string& json)
|
||||||
}
|
}
|
||||||
catch (const exception& e)
|
catch (const exception& e)
|
||||||
{
|
{
|
||||||
throw JsonRequestException(e.what(), -32603, id);
|
throw JsonInternalErrorException(e.what(), id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,107 +23,13 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <boost/lexical_cast.hpp>
|
#include <boost/lexical_cast.hpp>
|
||||||
#include "json.hpp"
|
#include "json.hpp"
|
||||||
#include "common/snapException.h"
|
#include "jsonrpcException.h"
|
||||||
|
|
||||||
|
|
||||||
using Json = nlohmann::json;
|
using Json = nlohmann::json;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class JsonRequestException : public SnapException
|
|
||||||
{
|
|
||||||
int errorCode_, id_;
|
|
||||||
public:
|
|
||||||
JsonRequestException(const char* text, int errorCode = 0, int requestId = -1) : SnapException(text), errorCode_(errorCode), id_(requestId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
JsonRequestException(const std::string& text, int errorCode = 0, int requestId = -1) : SnapException(text), errorCode_(errorCode), id_(requestId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
// JsonRequestException(const JsonRequest& request, const std::string& text, int errorCode = 0) : SnapException(text), errorCode_(errorCode), id_(request.id)
|
|
||||||
// {
|
|
||||||
// }
|
|
||||||
|
|
||||||
JsonRequestException(const JsonRequestException& e) : SnapException(e.what()), errorCode_(e.errorCode()), id_(e.id_)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual int errorCode() const noexcept
|
|
||||||
{
|
|
||||||
return errorCode_;
|
|
||||||
}
|
|
||||||
|
|
||||||
Json getResponse() const noexcept
|
|
||||||
{
|
|
||||||
int errorCode = errorCode_;
|
|
||||||
if (errorCode == 0)
|
|
||||||
errorCode = -32603;
|
|
||||||
|
|
||||||
Json response = {
|
|
||||||
{"jsonrpc", "2.0"},
|
|
||||||
{"error", {
|
|
||||||
{"code", errorCode},
|
|
||||||
{"message", what()}
|
|
||||||
}},
|
|
||||||
};
|
|
||||||
if (id_ == -1)
|
|
||||||
response["id"] = nullptr;
|
|
||||||
else
|
|
||||||
response["id"] = id_;
|
|
||||||
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
// -32601 Method not found The method does not exist / is not available.
|
|
||||||
// -32602 Invalid params Invalid method parameter(s).
|
|
||||||
// -32603 Internal error Internal JSON-RPC error.
|
|
||||||
|
|
||||||
class JsonMethodNotFoundException : public JsonRequestException
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
JsonMethodNotFoundException(int requestId = -1) : JsonRequestException("method not found", -32601, requestId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
JsonMethodNotFoundException(const std::string& message, int requestId = -1) : JsonRequestException(message, -32601, requestId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class JsonInvalidParamsException : public JsonRequestException
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
JsonInvalidParamsException(int requestId = -1) : JsonRequestException("invalid params", -32602, requestId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
JsonInvalidParamsException(const std::string& message, int requestId = -1) : JsonRequestException(message, -32602, requestId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class JsonInternalErrorException : public JsonRequestException
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
JsonInternalErrorException(int requestId = -1) : JsonRequestException("internal error", -32603, requestId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
JsonInternalErrorException(const std::string& message, int requestId = -1) : JsonRequestException(message, -32603, requestId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/// JSON-RPC 2.0 request
|
/// JSON-RPC 2.0 request
|
||||||
/**
|
/**
|
||||||
* Simple jsonrpc 2.0 parser with getters
|
* Simple jsonrpc 2.0 parser with getters
|
||||||
|
|
140
server/json/jsonrpcException.h
Normal file
140
server/json/jsonrpcException.h
Normal file
|
@ -0,0 +1,140 @@
|
||||||
|
/***
|
||||||
|
This file is part of snapcast
|
||||||
|
Copyright (C) 2015 Johannes Pohl
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
***/
|
||||||
|
|
||||||
|
#ifndef JSON_RPC_EXCEPTION_H
|
||||||
|
#define JSON_RPC_EXCEPTION_H
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <boost/lexical_cast.hpp>
|
||||||
|
#include "json.hpp"
|
||||||
|
#include "common/snapException.h"
|
||||||
|
|
||||||
|
|
||||||
|
using Json = nlohmann::json;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class JsonRequestException : public SnapException
|
||||||
|
{
|
||||||
|
int errorCode_, id_;
|
||||||
|
public:
|
||||||
|
JsonRequestException(const char* text, int errorCode = 0, int requestId = -1) : SnapException(text), errorCode_(errorCode), id_(requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonRequestException(const std::string& text, int errorCode = 0, int requestId = -1) : SnapException(text), errorCode_(errorCode), id_(requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
// JsonRequestException(const JsonRequest& request, const std::string& text, int errorCode = 0) : SnapException(text), errorCode_(errorCode), id_(request.id)
|
||||||
|
// {
|
||||||
|
// }
|
||||||
|
|
||||||
|
JsonRequestException(const JsonRequestException& e) : SnapException(e.what()), errorCode_(e.errorCode()), id_(e.id_)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual int errorCode() const noexcept
|
||||||
|
{
|
||||||
|
return errorCode_;
|
||||||
|
}
|
||||||
|
|
||||||
|
Json getResponse() const noexcept
|
||||||
|
{
|
||||||
|
int errorCode = errorCode_;
|
||||||
|
if (errorCode == 0)
|
||||||
|
errorCode = -32603;
|
||||||
|
|
||||||
|
Json response = {
|
||||||
|
{"jsonrpc", "2.0"},
|
||||||
|
{"error", {
|
||||||
|
{"code", errorCode},
|
||||||
|
{"message", what()}
|
||||||
|
}},
|
||||||
|
};
|
||||||
|
if (id_ == -1)
|
||||||
|
response["id"] = nullptr;
|
||||||
|
else
|
||||||
|
response["id"] = id_;
|
||||||
|
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// -32600 Invalid Request The JSON sent is not a valid Request object.
|
||||||
|
// -32601 Method not found The method does not exist / is not available.
|
||||||
|
// -32602 Invalid params Invalid method parameter(s).
|
||||||
|
// -32603 Internal error Internal JSON-RPC error.
|
||||||
|
|
||||||
|
class JsonInvalidRequestException : public JsonRequestException
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
JsonInvalidRequestException(int requestId = -1) : JsonRequestException("invalid request", -32600, requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonInvalidRequestException(const std::string& message, int requestId = -1) : JsonRequestException(message, -32600, requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class JsonMethodNotFoundException : public JsonRequestException
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
JsonMethodNotFoundException(int requestId = -1) : JsonRequestException("method not found", -32601, requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonMethodNotFoundException(const std::string& message, int requestId = -1) : JsonRequestException(message, -32601, requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class JsonInvalidParamsException : public JsonRequestException
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
JsonInvalidParamsException(int requestId = -1) : JsonRequestException("invalid params", -32602, requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonInvalidParamsException(const std::string& message, int requestId = -1) : JsonRequestException(message, -32602, requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class JsonInternalErrorException : public JsonRequestException
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
JsonInternalErrorException(int requestId = -1) : JsonRequestException("internal error", -32603, requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonInternalErrorException(const std::string& message, int requestId = -1) : JsonRequestException(message, -32603, requestId)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -48,6 +48,16 @@ doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetMute\", \"params\": {\
|
||||||
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetMute\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\", \"mute\": false}, \"id\": 9}\r\n")
|
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetMute\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\", \"mute\": false}, \"id\": 9}\r\n")
|
||||||
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetLatency\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\", \"latency\": 10}, \"id\": 7}\r\n")
|
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetLatency\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\", \"latency\": 10}, \"id\": 7}\r\n")
|
||||||
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetName\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\", \"name\": \"living room\"}, \"id\": 8}\r\n")
|
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetName\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\", \"name\": \"living room\"}, \"id\": 8}\r\n")
|
||||||
|
#invalid json
|
||||||
|
doRequest("some message to test invalid requests\r\n")
|
||||||
|
#missing id
|
||||||
|
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetName\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\", \"name\": \"living room\"}}\r\n")
|
||||||
|
#missing parameter
|
||||||
|
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetName\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\"}, \"id\": 8}\r\n")
|
||||||
|
#invalid method
|
||||||
|
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"NonExistingMethod\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\"}, \"id\": 8}\r\n")
|
||||||
|
#out of range
|
||||||
|
doRequest("{\"jsonrpc\": \"2.0\", \"method\": \"Client.SetVolume\", \"params\": {\"client\": \"00:21:6a:7d:74:fc\", \"volume\": 101}, \"id\": 3}\r\n")
|
||||||
|
|
||||||
s = raw_input("")
|
s = raw_input("")
|
||||||
print(s)
|
print(s)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue