Back to index page
How to expose custom Greenstone 3 web services on GS3's server
What you need:
- Java JDK installed
- Greenstone 3
In this document,
- $GSDL3HOME refers to the full path to your Greenstone 3 installation.
- GS3 may be used as a shorthand to refer to Greenstone 3.
Sections
In the steps below, I am assuming that your web service class will be passing either
- simple data types: strings, ints, floats, characters, boolean, arrays of simple data types, etc., or
- Java Collection data types: HashMap, Sets, Lists of simple data types, for which Apache Axis--which comes with Greenstone 3--already provides web service support.
If this is indeed the case, the default behaviour that will apply when the steps below are followed will be appropriate.
DETAILS: This default behaviour is that the "provider" property of the web service will be set to Java:RPC in the web service descriptor file (*.wsdd) used by Apache Axis to deploy your web service.
Assuming that your web service class is going to make use of Greenstone 3 functionality, the classpath to all of Greenstone 3's java code is already available in the Ant buildfile that will be used to expose your web services on Greenstone 3's services page.
- Write the Java class that will contain the methods you wish to expose as operations on Greenstone's "services" page.
Note that I haven't tried working with constructors other than the default constructors (the ones that take no parameters).
- Copy the contents of the java file into a new java file and name it <someWebService>SOAPServer.java.in. For example, this duplicate file would be called MyServicesSOAPServer.java.in
- Edit <someWebService>SOAPServer.java.in so that
- its class name is <someWebService>SOAPServer@sitename@
- its constructor is similarly called <someWebService>SOAPServer@sitename@
- Any other explicit references in the file to the class name must similarly be renamed to <someWebService>SOAPServer@sitename@. For instance, a Logger object for the class or static references to the class must now refer to <someWebService>SOAPServer@sitename@.
- Place the file <someWebService>SOAPServer.java.in into the folder $GSDL3HOME/resources/java, alongside the other SOAPServer.java.in already in here.
- OPTIONAL STEP: Open $GSDL3HOME/build.xml and you can add your web service name (<someWebService>SOAPServer) to the list of web services already mentioned in there. This will then be available in the command-line menu when you try to deploy a web service using Apache Ant.
- Open an X-term or DOS-prompt and go into the $GSDL3HOME directory.
- Make sure that Greenstone 3's Tomcat server is running. If it's not running, do:
ant start
- Deploy your site by typing:
ant soap-deploy-site
It will ask you 3 things:
- Type the name of the Site you wish to deploy it for. It can be any existing remote Site that you have access to, or if you wish to deploy it locally, you would type
localsite
- Type the name of the Greenstone 3 web service you wish to deploy. The default Greenstone 3 SOAPServer and QBRSOAPServer (for Query, Browse and Retrieve operations) are already in the list of web services that can be deployed. And because you have now added your web service class in there as well, you can type its name:
<someWebService>SOAPServer
- Finally, give the web service a name. For instance, you can type "MyGS3WebServices" or something more descriptive of the web services you have created. Alternatively, you can choose the default web service name it will give you, which will be of the form
<someWebService>SOAPServer<NameOftheSiteYouDeployedItFor>
It's handy to remember the name of the web services you deployed in case you wish to undeploy it (see Section C below).
- If all goes well, it will have deployed your web service. To check that this is indeed the case, point your web browser to the greenstone server's services page for the Site you deployed the web service for. This page will list all the web services deployed.
For example, the http://HOST:PORT/greenstone3/services page, when deployed for the Site "localsite" if on localhost and port 8080, would be http://localhost:8080/greenstone3/services
- You need the name of the web services you deployed. If you don't remember, go to the services page for the Site you deployed it on. (http://HOST:PORT/greenstone3/services for the HOST and PORT values that apply to your deployment situation).
- Open an X-term or DOS prompt and go into the $GSDL3HOME folder.
- Type:
soap-undeploy-site
It will ask you for the name of the web service you wish to undeploy. Type the name.
- If your web service was deployed and you typed the web service name correctly, it will now be undeployed. To check, go to http://HOST:PORT/greenstone3/services and check that your web service is no longer in the list of hosted services.