-
Notifications
You must be signed in to change notification settings - Fork 767
Build Instructions
This project is tested to build on Java 8 (for master and 1.3) or Java 7 (for 1.2.x). It uses Maven as its build system, and should run on Maven 3.0 and above. The project makes use of Maven submodules to organize components.
Check out the project using a normal Git clone command:
git clone https://github.com/mitreid-connect/OpenID-Connect-Java-Spring-Server.git
The project has a hierarchical layout:
OpenID-Connect-Java-Spring-Server
+-- openid-connect-common
+-- openid-connect-client
+-- openid-connect-server
+-- openid-connect-server-webapp
openid-connect-common
, openid-connect-client
, openid-connect-server
, and openid-connect-server-webapp
are each managed as individual Maven submodules. The root of the project contains a pom.xml
file that references all sub-modules. Most Maven commands should be run from this parent project.
The project uses the Maven package
directive to build from the root of the project:
mvn package
By building in the root, Maven automatically builds all dependencies across submodules. Building directly in the submodules will often fail as the cross-dependencies on other portions of the project (such as the server's dependency on common) will not have been built yet.
The build process produces a .jar file for openid-connect-common
, openid-connect-client
, openid-connect-server
and a .war file for openid-connect-server-webapp
in the following directories:
openid-connect-client/target/openid-connect-client-{VERSION}.jar
openid-connect-common/target/openid-connect-common-{VERSION}.jar
openid-connect-server/target/openid-connect-server-{VERSION}.jar
openid-connect-server-webapp/target/openid-connect-server-webapp.war
Where {VERSION}
is the current build version of the project such as 1.2.0-SNAPSHOT
.
To skip unit tests, add this option:
mvn -DskipTests package
To skip JavaDoc generation:
mvn -Dmaven.javadoc.skip=true package
To configure an http and https proxy, add this option (especially because it seems that Maven on Linux doesn't always read the settings.xml file):
mvn -Dhttp.proxyHost=proxy -Dhttp.proxyPort=80 -Dhttps.proxyHost=proxy -Dhttps.proxyPort=80 package
The demo server webapp is configured out of the box to use an in-memory HyperSQL database (hsqldb). All data that the server stores, such as tokens, clients, and user authorizations, will be lost when the server is shut down. In order to persist data for longer than a single session, it is necessary to change the data source as configured in openid-connect-server-webapp/src/main/webapp/WEB-INF/data-context.xml
.
The server is auto-configured with one client and two users, which are enumerated in the file openid-connect-server-webapp/src/main/resources/db/hsql/clients.sql
and openid-connect-server-webapp/src/main/resources/db/hsql/users.sql
. These files are automatically loaded by the hsqldb data source and can be edited to hold other clients and users.
The project uses JCE through BouncyCastle which may require special installation. If you run into javax.crypto.JceSecurity or "TestDefaultJWTEncryptionAndDecryptionService.java [XXX,X] error: cannot find symbol" errors, do the following:
-
Add the BouncyCastle Provider to your JRE/JDK, per instructions at http://www.bouncycastle.org/wiki/display/JA1/Provider+Installation/
-
Download the "Java Cryptography Extension (JCE) Unlimited Strength Jurisdiction Policy Files" for your JRE version from http://www.oracle.com/technetwork/java/javase/downloads/index.html (scroll to the bottom of the page).
-
Install the new policy files per the README file included in the download. The download contains new versions of local_policy.jar and US_export_policy.jar. These files must be placed in your jre/lib/security folder(s - multiple on Windows), replacing the current files. If you wish to at some point revert back to your original policy files, store the original files elsewhere.
The openid-connect-server-webapp
module will produce a packaged WAR
file that can be deployed to a number of different servlet containers. To configure the server for local use, see the Server Configuration documentation. Most importantly, the issuer
value in the server configuration bean needs to be set to the URL that the server can be accessed from. The default value for the issuer
is http://localhost:8080/openid-connect-server-webapp/
.
The server webapp can be deployed using an embedded Jetty instance inside of Maven. To deploy to Jetty, first install the application to your local Maven repository by running this from the parent project directory:
mvn clean install
To run the embedded Jetty server and deploy the server webapp, run the following command from the openid-connect-server-webapp
directory (important: do not run this command from the parent project directory).
mvn jetty:run-war
This will deploy the server to http://localhost:8080/openid-connect-server-webapp/
. You can login with username: user
and password: password
.
The server webapp has been tested with Tomcat 6 and Tomcat 7. To deploy the server to Tomcat (or a similar servlet container), copy the generated .war file to the appropriate Tomcat webapps
directory, such as:
cp openid-connect-server-webapp/target/openid-connect-server.war /var/lib/tomcat6/webapps
Software is available under the Apache 2.0 license. Documentation available under the Creative Commons 3.0 By-NC license.