Class JsonRosterHttpService

java.lang.Object
jmri.server.json.JsonHttpService
jmri.server.json.roster.JsonRosterHttpService

  • Constructor Details

    • JsonRosterHttpService

      public JsonRosterHttpService(com.fasterxml.jackson.databind.ObjectMapper mapper)
  • Method Details

    • doGet

      public com.fasterxml.jackson.databind.JsonNode doGet(String type, 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 class JsonHttpService
      Parameters:
      type - the type of the requested object
      name - the system name of the requested object
      data - JSON data set of attributes of the requested object
      request - 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(String type, 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 class JsonHttpService
      Parameters:
      type - the type of the requested object
      name - the system name of the requested object
      data - JSON data set of attributes of the requested object to be updated
      request - 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(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 the JsonTimeHttpService 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 class JsonHttpService
      Parameters:
      type - the type of the requested list
      data - JSON data set of attributes of the requested objects
      request - 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 Locale locale, @Nonnull com.fasterxml.jackson.databind.JsonNode data, int id) throws JsonException
      Throws:
      JsonException
    • getRosterEntry

      public com.fasterxml.jackson.databind.JsonNode getRosterEntry(Locale locale, 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 locale
      name - the id of an entry in the roster
      id - 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(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 Locale
      entry - 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(Locale locale, String name, int id) throws JsonException
      Throws:
      JsonException
    • doSchema

      public com.fasterxml.jackson.databind.JsonNode doSchema(String type, boolean server, JsonRequest request) throws JsonException
      Description copied from class: JsonHttpService
      Get the JSON Schema for the data 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 class JsonHttpService
      Parameters:
      type - the type for which a schema is requested
      server - true if the schema is for a message from the server; false if the schema is for a message from the client
      request - 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(Locale locale, String name, com.fasterxml.jackson.databind.JsonNode data, int id) throws JsonException
      Edit an existing roster entry.
      Parameters:
      locale - the locale of the client
      name - the roster entry id
      data - the roster entry attributes to be edited
      id - message id set by client
      Returns:
      the roster entry as edited
      Throws:
      JsonException - if an error needs to be reported to the user