Required Software
In general, the most recent versions can (and should) probably be used for each of these. But the versions below are the ones I have working as of May 2019.
- Java OpenJDK 11.0.2
- Eclipse 2019-03
- Git 2.9.0
- Apache Maven 3.6.0
- SQL Developer 3.2.20.09 (Not required for build, but useful for support)
Setup
Install the OpenJDK, Eclipse, git, and Maven normally. Modify your path as necessary so that you can run Maven and Java from the git bash shell.
Clone all of the git projects from the 'ras' and 'ras-kuali' groups on the Tufts GitLab (https://gitlab.it.tufts.edu/ras, https://gitlab.it.tufts.edu/ras-kuali).
Visual Studio Libraries?
At one point in the past (~2016), an installation of Visual Studio was required to build some parts of the KC software on Windows, due to needing some specific C++ libraries for a part of the coeus-webapp build. I *believe* this is no longer required, but as I still have it installed on my system, I'll leave the info here in case it is needed.
- Installed software: Microsoft Visual Studio 12.0
- Environment variables set in git bash:
- VS120COMNTOOLS=C:\Program Files (x86)\Microsoft Visual Studio 12.0\Common7\Tools\
- VCTargetsPath="C:\Program Files (x86)\MSBuild\Microsoft.Cpp\v4.0\V120"
When these libraries were not present on older releases, the node.js section of the coeus-webapp build would fail with a message related to missing MS C++ libraries.
Build Process
Detailed instructions for building the Kuali Coeus software can be found in the Kuali git repo at https://github.com/KualiCo/kc/blob/master/README.md.
The basic steps for building the Tufts release are to run the maven build in each of the following projects using the given commands:
- schemaspy – mvn clean install -Dgrm.off=true
- kc-rice – mvn clean install -Dgrm.off=true
- kc-api – mvn clean install -Dgrm.off=true
- kc-s2sgen – mvn clean install -Dgrm.off=true
- kc – mvn clean install -Dgrm.off=true
- kc-custom – ./build.sh
The "-Dgrm.off=true" flag is necessary to disable the proprietary parts of the Kuali builds. If the flag is not provided, the build will fail while attempting to download artifacts from the private internal Kuali repo.
Each build in steps 1-5 will create the jar/war file for that project and store it in your local maven repository. The final step will create the final application .war file at kc-custom\coeus-webapp-custom\kc-dev.war. This file should be uploaded to the tomcat\webapps directory to deploy and run the KC application.