Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: No IntelliJ IDEA requirement

Developer Setup - For any issues send a mail to ole.devops@kuali.org

A developer's workstation can be setup by following the steps outlined below;

Info
titleHardware/Software Info

The following guide has been tested on the following hardware/software and will be updated periodically.

Hardware:

  1. Amazon EC2 Instance type (m1.medium)
    1. AMD 64 bit
    2. 2 CPUs
    3. 7.5 GB RAM
    4. 480 GB HDD
  2. Mac OS X
    1. 64 Bit
    2. 2 CPUs
    3. 8 GB RAM
    4. 240 GB Solid State HD

Software:

  1. Linux (3.2.28-45.62.amzn1.x86_64)
  2. OS X (10.7 and higher)
  3. Java 7
  4. Apache Tomcat 6 and 7

 

Info

The new improvised project model/structure does not require any additional configuration files, setup or any such overrides. The steps are very simple with details below;

  1. Checkout code
  2. Build the modules (one maven command)
  3. Reset databases (One maven command that is re-used for all the modules and also consistent across the modules)
  4. Bring up the applications in the IDE
  5. And everything should work right from the get go.
Warning
titleClean up default directories

Ensure you clean up the following folders. This may be around from pervious installations of OLE -

1. anything Anything under .m2/repository/org/kuali/ole;

2. anything under user.home/kuali/main/dev;

3. anything under user.home/kuali/main/local;

4. anything under user.home/.kuali

  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 - SE Development Kit 8 = JDK 1.8. (JDK 1.7 (= Java 7 ). The software can be downloaded from herealso works, but Oracle ended publishing security fixes for 1.7 in April 2015.). Download JDK from oracle.com.
    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.

      Warning
      titleTomcat 6 vs Tomcat 7
      Currently OLE has been throughly tested on tomcat 6.x. There are some issues with tomcat 7 which are being looked into.

      Tested versions are 6.x and 7.x.

       

      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.

      Increase memory and enable UTF-8 for file uploads in setenv.sh (Linux) or setenv.bat (Windows) in tomcat's bin directory, eg.

      Code Block
      title/usr/share/tomcat7/bin/setenv.sh
      export JAVA_OPTS="$JAVA_OPTS -Xms512m -Xmx1g -XX:MaxPermSize=512m -Dfile.encoding=UTF-8"
      Code Block
      titleC:\tomcat\bin\setenv.bat
      set "JAVA_OPTS=%JAVA_OPTS% -Xms512m -Xmx1g -XX:MaxPermSize=512m -Dfile.encoding=UTF-8"

      Make sure there is URIEncoding="UTF-8" in the Connector tag of tomcat's server.xml, eg.

      Code Block
      titleserver.xml
      collapsetrue
      <Connector port="8080" protocol="HTTP/1.1"
                 connectionTimeout="20000"
                 URIEncoding="UTF-8"
                 redirectPort="8443" />
    4. MySQL/Oracle - OLE supports both MySQL and Oracle and these can be downloaded from here

       

      Info
      titleOracle Install
      Oracle can be installed by following directions documented at Install Oracle 11g using Vagrant
      Info
      titleMySQL version
      KOLE is compatible with both 5.6.x and 5.5.x versions of MySQL server.


      For MySQL put the following options into the [mysqld] or [server] section of a MySQL server configuration file, eg. /etc/mysql/conf.d/mysql-ole.cnf/etc/my.cnf.d/server.cnf, or /etc/my.cnf

      Code Block
      titlemysql-ole.cnf
      collapsetrue
      [mysqld]
      lower_case_table_names=1
       
      # innodb_file_per_table is default from MySQL 5.6.6 on,
      # but also useful for previous versions.
      # https://dev.mysql.com/doc/refman/5.7/en/innodb-multiple-tablespaces.html
      innodb_file_per_table
      
      # Increasing open_files_limit is needed for MySQL before 5.6.8
      # when using innodb_file_per_table because
      # OLE has more than 1300 tables. Otherwise you get an
      # SQLException or CommunicationsException saying
      # "Communications link failure".
      open_files_limit=5000
      
      # Make all unicode characters work, eg. decomposed umlauts using
      # U+0308 (COMBINING DIAERESIS): äöü
      character-set-server = utf8
      collation-server     = utf8_unicode_ci
  3. Checking out the codebase 

     - OLE codebase can be checked out from the following SVNGithub location.

    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 (Replace svn update with svn checkout in the script below depending on if its the first time or not).

    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 (Replace the password with the appropriate root password in your MySQL install).

    Code Block
    collapsetrue
    #!/bin/bash
    echo "Refresh OLEFS database"
    cd ${OLE_DEVELOPMENT_WORKSPACE_ROOT}/ole-app/olefs
    mvn initialize -Pdb "-Djdbc.dba.username=[fill me] -Djdbc.dba.password=[fill me]
    echo "Refresh OLELS database (OLERICE2)"
    echo "Refreshing OLEDOCSTORE database"
    cd ${OLE_DEVELOPMENT_WORKSPACE_ROOT}/ole-docstore/ole-docstore-webapp
    mvn initialize -Pdb -Djdbc.dba.username=[fill me] -Djdbc.dba.password=[fill me]"
  4. Building the OLE modules (If you haven't run the automated scripts above in step 3, then follow the steps below for step by step building and resetting of the db)
    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 several modules but in order to build the whole project and generate the two war files (olefs.war and oledocstore.war), you must execute the following; 

    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 OLE application
      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 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 "-Djdbc.dba.username=[fill me]" "-Djdbc.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.war
    3. Building the OLEDOCSTORE application
      1. Database setup - CD project-directory/ole-docstore/ole-docstore-webapp

        run mvn initialize -Pdb

        InfoAlternatively if you have your MySQL server setup with a dba username/password, then update your maven command to the following and execute; mvn initialize -Pdb -Djdbc.dba.username=[fill me] -Djdbc.dba.password=[fill me]The docstore tables get created as part of the OLEFS build process. Both OLEFS and OLEDOCSTORE share the same schema.
      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
    4. IDE

    Setup 
    1. Setup

      IntelliJ IDEA: The following images show a typical IntelliJ setup. 

      Image ModifiedImage ModifiedImage ModifiedImage Modified
      Image ModifiedImage ModifiedImage Added 

      Eclipse: Coming soon.

       

  5. 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 OLE 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. OLEDOCSTORE
      1. Bibliographic Records - coming soon!
      2. Instance Records - coming soon!
      3. License Request/Agreement documents - coming soon!
  6. Verification
    InfoEnsure the JAVA_OPTS has the following memory settings: -Xms512m -Xmx1g -XX:MaxPermSize=512m

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

    1. localhost:8080/olefs
    2. localhost:8080/oledocstore
    Database Changes - The ole-app/ole-db module is the main module for the database portion for OLE.