Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Migrated to Confluence 5.3
{composition-setup} {deck:id=Kuali OLE} {card:label=Overview} *Kuali Open Library Environment* is an open source enterprise software solution to fulfill libraries needs in terms of financial and content management. Financial management is implemented using the already developed *[Kuali Financial System|http://www.kuali.org/kfs]* which is bundled within OLE. Content management has been implemented using the Apache Jackrabbit and Apache Solr technologies, details of which can be found in subsequent sections or tabs on this main page. KOLE is a mix of ant style and maven style applications. There is a maven wrapper for the [ant|http://ant.apache.org/] part of the project (KFS) and so one can build the whole application using few maven commands. {gliffy:name=OLE|align=left|size=L|version=3} {card} \\ {card:label = Continuous Integration} {info}Continuous Integration (CI) is vital for any project as it ensures detection of issues with the code in a timely manner and also validity of a build. OLE follows a CI process as described below.{info} The Kuali configuration management pool manages deployments to DEV and TEST environments in the Amazon cloud.&nbsp; # Dev Environment - Coming soon\! # [Test Environment|https://wiki.kuali.org/display/KULRICE/OLE+Deploy] {card} {card:label = OLE Release Documentation} OLE is still in the beta phase of development with an installable release expected to be during early 2013. There have been two releases for the user community to experiment with the feature set and performance of the system up to date and the documentation can be found in the sections below; # h4. [Overall Release Documentation|https://wiki.kuali.org/display/OLE/OLE+Release+Documentation] # h4. [OLE 0.8 Iteration Release Documentation|https://wiki.kuali.org/display/OLE/OLE+Release+Documentation+-+for+Milestone+0.8] {card} {card:label = Developer's Guide} h4. Developer Setup A developer's workstation can be setup by following the steps outlined below; # 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.&nbsp; # Required Software ## Java SDK - Currently OLE is developed and tested using JDK 1.6 (Java 6) and soon we will be moving to JDK 1.7 (Java 7). The software can be downloaded from [here|http://www.oracle.com/technetwork/java/javase/downloads/index.html]. ## Maven 3.x - OLE uses maven as the build management tool and the software can be downloaded from [here|http://maven.apache.org/download.cgi]. Maven uses this idea of pulling down the required artifacts (jar files) from a central repository. Sometimes the&nbsp;dependent&nbsp;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&nbsp;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:&nbsp; {code:language=html/xml|title=Maven settings.xml|collapse=true}<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>[check with your project lead]</password> </server> </servers>{code} ## Tomcat - OLE is deployed under Tomcat web container. The software can be downloaded from [here|http://tomcat.apache.org/download-70.cgi]. Ensure the following jars are in your tomcat.home/lib directory; ojdbc6.jar and mysql-connector-java-5.1.13.jar. These jars will be required for database connectivity when the applications are launched in tomcat. ## MySQL/Oracle - OLE supports both MySQL and Oracle and these can be downloaded from [here|http://www.oracle.com/technetwork/indexes/downloads/index.html].&nbsp; {info:title=Linux}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.{info} {warning:title=MySQL 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.{warning} # Checking out the codebase - OLE codebase can be checked out from the following [SVN|https://svn.kuali.org/repos/ole/trunk/] location. # Building the OLE modules - OLE is made up of three modules namely OLEFS, OLELS and OLEDOCSTORE.&nbsp; ## From the root directory of where the OLE codebase has been checked out run the following maven command&nbsp; {noformat}mvn clean install -DskipTests=true{noformat} ## 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. ### 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. {noformat}
Wiki Markup
Deck
idKuali OLE
Card
labelOverview

Kuali Open Library Environment is an open source enterprise software solution to fulfill libraries needs in terms of financial and content management. Financial management is implemented using the already developed Kuali Financial System which is bundled within OLE. Content management has been implemented using the Apache Jackrabbit and Apache Solr technologies, details of which can be found in subsequent sections or tabs on this main page.

KOLE is a mix of ant style and maven style applications. There is a maven wrapper for the ant part of the project (KFS) and so one can build the whole application using few maven commands.

Card
labelContinuous Integration
Info

Continuous Integration (CI) is vital for any project as it ensures detection of issues with the code in a timely manner and also validity of a build. OLE follows a CI process as described below.

The Kuali configuration management pool manages deployments to DEV and TEST environments in the Amazon cloud. 

  1. Dev Environment - Coming soon!
  2. Test Environment
Card
labelOLE Release Documentation

OLE is still in the beta phase of development with an installable release expected to be during early 2013. There have been two releases for the user community to experiment with the feature set and performance of the system up to date and the documentation can be found in the sections below;

  1. Overall Release Documentation

  2. OLE 0.8 Iteration Release Documentation

Card
labelDeveloper's Guide

Developer Setup

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

  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 - Currently OLE is developed and tested using JDK 1.6 (Java 6) and soon we will be moving to 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>[check with your project lead or the configuration manager]</password>
              </server>
          </servers>
      
      </settings>
    3. Tomcat - OLE is deployed under Tomcat web container. The software can be downloaded from here. Ensure the following jars are in your tomcat.home/lib directory; ojdbc6.jar and mysql-connector-java-5.1.13.jar. 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
      titleLinux

      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 - OLE codebase can be checked out from the following SVN location.
  4. Building the OLE modules - 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 

      No Format
      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.

        No Format
        cd project-directory/ole-app/ole-fs
        mvn initialize -Pdb
        
        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]
{noformat} ### Verify the database got created by; there should be an entry for OLE in MySQL ### Generating the war file - The war file would have been generated as part of 4.a and can be located under
      1. Verify the database got created by; there should be an entry for OLE in MySQL
      2. 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/
*
      1. olefs-
\
      1. [version
\
      1. ]-webapp.war
*;&nbsp; ## Building the OLELS application ### Database setup - The default database setup is MySQL and can be done using the following maven command&nbsp; {noformat}
    1. Building the OLELS application
      1. Database setup - The default database setup is MySQL and can be done using the following maven command 

        No Format
        cd project-directory/ole-rice2/ole-rice-db
        mvn clean install -Pdb,mysql
      1. 
        
        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]
{noformat} ### Verify the database got created; there should be an entry for OLERICE2 in MySQL.&nbsp; ### Generating the war file - The war file would have been generated as part of 4.a and can be located under the
      1. Verify the database got created; there should be an entry for OLERICE2 in MySQL. 
      2. 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/
*
      1. ole-rice-webapp-
\
      1. [version
\
      1. ].war
* ###
      1. Module
      1. specific
      1. configuration
      1. file
      1. -
      1. This
      1. is
      1. a
      1. file
      1. that
      1. the
      1. Rice
      1. framework
      1. will
      1. look
      1. for
      1. under
      1. user.home/kuali/main/dev
      1. on
      1. the
      1. local
      1. machine
      1. and
      1. any
      1. properties
      1. such
      1. as
      1. db
      1. connection
      1. info,
      1. application
      1. urls
      1. etc
      1. will
      1. be
      1. overridden.
      1. Copy
      1. the
      1. following
      1. file
      1. to
      1. your
      1. user.home/kuali/main/
dev and update it before continuing with Step 5.&nbsp;[^OLE_Rice2-config.xml]. Ensure the name of the file is similar to the module name and in this case it is set to OLE_Rice2. ## Building the OLEDOCSTORE application ### Database setup - OLEDOCSTORE is based on Apache Jackrabbit core and currently running the application sets up the db directly. ### Generating the war file - The war file would have been generated as part of step 4.a and can be located under the
      1. dev OLE_Rice2-config.xml. Ensure the name of the file is similar to the module name and in this case it is set to OLE_Rice2.
    1. Building the OLEDOCSTORE application
      1. Database setup - OLEDOCSTORE is based on Apache Jackrabbit core and currently running the application sets up the db directly.
      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/
*
      1. oledocstore.war
* #
  1. Deployment
  1. to
  1. tomcat
##
    1. OLEFS
    1. -
    1. Rename
    1. the
    1. war
    1. file
    1. from
    1. 4.b.iii
    1. to
    1. olefs.war
    1. and
    1. copy
    1. it
    1. to
    1. your
    1. local
    1. tomcat's
webapps&nbsp;folder. ## OLELS - Rename the war file from
    1. webapps folder.
    2. OLELS - Rename the war file from 4.c.iii
    1. to
    1. olerice2.war
    1. and
    1. copy
    1. it
    1. to
    1. your
    1. local
    1. tomcat'
s&nbsp;webapps
    1. s webapps folder.
##
    1. OLEDOCSTORE

    1. -

    1. Simply

    1. copy

    1. the

    1. oledocstore.war

    1. to

    1. your

    1. local

    1. tomcat's

    1. webapps

    1. folder.

{
    1. Code Block
:
    1. title
=
    1. If
    1. you
    1. dont
    1. want
    1. to
    1. perform
    1. steps
    1. a,
    1. b
    1. and
    1. c,
    1. alternatively
    1. you
    1. can
    1. point
    1. your
    1. local
    1. tomcat
    1. to
    1. the
    1. individual
    1. modules.
    1. The
    1. following
    1. lines
    1. need
    1. to
    1. be
    1. added
    1. to
    1. the
    1. file
    1. named
    1. server.xml
    1. under
    1. the
    1. tomcat.home.directory/conf
    1. folder
    1. and
    1. within
    1. the
    1. <Host>
    1. </Host>
    1. tags.
}
    1. <Context docBase="project-root-directory/ole-app/ole-fs/target/ole-fs-webapp" path="/olefs"/>
      
      <Context docBase="project-root-directory/ole-rice2/ole-rice-webapp/target/ole-rice-webapp" path="/olerice2"/>
      
      <Context docBase="project-root-directory/ole-docstore/ole-docstore-webapp/target/ole-docstore-webapp-webapp" path="/oledocstore"/>
{code} # Verify the applications are up and running: ##
  1. Verify the applications are up and running:

    Info

    Ensure the JAVA_OPTS have the following entry too for the memory settings; -Xms512m -Xmx1g -XX:MaxPermSize=512m

    1. localhost:8080/olefs
##
    1. localhost:8080/olerice2
##
    1. localhost:8080/
oledocstore&nbsp; The above steps have been tested and verified to get a working OLE codebase on a local developer's machine
    1. oledocstore 

The above steps have been tested and verified to get a working OLE codebase on a local developer's machine (Mac/Ubuntu).

The

steps

should

be

very

similar

on

windows

too

and

if

there

are

any

issues,

contact

devops@ole.kuali.org.

There

are

few

scripts

attached

here

also

that

essentially

perform

the

steps

above

in

an

automated

fashion.

&nbsp; {info:title=System Variables}Ensure the following system properties are set;

 

Info
titleSystem Variables

Ensure the following system properties are set;

OLE_WORKSPACE_ROOT


TOMCAT_HOME

On

a

Mac/Ubuntu

this

will

be

typically

found

in

the

.bashrc

or

the

.profile

files;

On

a

windows

machine

its

set

in

the

environment

variables

section

under

Advanced

Settings

in

the

Control

Panel{info} # [^ole.sh]&nbsp;\- Script to checkout codebase and build to produce the deployable artifacts. # [^db

Panel

  1. ole.sh - Script to checkout codebase and build to produce the deployable artifacts.
  2. db-refresh-mysql.sh
]&nbsp;\
  1.  -
  1. Script
  1. to
  1. refresh
  1. local
  1. MySQL
  1. DB
  1. for
  1. OLEFS
  1. and
  1. OLELS
  1. (
  1. Ensure
  1. to
  1. update
  1. this
  1. script
  1. with
  1. the
  1. appropriate
  1. impex.dba.password
  1. (root
  1. password
  1. for
  1. your
  1. MySQL
  1. installation)
) # [^InitializeAndStartTomcat.sh]&nbsp;\- Script to copy the deployable artifacts to local tomcat and bring up the applications. h4. IDE Setup \- Developers are free to use IDE of their choice, but in Kuali the two most common ones are [Eclipse|http://www.eclipse.org/downloads/] and [IntelliJ|http://www.jetbrains.com/idea/] h4. Overriding default properties&nbsp; # *OLEFS* \- In order to override the default properties we need to have a property file created in the right place where the application knows to look for. ## From the console change into the project root directory&nbsp; ## cd
  1. )
  2. InitializeAndStartTomcat.sh - Script to copy the deployable artifacts to local tomcat and bring up the applications.

IDE Setup

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

Overriding default properties 

  1. OLEFS- In order to override the default properties we need to have a property file created in the right place where the application knows to look for.
    1. From the console change into the project root directory 
    2. cd ole-app/ole-fs
##
    1. mvn
    1. generate-resources
\
    1. -Plocal
###
      1. This
      1. generates
      1. a
      1. file
      1. called
      1. ole-fs.properties
      1. under
      1. user.home/.kuali/ole
# *OLELS* # *OLEDOCSTORE* h4. Overriding default properties contd. || || OLEFS || OLELS || OLEDOCSTORE || | log4j.properties | Update
  1. OLELS
  2. OLEDOCSTORE

Overriding default properties contd.

 

OLEFS

OLELS

OLEDOCSTORE

log4j.properties

Update ole-fs.properties

under

user.home/.kuali/ole

with

the

following

entries \\ \\

entries

ole.fs.log4j.override=true

\\


ole.fs.log4j=

\

[path

the

log4j.properties

file

\] \\ | Edit the

]

Edit the OLE_Rice2-connfig.xml

file

under

the

"Developer

Setup"

section

#4.b.iv

with

the

following

entry \\ \\ <param

entry

<param name="log4j.settings.path">

path

to

the

log4j.properties

file

</param> \\ | | | | | | | | | | | | h4. [Database Refresh Process/Changes|OLE:OLE DB Refresh Process & Changes] \\ \\ h4. Database Swaps (MySQL/Oracle)\\ \\ \\ h4. Performance Tuning {card} \\ \\ \\ {card:label = Development Best Practices} Current coding standards and best practices can be found at [

</param>

 

 

 

 

 

 

 

 

 

Database Refresh Process/Changes

 

Database Swaps (MySQL/Oracle)

 

Performance Tuning

Card
labelDevelopment Best Practices

Current coding standards and best practices can be found at https://wiki.kuali.org/display/OLE/Coding+Standards

]

.

Even

though

developers

are

expected

to

know

these,

sometimes

the

use

of

code

metric

tools

like

PMD,

Checkstyle

and

FIndBugs

makes

it

relatively

easy

and

often

aids

in

code

reviews

and

quick

turn

around

times

in

identifying

potential

coding

violations.

[Sonar |http://www.sonarsource.org/]is an open source platform that just does that

Sonar is an open source platform that just does that i.e.

monitors

code

quality

by

combining

tools

such

as

PMD,

FindBugs

and

Checkstyle

etc.

\\ \\ OLE is hooked into Sonar via maven and currently all the modules under [OLE|http://svn.kuali.org/repos/ole/trunk/] get executed on Sonar and metrics reported [here |http://sonar.kuali.org/dashboard/index/25877]\\ \\ \\ \\ \\ \\ There are few things to look out for that absolutely need to be addressed on a regular basis; # *Violations* : These are indicators in code that need to be reviewed and corrected as soon as possible. Few examples are "empty if stmt", "broken null check" etc. # *Duplications* : As the name suggests, this metric reports redundancy in code and needs to be taken seriously for a reusable and robust codebase. # *Complexity* : This often indicates the level of nesting in a particular method and for readability purposes the lower the number the better it is. There are several design patterns that address this and one of the most common one is the strategy pattern to replace several if-else blocks. \\ {card} \\ \\ \\ {card:label = OLE Installation} {info}\\ OLE currently comprises of three applications (war files) that have to be deployed individually. These are the olefs.war, rice2.war and the docstore.war.{info} {info:title=Required Software}In order to install OLE, following software is needed; \\ \\ 1. maven 3.x \\ 2. java jdk 1.6.x \\ 3. tomcat 6.x \\ 4. mysql server or oracle{info}\# h4. Check out the codebase&nbsp; ## Trunk location: [https://svn.kuali.org/repos/ole/trunk|https://svn.kuali.org/repos/ole/trunk] # h4. Building Artifacts ## Run the following from the root of the folder where the project was checked out {noformat} mvn clean install -DskipTests=true {noformat} ## Copy the following artifacts and place it in the webapps directory of your tomcat installation folder ### &nbsp; {noformat} ole/target/ole-fs-[particular iteration value]-webapp.war; Rename the war to olef.war {noformat} ### {noformat} ole-rice2/ole-rice-webapp/target/ole-rice-webapp-[particular iteration value].war; Rename the war to olerice2.war {noformat} ### {noformat} ole-docstore/ole-docstore-webapp/target/oledocstore.war; Rename the way to oledocstore.war {noformat} # h4. Generating the default configuration properties file ## Navigate to the ole folder under the main project ## Run the following command {noformat} mvn generate-resources -Plocal {noformat} ## This will generate a default configuration.properties file under {noformat} ~/.kuali/ole/fs/configuration.properties {noformat} ## {info}The default database is mysql and the root password is set to none. You will need to change the root password to the appropriate password as set for your mysql server.{info} # h4. Setting up the Database ## olefs - navigate to the {{ole-app}} folder under the root of the project and run the following command {info}The db instance chosen will be the one specified in the configuration.properties under user.home/.kuali/olefs; By default its MySQL.{info} {noformat} mvn clean install -Pdb {noformat} ## ole-rice2 - navigate to the {{ole-rice2/ole-rice-db}} folder under the project and run the following command {info}Ensure the impex.dba.password entry in the mysql.properties under ole-rice2/ole-rice-db/src/main/resources is appropriately set to whatever the password for your mysql server is. By default its set to root.{info} {noformat} mvn clean install -Pdb,mysql {noformat} ## ole-docstore - The database schema and appropriate tables gets created when the docstore application starts up as apache jackrabbit manages the setup. # h4. Configuration Files - Rice2 You will need to create a file called common-config.xml under user.home/kuali/main/dev with the following entry {info}Paths to the keystore file and the log4j.properties files will need to be updated to reflect a more appropriate location in your system.{info} {warning}Ensure you change the entry for application.url from localhost to the host ip of the server where you are running the application{warning} {noformat} {noformat} <\!-\- \\ &nbsp;&nbsp;&nbsp; Copyright 2005-2012 The Kuali Foundation \\ \\ &nbsp;&nbsp;&nbsp; Licensed under the Educational Community License, Version 2.0 (the "License"); \\ &nbsp;&nbsp;&nbsp; you may not use this file except in compliance with the License. \\ &nbsp;&nbsp;&nbsp; You may obtain a copy of the License at \\ \\ &nbsp;&nbsp;&nbsp; [http://www.opensource.org/licenses/ecl2.php]\\ \\ &nbsp;&nbsp;&nbsp; Unless required by applicable law or agreed to in writing, software \\ &nbsp;&nbsp;&nbsp; distributed under the License is distributed on an "AS IS" BASIS, \\ &nbsp;&nbsp;&nbsp; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. \\ &nbsp;&nbsp;&nbsp; See the License for the specific language governing permissions and \\ &nbsp;&nbsp;&nbsp; limitations under the License. \\ \\ \--> \\ <config> \\ &nbsp; \\ &nbsp;&nbsp;&nbsp; &nbsp;<param name="rice.logging.configure">true</param> \\ &nbsp;&nbsp;&nbsp; &nbsp; \\ &nbsp;&nbsp; &nbsp;<\!-\- App specific parameters --> \\ &nbsp;&nbsp; &nbsp;<param name="application.id">olerice2</param> \\ &nbsp;&nbsp; &nbsp;<param name="app.code">olerice2</param> \\ &nbsp;&nbsp; &nbsp;<param name="app.context.name">${app.code}</param> \\ &nbsp;&nbsp; &nbsp;<param name="application.url">[http://localhost:8080/$]{app.context.name}</param>



OLE is hooked into Sonar via maven and currently all the modules under OLE get executed on Sonar and metrics reported here





There are few things to look out for that absolutely need to be addressed on a regular basis;

  1. Violations : These are indicators in code that need to be reviewed and corrected as soon as possible. Few examples are "empty if stmt", "broken null check" etc.
  2. Duplications : As the name suggests, this metric reports redundancy in code and needs to be taken seriously for a reusable and robust codebase.
  3. Complexity : This often indicates the level of nesting in a particular method and for readability purposes the lower the number the better it is. There are several design patterns that address this and one of the most common one is the strategy pattern to replace several if-else blocks.
Card
labelOLE Installation
Info


OLE currently comprises of three applications (war files) that have to be deployed individually. These are the olefs.war, rice2.war and the docstore.war.

Info
titleRequired Software

In order to install OLE, following software is needed;

1. maven 3.x
2. java jdk 1.6.x
3. tomcat 6.x
4. mysql server or oracle

  1. If using MySQL, refer to https://wiki.kuali.org/display/KULRICE/Rice+MySQL+configuration+prerequisites for configuration file changes that are necessary for the rice database to work properly
  1. Check out the codebase 

    1. Trunk location: https://svn.kuali.org/repos/ole/trunk
  2. Building Artifacts

    1. Run the following from the root of the folder where the project was checked out

      No Format
       mvn clean install -DskipTests=true
      
    2. Copy the following artifacts and place it in the webapps directory of your tomcat installation folder
      1. No Format
        ole/target/ole-fs-[particular iteration value]-webapp.war; Rename the war to olef.war
        
      2. No Format
        ole-rice2/ole-rice-webapp/target/ole-rice-webapp-[particular iteration value].war; Rename the war to olerice2.war
        
      3. No Format
        ole-docstore/ole-docstore-webapp/target/oledocstore.war; Rename the way to oledocstore.war
        
  3. Generating the default configuration properties file

    1. Navigate to the ole folder under the main project
    2. Run the following command

      No Format
      mvn generate-resources -Plocal
      
    3. This will generate a default configuration.properties file under

      No Format
      ~/.kuali/ole/fs/configuration.properties
      
    4. Info

      The default database is mysql and the root password is set to none. You will need to change the root password to the appropriate password as set for your mysql server.

  4. Setting up the Database

    1. olefs - navigate to the ole-appfolder under the root of the project and run the following command

      Info

      The db instance chosen will be the one specified in the configuration.properties under user.home/.kuali/olefs; By default its MySQL.

      No Format
      mvn clean install -Pdb
      
    2. ole-rice2 - navigate to the ole-rice2/ole-rice-dbfolder under the project and run the following command

      Info

      Ensure the impex.dba.password entry in the mysql.properties under ole-rice2/ole-rice-db/src/main/resources is appropriately set to whatever the password for your mysql server is. By default its set to root.

      No Format
      mvn clean install -Pdb,mysql
      
    3. ole-docstore - The database schema and appropriate tables gets created when the docstore application starts up as apache jackrabbit manages the setup.
  5. Configuration Files - Rice2

    You will need to create a file called common-config.xml under user.home/kuali/main/dev with the following entry

    Info

    Paths to the keystore file and the log4j.properties files will need to be updated to reflect a more appropriate location in your system.

    Warning

    Ensure you change the entry for application.url from localhost to the host ip of the server where you are running the application

    No Format
    <\!-\-
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<param name="production.environment.code">PRD</param>
  1.  Copyright 2005-2012 The Kuali Foundation
    \\
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<\!-\- Misc parameters --> \\ &nbsp;&nbsp; &nbsp;<param name="institution">rice</param>
  1.  Licensed under the Educational Community License, Version 2.0 (the "License");
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<param name="version">03/19/2007 01:59 PM</param>
  1.  you may not use this file except in compliance with the License.
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<param name="transaction.timeout">3600</param>
  1.  You may obtain a copy of the License at
    \\
    
&nbsp;&nbsp;
  1. \\
    &nbsp;&nbsp;&nbsp; 
&nbsp;
  1. [http://www.opensource.org/licenses/ecl2.php]\\
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<param name="datasource.url">jdbc:mysql://localhost:3306/OLERICE2</param>
  1.  Unless required by applicable law or agreed to in writing, software
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<param name="datasource.username">OLERICE2</param>
  1.  distributed under the License is distributed on an "AS IS" BASIS,
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<param name="datasource.password">OLERICE2</param> \\ &nbsp;&nbsp; &nbsp;<param name="datasource.ojb.platform">MySQL</param>
  1.  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<param name="datasource.platform">org.kuali.rice.core.framework.persistence.platform.MySQLDatabasePlatform</param>
  1.  See the License for the specific language governing permissions and
    \\
    &nbsp;&nbsp;
  1. &nbsp;
<param name="datasource.driver.name">com.mysql.jdbc.Driver</param> \\ &nbsp;&nbsp;
  1.  limitations under the License.
    \\
    \\
    \-->
    \\
    <config>
    \\
    &nbsp;
<param
  1. 
    
name="datasource.pool.maxWait">30000</param>
  1. \\
    &nbsp;&nbsp;&nbsp; &nbsp;<param name="
datasource
  1. rice.
pool
  1. logging.
maxSize
  1. configure"
>20<
  1. >true</param>
    \\
    &nbsp;&nbsp;&nbsp; &nbsp;
<param
  1. 
    
name="datasource.pool.minSize">5</param>
  1. \\
    
\\
  1. &nbsp;&nbsp; &nbsp;
<param name="keystore.alias">rice</param>
  1. <\!-\- App specific parameters -->
    \\
    &nbsp;&nbsp; &nbsp;<param name="
keystore
  1. application.
file">${user.home}/kuali/main/dev/rice.keystore</
  1. id">olerice2</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="
keystore
  1. app.
password
  1. code"
>r1c3pw<
  1. >olerice2</param>
    \\
|
  1. 
    
  1. &nbsp;&nbsp; &nbsp;<param name="
dev
  1. app.context.
mode">false<
  1. name">${app.code}</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="
useQuartzDatabase">false</param>
  1. application.url">[http://localhost:8080/$]{app.context.name}</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="
Routing
  1. production.environment.
ImmediateExceptionRouting
  1. code"
>true<
  1. >PRD</param>
    \\
    \\
    &nbsp;&nbsp; &nbsp;<\!-\- 
Kuali
  1. Misc parameters -->
    
&nbsp;&nbsp;
  1. \\
    &nbsp;
<param name="encryption.key">7IC64w6ksLU</param> &nbsp;
  1. &nbsp; &nbsp;<param name="
kfsLocator.useAppContext
  1. institution"
>true<
  1. >rice</param>
    
&nbsp;&nbsp; &nbsp; &nbsp;&nbsp; &nbsp;<
  1. \
!-
  1. \
- Change Configurer Modes to LOCAL -->
  1. 
    &nbsp;&nbsp; &nbsp;
  1. <param name="
location.mode">LOCAL<
  1. version">03/19/2007 01:59 PM</param>
    \\
    &nbsp;&nbsp; &nbsp;
  1. <param name="
coreservice
  1. transaction.
mode
  1. timeout"
>LOCAL<
  1. >3600</param>
    \\
    &nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;
    \\
    &nbsp;&nbsp; &nbsp;<param name="
ken
  1. datasource.
mode">LOCAL<
  1. url">jdbc:mysql://localhost:3306/OLERICE2</param>
    \\
    &nbsp;&nbsp; &nbsp;
  1. <param name="
kim
  1. datasource.
mode
  1. username"
>LOCAL<
  1. >OLERICE2</param>
    \\
    &nbsp;&nbsp; &nbsp;
  1. <param name="
kew
  1. datasource.
mode
  1. password"
>LOCAL<
  1. >OLERICE2</param>
    \\
    &nbsp;&nbsp; &nbsp;
  1. <param name="
krms
  1. datasource.ojb.
mode
  1. platform"
>LOCAL<
  1. >MySQL</param>
    \\
    &nbsp;&nbsp; &nbsp;
  1. <param name="
ksb
  1. datasource.
mode">LOCAL</param> <param name="data.xml.root.location">[enter the user.home directory here]/kuali/main/dev/olerice2/workflow</param>
  1. platform">org.kuali.rice.core.framework.persistence.platform.MySQLDatabasePlatform</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="
data
  1. datasource.
xml
  1. driver.
pending.location">${data.xml.root.location}/pending</param>
  1. name">com.mysql.jdbc.Driver</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="
data
  1. datasource.
xml
  1. pool.
loaded.location">${data.xml.root.location}/loaded</param>
  1. maxWait">30000</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="
data
  1. datasource.
xml
  1. pool.
problem.location">${data.xml.root.location}/problem</param>
  1. maxSize">20</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="datasource.pool.minSize">5</param>
    \\
    \\
    &nbsp;&nbsp; &nbsp;
  1. <param name="
filter
  1. keystore.
login.class">org.kuali.rice.kew.web.DummyLoginFilter</param>
  1. alias">rice</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="
filtermapping.login.1">/*</param>
  1. keystore.file">${user.home}/kuali/main/dev/rice.keystore</param>
    \\
    &nbsp;&nbsp; &nbsp;<param name="
config
  1. keystore.
location">classpath:META-INF/common-config-defaults.xml<
  1. password">r1c3pw</param> 
</config> {noformat} {noformat} # h4. [OLE:Property Files] # h4. Running the applications ## Now that all the three application war files are copied to your tomcat folder, and the database has been set up for olefs and olerice2, its time to start tomcat ## Ensure the JAVA_OPTS have the following entry too for the memory settings; \-Xms512m \-Xmx1g \-XX:MaxPermSize=512m ## Accessing the applications ### OLEFS - [http://hostip:8080/olefs] ### OLERICE2 - [http://hostip:8080/olerice2] ### OLEDOCSTORE - [http://hostip:8080/oledocstore] # h4. Sample Data and Permissions In order for the OLE application to be fully functional, there are permissions and sample data files that need to be ingested. This process is automated and every time the applications are brought up (after a fresh install), the following data is ingested; a. [Workflows/Permissions|https://svn.kuali.org/repos/ole/trunk/ole-rice2/ole-rice-workflow/src/main/resources/org/kuali/ole/] b. [Patrons|https://jira.kuali.org/browse/OLE-3404] c. [Locations|https://jira.kuali.org/browse/OLE-3406] d.&nbsp;[Circulation&nbsp;Policies|https://jira.kuali.org/browse/OLE-3407] e. [YPB Ingest Profile&nbsp;|https://jira.kuali.org/browse/OLE-3403] {card} {card:label = OLE System Architecture} {card}{deck}
  1. \|
    
    &nbsp;&nbsp; &nbsp;<param name="dev.mode">false</param>
    &nbsp;&nbsp; &nbsp;<param name="useQuartzDatabase">false</param>
    &nbsp;&nbsp; &nbsp;<param name="Routing.ImmediateExceptionRouting">true</param>
    &nbsp;&nbsp; &nbsp;<\!-\- Kuali parameters -->
    &nbsp;&nbsp; &nbsp;<param name="encryption.key">7IC64w6ksLU</param>
    &nbsp;&nbsp; &nbsp;<param name="kfsLocator.useAppContext">true</param>
    &nbsp;&nbsp; &nbsp;
    &nbsp;&nbsp; &nbsp;<\!-\- Change Configurer Modes to LOCAL -->
    &nbsp;&nbsp;&nbsp; <param name="location.mode">LOCAL</param>
    &nbsp;&nbsp;&nbsp; <param name="coreservice.mode">LOCAL</param>
    &nbsp;&nbsp;&nbsp; <param name="ken.mode">LOCAL</param>
    &nbsp;&nbsp;&nbsp; <param name="kim.mode">LOCAL</param>
    &nbsp;&nbsp;&nbsp; <param name="kew.mode">LOCAL</param>
    &nbsp;&nbsp;&nbsp; <param name="krms.mode">LOCAL</param>
    &nbsp;&nbsp;&nbsp; <param name="ksb.mode">LOCAL</param>
    
    <param name="data.xml.root.location">[enter the user.home directory here]/kuali/main/dev/olerice2/workflow</param>
    <param name="data.xml.pending.location">${data.xml.root.location}/pending</param>
    <param name="data.xml.loaded.location">${data.xml.root.location}/loaded</param>
    <param name="data.xml.problem.location">${data.xml.root.location}/problem</param>
    &nbsp;&nbsp; &nbsp;
    &nbsp;&nbsp;&nbsp; <param name="filter.login.class">org.kuali.rice.kew.web.DummyLoginFilter</param>
    &nbsp;&nbsp; &nbsp;<param name="filtermapping.login.1">/*</param>
    &nbsp;&nbsp; &nbsp;<param name="config.location">classpath:META-INF/common-config-defaults.xml</param>
    
    </config>
    
    
  1. Property Files

  2. Running the applications

    1. Now that all the three application war files are copied to your tomcat folder, and the database has been set up for olefs and olerice2, its time to start tomcat
    2. Ensure the JAVA_OPTS have the following entry too for the memory settings; -Xms512m -Xmx1g -XX:MaxPermSize=512m
    3. Accessing the applications
      1. OLEFS - http://hostip:8080/olefs
      2. OLERICE2 - http://hostip:8080/olerice2
      3. OLEDOCSTORE - http://hostip:8080/oledocstore
  3. Sample Data and Permissions

    In order for the OLE application to be fully functional, there are permissions and sample data files that need to be ingested. This process is automated and every time the applications are brought up (after a fresh install), the following data is ingested;
    a. Workflows/Permissions
    b. Patrons
    c. Locations
    d. Circulation Policies
    e. YPB Ingest Profile 
Card
labelOLE System Architecture