Mercurial > dive4elements > framework
changeset 73:d1b8c91b4506
Added url '/service/{service}' to REST server to offer the actual service over HTTP.
artifacts/trunk@601 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Fri, 22 Jan 2010 11:56:28 +0000 |
parents | b01e47317a78 |
children | 66f43d1e69eb |
files | ChangeLog artifact-database/src/main/java/de/intevation/artifactdatabase/rest/RestApp.java artifact-database/src/main/java/de/intevation/artifactdatabase/rest/ServiceResource.java |
diffstat | 3 files changed, 80 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/ChangeLog Fri Jan 22 11:40:26 2010 +0000 +++ b/ChangeLog Fri Jan 22 11:56:28 2010 +0000 @@ -1,3 +1,12 @@ +2010-01-22 Sascha L. Teichmann <sascha.teichmann@intevation.de> + + * artifact-database/src/main/java/de/intevation/artifactdatabase/rest/ServiceResource.java: + New REST wrapper to call the service. Bound under '/service/{service}' + where '{service}' is the name of the service as announced by '/services'. + + * artifact-database/src/main/java/de/intevation/artifactdatabase/rest/RestApp.java: + Register new resource to web server. + 2010-01-22 Sascha L. Teichmann <sascha.teichmann@intevation.de> * artifact-database/src/main/java/de/intevation/artifactdatabase/rest/ServicesResource.java:
--- a/artifact-database/src/main/java/de/intevation/artifactdatabase/rest/RestApp.java Fri Jan 22 11:40:26 2010 +0000 +++ b/artifact-database/src/main/java/de/intevation/artifactdatabase/rest/RestApp.java Fri Jan 22 11:56:28 2010 +0000 @@ -36,6 +36,7 @@ Router router = new Router(context); router.attach(ServicesResource.PATH, ServicesResource.class); + router.attach(ServiceResource.PATH, ServiceResource.class); router.attach(FactoriesResource.PATH, FactoriesResource.class); router.attach(CreateResource.PATH, CreateResource.class); router.attach(ArtifactResource.PATH, ArtifactResource.class);
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/artifact-database/src/main/java/de/intevation/artifactdatabase/rest/ServiceResource.java Fri Jan 22 11:56:28 2010 +0000 @@ -0,0 +1,70 @@ +package de.intevation.artifactdatabase.rest; + +import org.restlet.representation.Representation; +import org.restlet.representation.EmptyRepresentation; + +import org.restlet.ext.xml.DomRepresentation; + +import de.intevation.artifacts.ArtifactDatabase; +import de.intevation.artifacts.ArtifactDatabaseException; + +import org.restlet.data.Request; +import org.restlet.data.Response; +import org.restlet.data.Status; +import org.restlet.data.MediaType; + +import org.apache.log4j.Logger; + +import org.w3c.dom.Document; + +import java.io.IOException; + +/** + * @author Sascha L. Teichmann (sascha.teichmann@intevation) + */ +public class ServiceResource +extends BaseResource +{ + private static Logger logger = Logger.getLogger(ServiceResource.class); + + public static final String PATH = "/service/{service}"; + + public static final String NO_SUCH_ACTION_MESSAGE = "no such service"; + + protected Representation innerPost(Representation requestRepr) { + + Document inputDocument = null; + try { + DomRepresentation input = new DomRepresentation(requestRepr); + input.setNamespaceAware(true); + inputDocument = input.getDocument(); + } + catch (IOException ioe) { + logger.error(ioe.getMessage()); + Response response = getResponse(); + response.setStatus(Status.CLIENT_ERROR_BAD_REQUEST, ioe); + return new EmptyRepresentation(); + } + + Request request = getRequest(); + + String service = (String)request.getAttributes().get("service"); + + ArtifactDatabase db = (ArtifactDatabase)getContext() + .getAttributes().get("database"); + + try { + return new DomRepresentation( + MediaType.APPLICATION_XML, + db.process(service, inputDocument, getCallMeta())); + } + catch (ArtifactDatabaseException adbe) { + logger.warn(adbe.getLocalizedMessage(), adbe); + Response response = getResponse(); + response.setStatus( + Status.CLIENT_ERROR_BAD_REQUEST, adbe.getMessage()); + return new EmptyRepresentation(); + } + } +} +// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :