This guide walks a module developer through adding a new set of web service methods for a core object. There is a separate guide for core developers.
Conventions
The first thing to do is to read through the conventions section on the REST Web Services API For Clients page. Your module should follow similar conventions.Your REST URLs should be exposed as
Panel |
---|
Note: When creating a REST resource and sub-resource URI and name respectively, the absolute and relative path names should be written in all-lowercase ASCII letters. Avoid capital letters, camel caps to mention a few. The norm is to use lower case letters. Examples:
|
...
|
Getting the REST Web Services Jar into your project
See Requiring another module in your module
Ideally by the time you are reading this the restws module has been uploaded into OpenMRS's maven repository and you can simply You will need to check out the webservices.rest project and mvn clean install it to make it available to your module project. You will also need to add a few dependencies in your module's pom.xml files:
Code Block | ||
---|---|---|
| ||
<dependency> <groupId>org.openmrs.module</groupId> <artifactId>webservices.rest-api</artifactId> <version>1.0</version> <type>provided<<scope>provided</type>scope> </dependency> <dependency> <groupId>org.openmrs.module</groupId> <artifactId>webservices.rest<rest-omod</artifactId> <version>1.0</version> <type>provided<<scope>provided</type>scope> </dependency> |
Code Block | ||
---|---|---|
| ||
<dependency> <groupId>org.openmrs.module</groupId> <artifactId>webservices.rest-api</artifactId> <version>1.0</version> <type>jar</type> </dependency> <dependency> <groupId>org.openmrs.module</groupId> <artifactId>webservices.rest<rest-omod</artifactId> <version>1.0</version> <type>jar</type> </dependency> |
Note that some of the controller dependencies (e.g. BaseCrudController) are now part of package org.openmrs.module.webservices.rest.web.v1_0.controller.
Adding new Web Service URLs
Info |
---|
Our best-practices may change over the course of the sprint as we learn new things, but see the reportingrest module for an example module exposing web services. |
The documentation on how to create methods is the same as for the core developers. See that page for more information.
...
Code Block |
---|
@RequestMapping(value = "/rest/yourmoduleid/yourobjectid") |
Examples
The idgenws module was built as an example maven module that uses the restws code. It is a rudimentary example and does not use a lot of the helper parent classes. See http://svn.openmrs.org/openmrs-modules/idgenws/trunk
The reportingrest module was also built as a PoC. It is based on ant/build.xml and so the library setup, etc is slightly different than the maven example on this page. See the code for that here: http://svn.openmrs.org/openmrs-modules/reportingrest