Package jmri.server.json.roster
Class JsonRosterSocketService
java.lang.Object
jmri.server.json.JsonSocketService<JsonRosterHttpService>
jmri.server.json.roster.JsonRosterSocketService
Listen for changes in the roster and notify subscribed clients of changes to
the roster, including roster groups
-
Field Summary
Fields inherited from class jmri.server.json.JsonSocketService
connection, service -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidlisten()voidonClose()Perform any teardown required when closing a connection.voidonList(String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) Handle a request for a list of objects.voidonMessage(String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) Handle an inbound message.Methods inherited from class jmri.server.json.JsonSocketService
getConnection, getHttpService, getLocale, getVersion
-
Constructor Details
-
JsonRosterSocketService
-
-
Method Details
-
listen
-
onMessage
public void onMessage(String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) throws IOException, JmriException, JsonException Description copied from class:JsonSocketServiceHandle an inbound message.- Specified by:
onMessagein classJsonSocketService<JsonRosterHttpService>- Parameters:
type- The service type; if the implementing service responds to multiple types, it will need to use this to handle data correctlydata- JSON data; the contents of this will depend on the implementing servicerequest- The JSON request- Throws:
IOException- Thrown if the service cannot send a response; this will cause the JSON Server to close its connection to the client if openJmriException- Thrown if the request cannot be handled; throwing this will cause the JSON Server to pass a 500 UnsupportedOperation message to the clientJsonException- Thrown if the service needs to pass an error message back to the client
-
onList
public void onList(String type, com.fasterxml.jackson.databind.JsonNode data, JsonRequest request) throws IOException, JmriException, JsonException Description copied from class:JsonSocketServiceHandle a request for a list of objects. Note that this should not create listeners for items in the list, but should only create listeners for the object providing the list, if applicable.- Specified by:
onListin classJsonSocketService<JsonRosterHttpService>- Parameters:
type- The service type; if the implementing service responds to multiple types, it will need to use this to handle data correctlydata- JSON data; the contents of this will depend on the implementing servicerequest- The JSON request- Throws:
IOException- Thrown if the service cannot send a response; this will cause the JSON Server to close its connection to the client if openJmriException- Thrown if the request cannot be handled; throwing this will cause the JSON Server to pass a 500 UnsupportedOperation message to the clientJsonException- If the service needs to pass an error message back to the client; implementing services may throw a JsonException with code 400 and the localized message "UnlistableService" to indicate thattypeshould not be listed
-
onClose
Description copied from class:JsonSocketServicePerform any teardown required when closing a connection.- Specified by:
onClosein classJsonSocketService<JsonRosterHttpService>
-