Package jmri.server.json.oblock
Class JsonOblockHttpService
java.lang.Object
Copied from jmri/server/json/blocks.java
-
Field Summary
Fields inherited from class jmri.server.json.JsonHttpService
mapper -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected voiddoDelete(OBlock bean, String name, String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) Delete the requested bean.com.fasterxml.jackson.databind.node.ObjectNodedoGet(OBlock oblock, String name, String type, JsonRequest request) Respond to an HTTP GET request for the requested name.com.fasterxml.jackson.databind.node.ObjectNodedoPost(OBlock oblock, String name, String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) Respond to an HTTP POST request for the requested name.com.fasterxml.jackson.databind.JsonNodedoSchema(String type, boolean server, JsonRequest request) Get the JSON Schema for thedataproperty of the requested type of JSON object.protected ProvidingManager<OBlock>Get the expected providing manager for the supported JSON type.protected StringgetType()Get the JSON type supported by this service.Methods inherited from class jmri.server.json.JsonNamedBeanHttpService
deleteBean, doDelete, doGet, doGetList, doPost, doPut, getManager, getNamedBeanMethods inherited from class jmri.server.json.JsonNonProvidedNamedBeanHttpService
doGetList, doGetList, getNamedBean, postNamedBeanMethods inherited from class jmri.server.json.JsonHttpService
acceptForceDeleteToken, doSchema, doSchema, getObjectMapper, message, message, message, message, message, throwDeleteConflictException
-
Constructor Details
-
JsonOblockHttpService
-
-
Method Details
-
doGet
public com.fasterxml.jackson.databind.node.ObjectNode doGet(OBlock oblock, String name, String type, JsonRequest request) throws JsonException Description copied from class:JsonNamedBeanHttpServiceRespond to an HTTP GET request for the requested name.If name is null, return a list of all objects for the given type, if appropriate.
This method should throw a 500 Internal Server Error if type is not recognized.
- Specified by:
doGetin classJsonNamedBeanHttpService<OBlock>- Parameters:
oblock- the requested objectname- the name of the requested objecttype- the type of the requested objectrequest- the JSON request- Returns:
- a JSON description of the requested object
- Throws:
JsonException- if the named object does not exist or other error occurs
-
doPost
public com.fasterxml.jackson.databind.node.ObjectNode doPost(OBlock oblock, String name, String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) throws JsonException Description copied from class:JsonNamedBeanHttpServiceRespond to an HTTP POST request for the requested name.- Specified by:
doPostin classJsonNamedBeanHttpService<OBlock>- Parameters:
oblock- the requested objectname- the name of the requested objecttype- the type of the requested objectdata- data describing the requested objectrequest- the JSON request- Returns:
- a JSON description of the requested object
- Throws:
JsonException- if an error occurs
-
doDelete
protected void doDelete(OBlock bean, String name, String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) throws JsonException Description copied from class:JsonNamedBeanHttpServiceDelete the requested bean.This method must be overridden to allow a bean to be deleted. The simplest overriding method body is:
deleteBean(bean, name, type, data, locale, id);- Overrides:
doDeletein classJsonNamedBeanHttpService<OBlock>- Parameters:
bean- the bean to deletename- the named of the bean to deletetype- the type of the bean to deletedata- data describing the named beanrequest- the JSON request- Throws:
JsonException- if an error occurs
-
doSchema
public com.fasterxml.jackson.databind.JsonNode doSchema(String type, boolean server, JsonRequest request) throws JsonException Description copied from class:JsonHttpServiceGet the JSON Schema for thedataproperty of the requested type of JSON object. It is a invalid for implementations to not return a valid schema that clients can use to validate a request to or response from the JSON services.Note that a schema must be contained in a standard object as:
{"type":"schema", "data":{"schema":<em>schema</em>, "server":boolean}}If using
JsonHttpService.doSchema(String, boolean, String, String, int), an implementation can be as simple as:return doSchema(type, server, "path/to/client/schema.json", "path/to/server/schema.json", id);- Specified by:
doSchemain classJsonHttpService- Parameters:
type- the type for which a schema is requestedserver- true if the schema is for a message from the server; false if the schema is for a message from the clientrequest- the JSON request- Returns:
- a JSON Schema valid for the type
- Throws:
JsonException- if an error occurs preparing schema; if type is is not a type handled by this service, this must be thrown with an error code of 500 and the localized message ERROR_UNKNOWN_TYPE
-
getType
Description copied from class:JsonNamedBeanHttpServiceGet the JSON type supported by this service.- Specified by:
getTypein classJsonNamedBeanHttpService<OBlock>- Returns:
- the JSON type
-
getProvidingManager
Description copied from class:JsonNamedBeanHttpServiceGet the expected providing manager for the supported JSON type. This should normally be the default manager.- Specified by:
getProvidingManagerin classJsonNamedBeanHttpService<OBlock>- Returns:
- the providing manager
-