This is an example of a user service which generates thumbnail previews of images.
Before building and/or running the pzsvc-preview-generator service, please ensure that the following components are available and/or installed, as necessary:
- Java (JDK for building/developing, otherwise JRE is fine)
- ElasticSearch
- Eclipse, or any maven-supported IDE
- Amazon S3 bucket access
- Access to Nexus is required to build
Ensure that the nexus url environment variable ARTIFACT_STORAGE_URL
is set:
$ export ARTIFACT_STORAGE_URL={Artifact Storage URL}
For additional details on prerequisites, please refer to the Piazza Developer's Guide Core Overview or the prerequisites for using Piazza section for additional details.
Create the directory the repository must live in, and clone the git repository:
$ mkdir -p {PROJECT_DIR}/src/github.com/venicegeo
$ cd {PROJECT_DIR}/src/github.com/venicegeo
$ git clone git@github.com:venicegeo/pzsvc-preview-generator.git
$ cd pzsvc-preview-generator
Note: In the above commands, replace {PROJECT_DIR} with the local directory path for where the project source is to be installed.
As noted in the Requirements section, to build and run this project, ElasticSearch is required. The application.properties
file controls URL information for ElasticSearch connection configurations.
To edit the port that the service is running on, edit the server.port
property.
To build and run the preview generator locally, pzsvc-preview-generator can be run using Eclipse any maven-supported IDE. Alternatively, pzsvc-preview-generator can be run through command line interface (CLI), by navigating to the project directory and run:
mvn clean install -U spring-boot:run
This will run a Tomcat server locally with the service running on port 8086 (unless port was modified per 'Configuring' section).
Note: This Maven build depends on having access to the
Piazza-Group
repository as defined in thepom.xml
file. If your Maven configuration does not specify credentials to this Repository, this Maven build will fail.
To run the pzsvc-preview-generator unit tests from the main directory, run the following command:
$ mvn test