Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Wiki Markup
{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=1}


{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}

# h4.  Daily Builds (Dev Environment)
{info}OLE code base ([https://svn.kuali.org/repos/ole/trunk]) is built everyday and deployed to the development environment. The build process is a fully automated maven process that includes the following;
{info}
## Code gets built at 12:30PM EST every day (CI job - [http://ci.rice.kuali.org/view/ole-0.8/job/ole-0.8-nightly/])
## Database is reset i.e. the schemas are completely wiped out and recreated again
### OLEFS - The OLEFS schama is refreshed from OLEDBA
### Rice2 - The Rice2 database is reset based on the ole-oracle-rice.sql file which contains the ddl for rice2 tables in OLE
### Docstore - The docstore schema is wiped out completely
## The war and jar files are built and uploaded to the following repository ([http://shrub.appspot.com/maven.kuali.org/snapshot/org/kuali/ole/]). The value of this approach is that in case a specific build has to be deployed at any given point, we can pick the particular build (war) and deploy it ad hoc.
## The war files gets deployed to the different application servers in the dev environment.
# h4. Test Release Builds (Test Environment)
## Test builds are deployed on an iterative basis (2 weeks sprints) to the test environment. Sprint schedule can be found at [https://jira.kuali.org/browse/OLE#selectedTab=com.atlassian.jira.plugin.system.project%3Aversions-panel]
## This process is fully automated and a member of the configuration management pool takes care of it. At the moment the process currently is to notify Jeff Cadel <jcaddel@kuali.org>/Paula Sisson <psisson@rsmart.com> who then take care of pushing the appropriate build to the test environment.
## [Test Promotion Details|OLE:Test Promotion Process]
# h4. Unit Tests
{info}OLE is a combination of ant and maven style applications/modules, so we dont have a common framework to run all tests in the project. For OLEFS, we use Jenkins and for Rice2/Docstore applications we use Sonar for tests and reporting.{info}
## Jenkins - The unit test jobs and the latest status for OLEFS can be found at [https://ci.rice.kuali.org/|http://ci.rice.kuali.org/view/ole-0.8/job/ole-0.8-unit-test/].
## Sonar - The unit test reports for Rice2/Docstore can be found at [http://sonar.kuali.org/dashboard/index/25877?did=1]
# h4. [CI Jobs|http://ci.rice.kuali.org/view/ole-0.8/]
{info}The task of building and deploying the applications are distributed among few jobs. There is one job that builds all three applications (OLEFS, OLERICE2 and OLEDOCSTORE). For deploying individual applications, one could run jobs b,c or d depending on which application needs to be deployed.{info}
{info}Job 4.a will trigger jobs b, c and d downstream.

But if something fails then individual applications can be re-deployed without having to deploy all the other apps.

In order to deploy the revision number is needed, which can be obtained from Job 4.a (look at the console logs to get the revision number){info}
## Building the applications - [ole-0.8-daily-build|http://ci.rice.kuali.org/view/ole-0.8/job/ole-0.8-daily-build/]
## Deploying OLEFS - [ole-0.8-daily-deploy-dev-olefs|http://ci.rice.kuali.org/view/ole-0.8/job/ole-0.8-daily-deploy-dev-olefs/]
## Deploying OLERICE2 - [ole-0.8-daily-deploy-dev-rice2|http://ci.rice.kuali.org/view/ole-0.8/job/ole-0.8-daily-deploy-dev-rice2/]
## Deploying OLEDOCSTORE - [ole-0.8-daily-deploy-dev-docstore|https://wiki.kuali.org/display/OLE/OLE+Environments]

h4. [Environment Details|https://wiki.kuali.org/display/OLE/OLE+Environments]



{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}
In order to contribute to OLE development, the following have to be met;

# SVN account
# Required Software
# Code checkout
# Local setup
# IDE
# Local Testing
## Code
## Database DDL

{card}
{card:label = Development Best Practices}
Various Kuali projects over time have put together coding standards and best practices which can be found at https://wiki.kuali.org/display/KFSIMP/General+Java+Coding+Standards and https://wiki.kuali.org/display/OLE/Coding+Standards. Even though developers are expected to know these
\\


{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
## ole - navigate to the ole 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}
 <!--

    Copyright 2005-2012 The Kuali Foundation

    Licensed under the Educational Community License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

    http://www.opensource.org/licenses/ecl2.php

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.

-->
<config>
 
     <param name="rice.logging.configure">true</param>
     
    <!-- App specific parameters -->
    <param name="application.id">olerice2</param>
    <param name="app.code">olerice2</param>
    <param name="app.context.name">${app.code}</param>
    <param name="application.url">http://localhost:8080/${app.context.name}</param>
    <param name="production.environment.code">PRD</param>

    <!-- Misc parameters -->
    <param name="institution">rice</param>
    <param name="version">03/19/2007 01:59 PM</param>
    <param name="transaction.timeout">3600</param>
        
    <param name="datasource.url">jdbc:mysql://localhost:3306/OLERICE2</param>
    <param name="datasource.username">OLERICE2</param>
    <param name="datasource.password">OLERICE2</param>
    <param name="datasource.ojb.platform">MySQL</param>
    <param name="datasource.platform">org.kuali.rice.core.framework.persistence.platform.MySQLDatabasePlatform</param>
    <param name="datasource.driver.name">com.mysql.jdbc.Driver</param>
    <param name="datasource.pool.maxWait">30000</param>
    <param name="datasource.pool.maxSize">20</param>
    <param name="datasource.pool.minSize">5</param>

    <param name="keystore.alias">rice</param>
    <param name="keystore.file">${user.home}/kuali/main/dev/rice.keystore</param>
    <param name="keystore.password">r1c3pw</param>

    <param name="dev.mode">false</param>
    <param name="useQuartzDatabase">false</param>
    <param name="Routing.ImmediateExceptionRouting">true</param>
    <!-- Kuali parameters -->
    <param name="encryption.key">7IC64w6ksLU</param>
    <param name="kfsLocator.useAppContext">true</param>
    
    <!-- Change Configurer Modes to LOCAL -->
    <param name="location.mode">LOCAL</param>
    <param name="coreservice.mode">LOCAL</param>
    <param name="ken.mode">LOCAL</param>
    <param name="kim.mode">LOCAL</param>
    <param name="kew.mode">LOCAL</param>
    <param name="krms.mode">LOCAL</param>
    <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>
    
    <param name="filter.login.class">org.kuali.rice.kew.web.DummyLoginFilter</param>
    <param name="filtermapping.login.1">/*</param>
    <param name="config.location">classpath:META-INF/common-config-defaults.xml</param>

</config>

{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}