The DRIVER+ adapter for the Common Information Space.
- Clone the Git repository
git clone https://github.com/DRIVER-EU/CommonInformationSpace.git
or use your Git Client UI. - Ensure you have maven on your computer and in the path. If not, you can download this from here.
- Execute the bat script 'mvnInstalls.bat' at
adaptor/maven/dependencies/
.
Check your local maven repository (default <userdir>/.m2/repository
) if the files were installed.
- The current ConnectorTemplate is able to send and receive CAP, EMSI, WMS, WFS, KML, KMZ and MLP if you just need one of them, you don't have to do anything else, just use the template
- If you need an adaptation of e.g. CAP handling (translation from app object structure to CAP) I would propose to copy this and rename it to any other project name, as the template will be updated, and to avoid overwriting your implementation
- In the connector sources in the implementation following files are interesting for you:
ConnectorCoreImpl.java
and the example CAP implementation:CapConnectorCoreExt.java
- For sending CAP message, you have to “translate” your content to the CAP Object structure, provided by the google library. If you have already a cap xml you can use this as it is shown in the example. if not, you send your java object structure from the application to the connector, and in the ConnectorCoreExt you are doing the translation.
- In the ConnectorCoreImpl you can see in the method:
public void msgReceived(CISPayload payload) throws InvalidObjectException {
log.info("--> messageReceived");
// translate the Object
// create and forward the message to the connector
AppCallbackHandlerImpl.getInstance().getCallback(CoreConstants.MSGTYPE_CAP).msgReceived(payload);
}
In this you have to change the checking of the type, if your xml is no CAP message, todo the forwarding to the spec. ConnectorCoreExt (yours).
That’s everything you have to do, the rest is done already ;-)
Depending on your application, you could add the connector and core library directly to your application (deep integration), and use directly the java interfaces (implementation). If this is not possible, then you have to use the standalone application. This exposed a REST IF to which you can POST the messages. To send a message to the StandaloneApplication you have to run it (e.g. directly in eclipse as java application).
The REST endpoint is reachable via the POST to http://localhost:8090/notify As parameters you have to specify msgType (one of: CAP, EMSI, KML, KMZ, WMS, WFS, MLP) and msg (the message itself (cap xml, kml xml, WFS uri, WMS uri, MLP string...)
Two basic examples on how to use the Connector are available. Both examples are Mavne projects that can be run directly from any Java IDE. For example in Eclipse: import -> maven -> existing maven project.
-
Using Deep Integration: https://github.com/DRIVER-EU/test-bed-adapter/tree/master/examples/java/cis-adapter-test/test-deep-integration-adapter This example introduces a dependency on the connector and the CIS Core directly from your application.
-
Using the REST endpoint of the CIS Core Standalone Adaptor: https://github.com/DRIVER-EU/test-bed-adapter/tree/master/examples/java/cis-adapter-test/test-rest-adapter This example requires you to run the CIS Core Standalone Adaptor as well: https://github.com/DRIVER-EU/CommonInformationSpace/tree/master/adaptor/executables/CISCoreStandalone to expose the REST endpoint.
see: HowTo.docx
The adaptor provides a Swagger-UI. You can all this with: http://localhost:8180/swagger-ui.html on that you can test the functionality and basic communication configuration.