Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  1. KIS account

    In order to have read/write access to the OLE version control repository, one must have a valid KIS account. Please contact your project manager to have an account created. 

  2. Required Software
    1. Java SDK - JDK 1.7 (Java 7). The software can be downloaded from here.
    2. Maven 3.x - OLE uses maven as the build management tool and the software can be downloaded from here. Maven uses this idea of pulling down the required artifacts (jar files) from a central repository. Sometimes the dependent jars may not be found in the central repository due to licensing issues and so Kuali also maintains a repository that has our own published artifacts. A common example would be oracle jar that is not published to the central repository. In order to download jars from the Kuali repository, the settings.xml under user.home/.m2 folder needs to be updated with the following entries: 

       

      Code Block
      languagehtml/xml
      titleMaven Settings.xml
      collapsetrue
      <?xml version="1.0" encoding="UTF-8"?>
       <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
          <mirrors> 
           <mirror> 
              <id>kuali.private</id> 
              <mirrorOf>*</mirrorOf> 
              <url>http://nexus.kuali.org/content/groups/developer</url> 
           </mirror>
          </mirrors> 
         <servers>
           <server> 
            <id>kuali.private</id>
            <username>developer</username> 
            <password>[send a mail to ole.devops@kuali.org for the password]</password> 
           </server> 
         </servers> 
      </settings>
    3. Tomcat - OLE is deployed under Tomcat web container. The software can be downloaded from here.

      Info
      titleRequired database libraries for tomcat
      Ensure the following jars are in your tomcat.home/lib directory; ojdbc6.jar and mysql-connector-java-5.1.13.jar. These jars can be found in your user.home/.m2/repository directory as it gets downloaded via maven once you do a build.

      These jars will be required for database connectivity when the applications are launched in tomcat.

    4. MySQL/Oracle - OLE supports both MySQL and Oracle and these can be downloaded from here

       

      Info
      titleOracle Install
      Oracle installation is tricky on a mac/ubuntu workstations, and so as a temporary workaround, install a VM with Windows or Oracle's VirtualBox that comes with Oracle bundled. 
      Warning
      titleMySQL version
      At the moment the latest version of MySQL which is 5.6 wont work with the impex tool that we have. One must install the 5.5 version of the MySQL server.
  3. Checking out the codebase 

     

    Info

    You can download or use the following scripts to update/checkout the code, build and reset the databases for the modules. You will need to save these scripts in files with .sh extension and run using ./name-of-the-file.sh command. Also ensure you have the system property OLE_DEVELOPMENT_WORKSPACE_ROOT set.

    a. Checkingout/Updating from SVN and building

    Code Block
    collapsetrue
    #!/bin/bash
    clear
    echo ${OLE_DEVELOPMENT_WORKSPACE_ROOT} 
    cd ${OLE_DEVELOPMENT_WORKSPACE_ROOT}
    echo "Updating from SVN"
    svn update
    echo "Building OLE"
    mvn clean install -DskipTests=true

    b. DB Reset

    Code Block
    collapsetrue
    #!/bin/bash
    echo "Refresh OLEFS database"
    cd ${OLE_DEVELOPMENT_WORKSPACE_ROOT}/ole-app/olefs
    mvn initialize -Pdb -Dmysql.dba.password=root
    echo "Refresh OLELS database (OLERICE2)"
    cd ${OLE_DEVELOPMENT_WORKSPACE_ROOT}/ole-rice2/ole-rice-webapp
    mvn initialize -Pdb -Dmysql.dba.password=root
    echo "Refreshing OLEDOCSTORE database"
    cd ${OLE_DEVELOPMENT_WORKSPACE_ROOT}/ole-docstore/ole-docstore-webapp
    mvn initialize -Pdb -Dmysql.dba.password=root

    - OLE codebase can be checked out from the following SVN location. Until the trunk gets stabilized for 1.0.0, use the following svn location.

  4. Building the OLE modules 
    Info
    The database refresh process for all the modules has been streamlined. In order to run the db refresh, you will need to change into the web app directory of the individual modules and run the maven command as explained below.

    OLE is made up of three modules namely OLEFS, OLELS and OLEDOCSTORE. 

    1. From the root directory of where the OLE codebase has been checked out run the following maven command 

      mvn clean install -DskipTests=true
    2. Building the OLEFS application - OLEFS is the financial module with KFS as the core. KFS is an ant style project, so even though it may look it has pom file and a maven build process, behind the scenes several ant targets are called to get the application ready for deployment.
      1. Database setup - The default database setup is MySQL and running the following maven command will setup a clean database for OLEFS. The default username and passwords are OLE/OLE. Also the default dba username is root and password is none.

        cd project-directory/ole-app/olefs

         

        run mvn initialize -Pdb

        Info
        Alternatively if you have your MySQL server setup with a dba username/passoword, then update your maven command to the following and execute; mvn initialize -Pdb -Dmysql.dba.username=[fill me] -Dmysql.dba.password=[fill me]
      2. Verify the database got created by; there should be an entry for OLE in MySQL
      3. Generating the war file - The war file would have been generated as part of 4.a and can be located under project-root-directory/ole-app/ole-fs/target/olefs-[version]-webapp.war
    3. Building the OLELS application
      1. Database setup - The default database setup is MySQL and can be done using the following maven command 

        cd project-directory/ole-rice2/ole-rice-webapp

         

        run mvn clean install -Pdb

        Info
        Alternatively if you have your MySQL server setup with a dba username/password, then update your maven command to the following and execute; mvn clean install -Pdb,mysql -Dimpex.dba.username=[fill me] -Dimpex.dba.password=[fill me]
      2. Verify the database got created; there should be an entry for OLERICE2 in MySQL. 
      3. Generating the war file - The war file would have been generated as part of 4.a and can be located under the project-root-directory/ole-rice2/ole-rice-webapp/target/ole-rice-webapp-[version].war

         

    4. Building the OLEDOCSTORE application
      1. Database setup - CD project-directory/ole-docstore/ole-docstore-webapp

        run mvn initialize -Pdb

        Info
        Alternatively if you have your MySQL server setup with a dba username/password, then update your maven command to the following and execute; mvn clean install -Pdb,mysql -Dimpex.dba.username=[fill me] -Dimpex.dba.password=[fill me]
      2. Generating the war file - The war file would have been generated as part of step 4.a and can be located under the project-root-directory/ole-docstore/ole-docstore-webapp/target/oledocstore.war
  5. IDE Setup

    Developers are free to use IDE of their choice, but in Kuali the two most common ones are Eclipse and IntelliJ

    IntelliJ Setup - The following screen shot shows how all three applications can be deployed at the same time;

    Gallery
    columns2
    sortname
    titleIntellij Setup

  6. Auto data loads during start-up
    Info
    The auto ingestion of workflow files and other reference data files happens only once when the database state is clean. As the application starts up, a flag is checked in the database for both OLEFS and OLELS to ensure the files haven't been loaded previously. In an event you need to force the workflow ingestion at any given point, you will need to go to the appropriate class that are doing loading of the files and force it to do so by turning the forceLoad flag to true.
    1. OLEFS
      1. workflows - Folders under src/main/resources/org/kuali/ole/workflows folder within the olefs module get copied to a location specified in the Bootstrap-config.xml file where they are picked up from for auto ingestion. This is usually under user.home/kuali/main/local/olefs/workflows/pending folder. The XmlPoller scans the pending folder every 30 seconds and automatically ingests the files and moves it the loaded folder under user.home/kuali/main/local/olefs/workflows. If there are any issues, then it moves those files under problem folder.
    2. OLELS 
      1. workflows - There are default workflow xml files that get ingested that define the document types for the OLELS application. These files are under src/main/org/kuali/ole/workflow folder in the ole-rice2/ole-rice-webapp folder.
      2. circulation policies - DefaultCircPolicies.xml is that file that gets ingested at application startup. This file is under ole-rice2/ole-rice-webapp/src/main/resources/org/kuali/ole/deliver
      3. location - There are three location files that are ingested namely DukeLocations.xml, IndianaLocations.xml and UChicagoLocations.xml which are under ole-rice2/ole-rice-webapp/src/main/resources/org/kuali/ole/location
      4. ingest profile - YBPSample.xml is the file which is used for the staff upload screen (batch ingest) can be found under ole-rice2/ole-rice-webapp/src/main/resources/org/kuali/ole/ingest
      5. patrons - DefaultPatrons.xml  contains default patrons that the system needs before the application startup. This can be found under ole-rice2/ole-rice-webapp/src/main/resources/org/kuali/ole/patron
    3. OLEDOCSTORE
      1. Bibliographic Records - coming soon!
      2. Instance Records - coming soon!
      3. License Request/Agreement documents - coming soon!
  7. Verification

    Once tomcat is up and running you can open up a browser and try the following;

    1. localhost:8080/olefs
    2. localhost:8080/olerice2
    3. localhost:8080/oledocstore

...