Class JsonRosterHttpService
- java.lang.Object
-
- jmri.server.json.JsonHttpService
-
- jmri.server.json.roster.JsonRosterHttpService
-
public class JsonRosterHttpService extends JsonHttpService
-
-
Field Summary
-
Fields inherited from class jmri.server.json.JsonHttpService
mapper
-
-
Constructor Summary
Constructors Constructor Description JsonRosterHttpService(com.fasterxml.jackson.databind.ObjectMapper mapper)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description com.fasterxml.jackson.databind.JsonNode
doGet(java.lang.String type, java.lang.String name, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request)
Respond to an HTTP GET request for the requested name.com.fasterxml.jackson.databind.JsonNode
doGetList(java.lang.String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request)
Respond to an HTTP GET request for a list of items of type.com.fasterxml.jackson.databind.JsonNode
doPost(java.lang.String type, java.lang.String name, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request)
Respond to an HTTP POST request for the requested name.com.fasterxml.jackson.databind.JsonNode
doSchema(java.lang.String type, boolean server, JsonRequest request)
Get the JSON Schema for thedata
property of the requested type of JSON object.com.fasterxml.jackson.databind.JsonNode
getRoster(java.util.Locale locale, com.fasterxml.jackson.databind.JsonNode data, int id)
com.fasterxml.jackson.databind.JsonNode
getRosterEntry(java.util.Locale locale, java.lang.String name, int id)
Returns the JSON representation of a roster entry.com.fasterxml.jackson.databind.JsonNode
getRosterEntry(java.util.Locale locale, RosterEntry entry, int id)
Returns the JSON representation of a roster entry.com.fasterxml.jackson.databind.JsonNode
getRosterGroup(java.util.Locale locale, java.lang.String name, int id)
com.fasterxml.jackson.databind.JsonNode
getRosterGroups(JsonRequest request)
Get a list of roster groups.com.fasterxml.jackson.databind.JsonNode
postRosterEntry(java.util.Locale locale, java.lang.String name, com.fasterxml.jackson.databind.JsonNode data, int id)
Edit an existing roster entry.-
Methods inherited from class jmri.server.json.JsonHttpService
acceptForceDeleteToken, doDelete, doPut, doSchema, doSchema, getObjectMapper, message, message, message, message, message, throwDeleteConflictException
-
-
-
-
Constructor Detail
-
JsonRosterHttpService
public JsonRosterHttpService(com.fasterxml.jackson.databind.ObjectMapper mapper)
-
-
Method Detail
-
doGet
public com.fasterxml.jackson.databind.JsonNode doGet(java.lang.String type, java.lang.String name, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) throws JsonException
Description copied from class:JsonHttpService
Respond 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:
doGet
in classJsonHttpService
- Parameters:
type
- the type of the requested objectname
- the system name of the requested objectdata
- JSON data set of attributes 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.JsonNode doPost(java.lang.String type, java.lang.String name, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) throws JsonException
Description copied from class:JsonHttpService
Respond to an HTTP POST request for the requested name.This method should throw a 400 Invalid Request error if the named object does not exist.
- Specified by:
doPost
in classJsonHttpService
- Parameters:
type
- the type of the requested objectname
- the system name of the requested objectdata
- JSON data set of attributes of the requested object to be updatedrequest
- the JSON request- Returns:
- a JSON description of the requested object after updates have been applied
- Throws:
JsonException
- if the named object does not exist or other error occurs
-
doGetList
public com.fasterxml.jackson.databind.JsonNode doGetList(java.lang.String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) throws JsonException
Description copied from class:JsonHttpService
Respond to an HTTP GET request for a list of items of type.This is called by the
JsonServlet
to handle get requests for a type, but no name. Services that do not have named objects, such as theJsonTimeHttpService
should respond to this with a list containing a single JSON object. Services that can't return a list may throw a 400 Bad Request JsonException in this case.- Specified by:
doGetList
in classJsonHttpService
- Parameters:
type
- the type of the requested listdata
- JSON data set of attributes of the requested objectsrequest
- the JSON request- Returns:
- a JSON list or message containing type "list", the list as data, and the passed in id
- Throws:
JsonException
- may be thrown by concrete implementations
-
getRoster
@Nonnull public com.fasterxml.jackson.databind.JsonNode getRoster(@Nonnull java.util.Locale locale, @Nonnull com.fasterxml.jackson.databind.JsonNode data, int id) throws JsonException
- Throws:
JsonException
-
getRosterEntry
public com.fasterxml.jackson.databind.JsonNode getRosterEntry(java.util.Locale locale, java.lang.String name, int id) throws JsonException
Returns the JSON representation of a roster entry.Note that this returns, for images and icons, a URL relative to the root folder of the JMRI server. It is expected that clients will fill in the server IP address and port as they know it to be.
- Parameters:
locale
- the client's localename
- the id of an entry in the rosterid
- the message id set by the client- Returns:
- a roster entry in JSON notation
- Throws:
JsonException
- If no roster entry exists for the given id
-
getRosterEntry
public com.fasterxml.jackson.databind.JsonNode getRosterEntry(java.util.Locale locale, @Nonnull RosterEntry entry, int id) throws JsonException
Returns the JSON representation of a roster entry.Note that this returns, for images and icons, a URL relative to the root folder of the JMRI server. It is expected that clients will fill in the server IP address and port as they know it to be.
- Parameters:
locale
- the client's Localeentry
- A RosterEntry that may or may not be in the roster.id
- message id set by client- Returns:
- a roster entry in JSON notation
- Throws:
JsonException
- if an error needs to be reported to the user
-
getRosterGroups
@Nonnull public com.fasterxml.jackson.databind.JsonNode getRosterGroups(JsonRequest request) throws JsonException
Get a list of roster groups.- Parameters:
request
- the JSON request- Returns:
- a message containing the roster groups
- Throws:
JsonException
- if a requested roster group does not exist
-
getRosterGroup
@Nonnull public com.fasterxml.jackson.databind.JsonNode getRosterGroup(java.util.Locale locale, java.lang.String name, int id) throws JsonException
- Throws:
JsonException
-
doSchema
public com.fasterxml.jackson.databind.JsonNode doSchema(java.lang.String type, boolean server, JsonRequest request) throws JsonException
Description copied from class:JsonHttpService
Get the JSON Schema for thedata
property 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:
doSchema
in 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
-
postRosterEntry
public com.fasterxml.jackson.databind.JsonNode postRosterEntry(java.util.Locale locale, java.lang.String name, com.fasterxml.jackson.databind.JsonNode data, int id) throws JsonException
Edit an existing roster entry.- Parameters:
locale
- the locale of the clientname
- the roster entry iddata
- the roster entry attributes to be editedid
- message id set by client- Returns:
- the roster entry as edited
- Throws:
JsonException
- if an error needs to be reported to the user
-
-