Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Migrated to Confluence 5.3

...

1.

...

Introduction

...

Document

...

Store

...

is

...

a

...

Document

...

storage

...

repository

...

system

...

with

...

features

...

like

...

checkin,

...

checkout,

...

Ingest

...

,

...

Delete

...

etc

...

for

...

library

...

records

...

such

...

as

...

Bibliographic,

...

Instance

...

(Holdings

...

and

...

Items)

...

etc.

...

Most

...

of

...

the

...

records

...

are

...

in

...

XML

...

format

...

but

...

the

...

Document

...

Store

...

is

...

format

...

agnostic

...

in

...

that

...

it

...

stores

...

the

...

content

...

as

...

is

...

without

...

any

...

type

...

conversion.

...

Furthermore

...

indexing

...

of

...

the

...

stored

...

data

...

is

...

also

...

supported

...

for

...

efficient

...

search

...

and

...

retrieval.

...

Although

...

the

...

Document

...

Store

...

is

...

an

...

independent

...

system

...

that

...

comes

...

with

...

basic

...

UI

...

to

...

enable

...

supported

...

operations,

...

majority

...

of

...

interaction

...

happens

...

from

...

within

...

the

...

code

...

of

...

OLE

...

such

...

as

...

ingest

...

of

...

new

...

records,

...

editing

...

of

...

existing

...

records,

...

search

...

and

...

retrievals. 

The functionality of Docstore is mostly used by other processes like OLE.

However, for demonstration and testing docstore, a screen is provided with different tabs for different functions of docstore and information about docstore.

Please refer to the docstore application deployed on Dev server:

http://dev.docstore.ole.kuali.org/

2. Operations

2.1 Summary

 Shows the summary of record count for each category, type and formath

 

2.2 Ingest

 

Allows storing of documents in the document store. The input should be a Request XML with a standard schema and returns the Response XML with a list of ingested UUIDs.

2.2.1 Sending the request

URL: http://dev.docstore.ole.kuali.org/document

Method: POST

Parameters:

                  docAction=ingestContent

                  stringContent=<request.xml as described in the next section>

2.2.2 Request XML

Information about the ingest operation to be performed.

No Format
 <request>
    <user>ole-khuntley</user>
    <operation>ingest</operation>
    <requestDocuments>
        <ingestDocument id="1" category="work" type="bibliographic" format="marc">
            <content>
        See section "Sample Input XML for Ingest".
    </content>
        </ingestDocument>
    </requestDocuments>
</request>

2.2.3 Receiving the response

HttpResponse should be read and interpreted as given in the next section below.

2.2.4 Response XML

Information about the response from the service for the given request

No Format
 <response>
  <documents>
    	<document id="1" category="work" type="bibliographic" format="marc">
      	    <uuid>10000004</uuid>
	</document>
   </documents>
<user>ole-khuntley</user>
<operation>ingest</operation>
<status>Success</status>
<message>Documents ingested</message>
</response>

Each document that is ingested will be given a UUID as specified in the response.

2.3 Check-in

Check-in functionality allows to modify the content and metadata (additional attributes) of a document identified by its UUID (Universally Unique Identifier).

2.3.1 Sending the request

URL: http://dev.docstore.ole.kuali.org/document

Method: POST

Parameters:

                  docAction=checkIn

                  stringContent=<request.xml as described in the next section>

2.3.2 Request XML

           Information about the check in  operation to be performed     

No Format
 <request>
    <user>ole-khuntley</user>
    <operation>checkIn</operation>
    <requestDocuments>
        <ingestDocument id="10000004" category="work" type="bibliographic" format="marc">
            <content>
		See section "Sample Input XML for Check in".
	</content>
        </ingestDocument>
    </requestDocuments>
</request>

2.3.3 Receiving the response

HttpResponse should be read and interpreted as given in the next section below.

2.3.4 Response XML

            Information about the response from the service for the given request 

No Format
 <response>
  <documents>
    	<document id="1" category="work" type="bibliographic" format="marc">
      	    <uuid>10000004</uuid>
	</document>
   </documents>
<user>ole-khuntley</user>
<operation>checkIn</operation>
<status>Success</status>
</response>

2.4 Check-out

This operation retrieves the content of a document given its UUID.

2.4.1 Sending the request

URL: http://dev.docstore.ole.kuali.org/document

Method: POST

Parameters:

                  docAction=checkOut

                  uuid=<uuid of the document to be retrieved>

2.4.2 Receiving the response

            HttpResponse should be read and interpreted as given in the next section below.

2.4.3  Response XML

Content of the document with the given UUID.

2.5 Delete

Deletes a record from DocumentStore based on the given UUID.

2.5.1 Sending the request

URL: http://dev.docstore.ole.kuali.org/document

Method: POST

Parameters:

                  docAction=delete or deleteWithLinkedDocs

                  requestContent=<request.xml as described in the next section>

2.5.2  Request XML

         Information about the delete  operation to be performed. The "Id" attribute of <ingestDocument> should be a valid UUID of a previously ingested document.

No Format
 <request>
    <user>ole-khuntley</user>
    <operation>delete</operation>
    <requestDocuments>
<ingestDocument id="10000004"></ingestDocument>
 </requestDocuments>
</request>

2.5.3  Receiving the response

             HttpResponse should be read and interpreted as given in the next section below.

2.5.4  Response XML

 Information about the response from the service for the given request.

No Format
 <response>
  <documents>
    <document id="10000004"></document>
  </documents>
  <user>ole-khuntley</user>
  <operation>delete</operation>
  <status>Success</status>
</response>

2.6 Bulk Ingest (Admin function)

Bulk ingest process is used for loading the docstore repository with large amounts of document information.

It is usually done by an admin user during off-peak hours to avoid end-users experiencing slow down of docstore.

The input data is copied to a "ole-batchUpload" directory on the server (specified by documentstore.properties)

Go to http://dev.docstore.ole.kuali.org/admin.jsp and 'Bulk Ingest' tab.

Click the button to start the process. Once started, the process runs in background and waits for input files to become available in the "ole-batchUpload" directory.

As soon as a file is available, it is picked up for processing. After a file is ingested it is moved to a ".done" sub-directory and the next available file is picked up.

NOTE: Make sure that input directory ("ole-batchUpload") has the "rwx" permissions for the Tomcat process to create ".done" sub-directory and files. (If unix, run "chmod -R 777 ." in the input directory.)

To verify that the data is stored in DocumentStore, go to URL

           http://dev.docstore.ole.kuali.org

           Click "Refresh Summary" button in the Summary tab.

           Note the count for each DocType.

To verify that the data is indexed in DocStore, go to URL

        http://dev.docstore.ole.kuali.org/discovery

         Click "Refresh" button in the Summary tab.

         Note the count for each DocType.

2.7 Rebuild indexes (Admin function)

Sometimes the indexed data in Docstore may get corrupted. Or the data may need to be reindexed due to changes in indexing criteria and search/sort/facet rules.

In these cases the Docstore data can be re-indexed. This is also done by the Admin user.

Go to http://dev.docstore.ole.kuali.org/admin.jsp and 'Reindex' tab.

Click the 'Start' button to start the process.

Click the 'Status' button to view the status of the process.

Click the 'Stop' button to stop the process. The process is stopped after the current batch of data is reindexed.

To verify that the data is indexed in DocStore, go to URL

        http://dev.docstore.ole.kuali.org/discovery

         Click "Refresh" button in the Summary tab.

         Note the count for each DocType and verify with DocStore count.

2.8 Ingest Binary data (BagIt Requests)

When the document content is of (non-text or binary) format PDF, DOC etc, (as in the case of License Agreement documents) it is difficult to send it to docstore through a web page.

And when the request has to deal with more than one of such documents, it is even more difficult.

So, BagIt packaging standard is used to bundle such requests along with the files of these formats.

The request can be for ingest, checkin, checkout or delete.

This functionality can be demonstrated using the "BagIt Requests" tab in thehttp://dev.docstore.ole.kuali.orgscreen.

To submit a request of this type follow these steps:

1. Create a folder (e.g. /opt/docstore/upload/bagItRequests/ingest) (link to an attachment of zipped bagItRequests folder with ingest, checkin, checkout, delete folders)

     (Make sure this folder has write permission for all users.)

2. Create and copy the request.xml and the corresponding binary files into it.

3. Enter the full path of this folder in the text box for "BagIt Requests Directory".

4. Click the Submit button.

How a bagIt request is processed?

The utility code for handling BagIt request creates a 'Bag' (as per BagIt standard) out of the "BagIt Requests Directory".

The content of the bag is sent to Docstore via an HTTP connection.

Docstore unbags the received content into a temp folder, uses the request.xml to process the files in the temp folder if any.

Docstore creates a respose.xml file to record the outcome of the processed request

and copies it along with any files that are part of response (in case of checkout) to a temp folder.

Then a 'Bag' is created out of the temp folder and sent back to the client.

The utility code receives the content from Docstore, unbags the content to a temp folder (e.g. /opt/docstore/upload/bagItRequests/ingest/response).

The response.xml along with the temp folder name is to the browser.

3.0 Appendix

3.0.1  Sample Input XML for Ingest

No Format
 <request>
    <user>ole-khuntley</user>
    <operation>batchIngest</operation>
    <requestDocuments>
        <ingestDocument id="1" category="work" type="bibliographic" format="marc">
            <content><![CDATA[
            <collection xmlns="http://www.loc.gov/MARC21/slim">
    <record>
        <leader>#####nam#a22######a#4500</leader>
    <controlfield tag="001">3</controlfield>
        <controlfield tag="003">OCoLC</controlfield>
        <controlfield tag="005">20090213152530.7</controlfield>
        <controlfield tag="008">131031s########xxu###########000#0#eng#d</controlfield>
        <datafield tag="035" ind1=" " ind2=" ">
            <content>
		See section "Sample Input XML for Check in".
	</content><subfield code="a">(OCoLC)ocm62378465</subfield>
        </datafield>
        <datafield  </ingestDocument>
tag="040" ind1=" " ind2=" ">
   </requestDocuments> </request>  {noformat} <\!-\-  /\* Style Definitions \*/  table.MsoNormalTable{mso-style-name:"Table Normal"; 	mso-tstyle-rowband-size:0; 	mso-tstyle-colband-size:0; 	mso-style-noshow:yes; 	mso-style-priority:99; 	mso-style-qformat:yes; 	mso-style-parent:""; 	mso-padding-alt:0cm 5.4pt 0cm 5.4pt; 	mso-para-margin:0cm; 	mso-para-margin-bottom:.0001pt; 	mso-pagination:widow-orphan; 	font-size:10.0pt; 	font-family:"Times New Roman","serif";} \-->

h3. 2.2.3 &nbsp;&nbsp;&nbsp;&nbsp;Receiving the response

HttpResponse should be read and interpreted as given in the next section below.
\\

h3. 2.2.4 &nbsp;&nbsp;&nbsp;&nbsp; ResponseXML

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Informationabout the response from the service for the given request&nbsp;

{noformat}
 <?xml version="1.0" encoding="UTF-8"?>
<OLEDocstore-call>
	<request>
		<command>Check-in</command>
		<params/>
	</request>
	<response>
		<status>Success</status>
		<message>Successfully checked in </message>
	</response>
</OLEDocstore-call>

{noformat}
<\!-\-  /\* Style Definitions \*/  table.MsoNormalTable{mso-style-name:"Table Normal"; 	mso-tstyle-rowband-size:0; 	mso-tstyle-colband-size:0; 	mso-style-noshow:yes; 	mso-style-priority:99; 	mso-style-qformat:yes; 	mso-style-parent:""; 	mso-padding-alt:0cm 5.4pt 0cm 5.4pt; 	mso-para-margin:0cm; 	mso-para-margin-bottom:.0001pt; 	mso-pagination:widow-orphan; 	font-size:10.0pt; 	font-family:"Times New Roman","serif";} \-->

h2. 2.3 &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Check-out

This operation retrieves the content of a document given its UUID.
\\

h3. 2.3.1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Sendingthe request

URL: [http://localhost:9080/oledocstore/document]


Method: POST

Parameters:

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; docAction=checkOut

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; uuid=<uuid of the document to be retrieved>
\\

h3. 2.3.2 &nbsp;&nbsp;&nbsp;&nbsp; Receiving the response

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;HttpResponseshould be read and interpreted as given in the next section below.

h3. 2.3.3 &nbsp;&nbsp;&nbsp;&nbsp; Response XML

Content of the document with the given UUID.

<\!-\-  /\* Style Definitions \*/  table.MsoNormalTable{mso-style-name:"Table Normal"; 	mso-tstyle-rowband-size:0; 	mso-tstyle-colband-size:0; 	mso-style-noshow:yes; 	mso-style-priority:99; 	mso-style-qformat:yes; 	mso-style-parent:""; 	mso-padding-alt:0cm 5.4pt 0cm 5.4pt; 	mso-para-margin:0cm; 	mso-para-margin-bottom:.0001pt; 	mso-pagination:widow-orphan; 	font-size:10.0pt; 	font-family:"Times New Roman","serif";} \-->

h2. 2.4 &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Delete


h3. Deletes a record from Document Store based on the given UUID.\\

h3. 2.4.1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Sendingthe request\\

URL: [http://localhost:9080/oledocstore/document]


Method: POST

Parameters:

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; docAction=delete or deleteWithLinkedDocs

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; requestContent=<request.xml as described in the next section>
\\

h3. 2.4.2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Request XML \\

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Information about the delete&nbsp; operation to be performed. The "Id" attribute of <ingestDocument> should be a valid UUID of a previously ingested document.

{noformat}
 <request>
    <user>ole-khuntley</user>
    <operation>delete</operation>
    <requestDocuments>
<ingestDocument id="715e92f0-b3ab-4263-96d9-58183a23e6d5"><linkedIngestDocuments></linkedIngestDocuments></ingestDocument>
 </requestDocuments>
</request>

{noformat}
<\!-\-  /\* Style Definitions \*/  table.MsoNormalTable{mso-style-name:"Table Normal"; 	mso-tstyle-rowband-size:0; 	mso-tstyle-colband-size:0; 	mso-style-noshow:yes; 	mso-style-priority:99; 	mso-style-qformat:yes; 	mso-style-parent:""; 	mso-padding-alt:0cm 5.4pt 0cm 5.4pt; 	mso-para-margin:0cm; 	mso-para-margin-bottom:.0001pt; 	mso-pagination:widow-orphan; 	font-size:10.0pt; 	font-family:"Times New Roman","serif";} \-->

h3. 2.4.3 &nbsp;&nbsp;&nbsp;&nbsp; Receiving the response

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; HttpResponse should be read and interpreted as given in the next section below.
\\
\\

h3. 2.4.4 &nbsp;&nbsp;&nbsp;&nbsp; Response XML

&nbsp;Information about the response from the service for the given request.

{noformat}
 <response>
  <documents>
    <document id="715e92f0-b3ab-4263-96d9-58183a23e6d5"></document>
  </documents>
  <user>ole-khuntley</user>
  <operation>delete</operation>
  <status>Success</status>
</response>

{noformat}
<\!-\-  /\* Style Definitions \*/  table.MsoNormalTable{mso-style-name:"Table Normal"; 	mso-tstyle-rowband-size:0; 	mso-tstyle-colband-size:0; 	mso-style-noshow:yes; 	mso-style-priority:99; 	mso-style-qformat:yes; 	mso-style-parent:""; 	mso-padding-alt:0cm 5.4pt 0cm 5.4pt; 	mso-para-margin:0cm; 	mso-para-margin-bottom:.0001pt; 	mso-pagination:widow-orphan; 	font-size:10.0pt; 	font-family:"Times New Roman","serif";} \-->

h2. 2.5 &nbsp;&nbsp;&nbsp;&nbsp;Appendix

<\!-\-  /\* Style Definitions \*/  table.MsoNormalTable{mso-style-name:"Table Normal"; 	mso-tstyle-rowband-size:0; 	mso-tstyle-colband-size:0; 	mso-style-noshow:yes; 	mso-style-priority:99; 	mso-style-qformat:yes; 	mso-style-parent:""; 	mso-padding-alt:0cm 5.4pt 0cm 5.4pt; 	mso-para-margin:0cm; 	mso-para-margin-bottom:.0001pt; 	mso-pagination:widow-orphan; 	font-size:10.0pt; 	font-family:"Times New Roman","serif";} \-->

h3. 2.5.1&nbsp;&nbsp;&nbsp;&nbsp;Sample Input XML for Ingest

{noformat}
 <request>
    <user>ole-khuntley</user>
    <operation>batchIngest</operation>
    <requestDocuments>
        <ingestDocument id="1" category="work" type="bibliographic" format="marc">
            <content><![CDATA[
<collection xmlns="http://www.loc.gov/MARC21/slim">
    <record>
        <leader>01142cam 2200301 a 4500</leader>
        <controlfield tag="001">92005291</controlfield>
        <controlfield tag="003">DLC</controlfield>
        <controlfield tag="005">19930521155141.9</controlfield>
        <controlfield tag="008">920219s1993 caua j 000 0 eng</controlfield><subfield code="a">DLC</subfield>
             <subfield code="c">DLC</subfield>
             <subfield code="d">DLC</subfield>
             <subfield code="d">HLS</subfield>
             <subfield code="d">IUL</subfield>
        </datafield>
         <datafield tag="022" ind1=" " ind2=" ">
            <subfield code="a">1729-1070|20</subfield>
        </datafield>
        <datafield tag="029" ind1="1" ind2=" ">
            <subfield code="a">AU@|b000040176476</subfield>
            <subfield code="b">000040176476</subfield>
        </datafield>
        <datafield tag="037" ind1=" " ind2=" ">
            <subfield code="b">The Managing Editor, BIAC Journal, P.O. Box 10026, Gaborone, Botswana</subfield>
        </datafield>
        <datafield tag="042" ind1=" " ind2=" ">
            <subfield code="a">lc</subfield>
        </datafield>
        <datafield tag="043" ind1="1" ind2="0">
            <subfield code="a">f-bs---</subfield>
        </datafield>
        <datafield tag="050" ind1="0" ind2="0">
            <subfield code="a">HD70.B55|bB53</subfield>
        </datafield>
        <datafield tag="049" ind1=" " ind2=" ">
            <subfield code="a">IULA</subfield>
        </datafield>
         <datafield tag="210" ind1="1" ind2=" ">
            <subfield code="a">BIAC j.</subfield>
        </datafield>
         <datafield tag="222" ind1=" " ind2="0">
            <subfield code="a">BIAC journal</subfield>
        </datafield>
         <datafield tag="245" ind1="0" ind2="0">
            <subfield code="a">The administration of justice. BIAC journal</subfield>
        </datafield>
         <datafield tag="246" ind1="1" ind2="3">
            <subfield code="a">Botswana Institute of Administration and Commerce journal</subfield>
        </datafield>
        <datafield tag="260" ind1=" " ind2=" ">
            <subfield code="a">Gaborone, Botswana :|bBotswana Institute of Administration and Commerce</subfield>
            <subfield code="b">Botswana Institute of Administration and Commerce</subfield>
        </datafield>
        <datafield tag="300" ind1=" " ind2=" ">
            <subfield code="a">v. ;</subfield>
            <subfield code="c">24 cm.</subfield>
        </datafield>
        <datafield tag="300" ind1=" " ind2=" ">
            <subfield code="a">v. ;</subfield>
            <subfield code="c">24 cm.</subfield>
        </datafield>
        <datafield tag="300" ind1=" " ind2=" ">
            <subfield code="a">v. ;</subfield>
            <subfield code="c">24 cm.</subfield>
        </datafield>
        <datafield tag="010310" ind1=" " ind2=" ">
            <subfield code="a">92005291<>Semiannual</subfield>
        </datafield>
        <datafield tag="020362" ind1=" 1" ind2=" ">
            <subfield code="a">0152038655 :> Began in 2004.</subfield>
            <subfield code="c">$15.95</subfield>
        </datafield>
        <datafield tag="040500" ind1=" " ind2=" ">
            <subfield code="a">DLC</subfield>>Description based on: Vol. 1, no. 1 (May. 2004); title    <subfield code="c">DLC</subfield>
            <subfield code="d">DLC<from cover.</subfield>
        </datafield>
        <datafield tag="042500" ind1=" " ind2=" ">
            <subfield code="a">lcac</subfield>>Latest issue consulted: Vol. 3, no. 1 (May 2006).</subfield>
        </datafield>
        <datafield tag="050650" ind1="0" ind2="0 ">
            <subfield code="a">PS3537.A618<>Industrial management</subfield>
            <subfield code="b">A88 1993<z">Botswana</subfield>
            <subfield code="v">Periodicals.</subfield>
        </datafield>
        <datafield tag="082650" ind1="0" ind2="0 ">
            <subfield code="a">811/.52<>Occupational training</subfield>
            <subfield code="2z">20<>Botswana</subfield>
        </datafield>         <datafield tag<subfield code="100" ind1="1" ind2=" ">v">Periodicals.</subfield>
        </datafield>
        <datafield <subfield code="a">Sandburg, Carl,</subfield>tag="710" ind1="2" ind2=" ">
            <subfield code="d">1878-1967a">Botswana Institute of Administration and Commerce.</subfield>
        </datafield>
        <datafield tag="245850" ind1="1 " ind2="0 ">
            <subfield code="a">Arithmetic /<>DLC</subfield>
        </datafield>
   <subfield code="c">    <datafield   tag="891" ind1="2" ind2="0">
         Carl Sandburg ; illustrated as an anamorphic adventure by Ted Rand.<subfield code="a">9853|81.1</subfield>
            <subfield code="a">v.</subfield>
    </subfield>         </datafield><subfield code="b">no</subfield>
         <datafield tag="250" ind1=" "<subfield ind2code=" u">>2</subfield>
            <subfield code="a">1st ed.<v">r</subfield>
        </datafield>         <datafield tag<subfield code="260" ind1=" " ind2=" ">i">(year)</subfield>
            <subfield code="a">San Diego :j">(month)</subfield>
            <subfield code="b">Harcourt Brace Jovanovich,<w">f</subfield>
            <subfield code="cx">c1993.<>05</subfield>
        </datafield>
        <datafield tag="300891" ind1=" 4" ind2=" 1">
            <subfield code="a">1 v. (unpaged) :<>9863|81.1</subfield>
            <subfield code="b">ill. (some col.) ;<a">1</subfield>
            <subfield code="c">26 cm.<b">1</subfield>
 
      </datafield>      <subfield   <datafield tagcode="500" ind1=" " ind2=" ">i">2004</subfield>
             <subfield code="a">One Mylar sheet included in pocket.<j">05</subfield>
        </datafield>
        <datafield tag="520596" ind1=" " ind2=" ">
            <subfield code="a">>1</subfield>
        </datafield>
    </record>
</collection>
 A poem about numbers and their characteristics. Features anamorphic, or distorted,      ]]>
          drawings which can</content>
be            <!--optional -->
   restored to normal by viewing from a particular angle or<additionalAttributes>
by viewing the image's             <dateEntered></dateEntered>
   reflection in the           <lastUpdated></lastUpdated>
     provided Mylar cone.         <fastAddFlag></fastAddFlag>
   </subfield>         </datafield>    <supressFromPublic></supressFromPublic>
    <datafield tag="650" ind1=" " ind2="0">        <harvestable></harvestable>
    <subfield code="a">Arithmetic</subfield>           <status></status>
 <subfield code="x">Juvenile poetry.</subfield>         </datafield>    <createdBy></createdBy>
    <datafield tag="650" ind1=" " ind2="0">        <updatedBy></updatedBy>
    <subfield code="a">Children's poetry, American.</subfield>         <<statusUpdatedOn></datafield>
statusUpdatedOn>
       <datafield tag="650" ind1=" " ind2="1">     <statusUpdatedBy></statusUpdatedBy>
       <subfield code="a">Arithmetic</subfield>          <staffOnlyFlag>true</staffOnlyFlag>
  <subfield code="x">Poetry.</subfield>         </datafield>additionalAttributes>
        <datafield  tag="650" ind1=" " ind2="1"> <linkedIngestDocuments></linkedIngestDocuments>
        </ingestDocument>

   <subfield code="a">American poetry.</subfield>
    </requestDocuments>
</request>



3.0.2  Sample Input file for Check In

The "Id" attribute of <ingestDocument> should be a valid UUID of a previously ingested document.

No Format
 <request>
    <<user>ole-khuntley</datafield>user>
    <operation>checkIn</operation>
   <datafield tag="650" ind1=" " ind2="1"><requestDocuments>
        <ingestDocument id="1" category="work" type="bibliographic" format="marc">
            <content><![CDATA[
<subfield<collection codexmlns="a">Visual perception.</subfield>http://www.loc.gov/MARC21/slim">
    <record>
        <leader>01142cam 2200301 a <4500</datafield>leader>
        <datafield<controlfield tag="700001" ind1="1" ind2=" ">>92005291</controlfield>
               <subfield code<controlfield tag="a">Rand, Ted,</subfield>003">DLC</controlfield>
            <subfield code<controlfield tag="e005">ill>19930521155141.<9</subfield>controlfield>
        </datafield>
    </record>
</collection><controlfield tag="008">920219s1993 caua j 000 0 eng</controlfield>
        <datafield tag="010" ind1=" " ind2=" ">
  ]]>             </content><subfield code="a">92005291</subfield>
        </ingestDocument>datafield>
     </requestDocuments>
</request>

{noformat}
<\!-\-  /\* Style Definitions \*/  table.MsoNormalTable{mso-style-name:"Table Normal"; 	mso-tstyle-rowband-size:0; 	mso-tstyle-colband-size:0; 	mso-style-noshow:yes; 	mso-style-priority:99; 	mso-style-qformat:yes; 	mso-style-parent:""; 	mso-padding-alt:0cm 5.4pt 0cm 5.4pt; 	mso-para-margin:0cm; 	mso-para-margin-bottom:.0001pt; 	mso-pagination:widow-orphan; 	font-size:10.0pt; 	font-family:"Times New Roman","serif";} \-->

h3. 2.5.2 &nbsp;&nbsp;&nbsp;Sample Input file for Check In

The "Id" attribute of <ingestDocument> should be a valid UUID of a previously ingested document.


{noformat}
 <request>
    <user>ole-khuntley</user>
    <operation>batchIngest</operation>
    <requestDocuments>   <datafield tag="020" ind1=" " ind2=" ">
            <subfield code="a">0152038655 :</subfield>
            <subfield code="c">$15.95</subfield>
        </datafield>
        <datafield tag="040" ind1=" " ind2=" ">
            <subfield code="a">DLC</subfield>
            <subfield code="c">DLC</subfield>
            <subfield code="d">DLC</subfield>
        </datafield>
        <ingestDocument<datafield idtag="1042" categoryind1="work " typeind2="bibliographic" format="marc">
            <content><![CDATA[
<collection xmlns="http://www.loc.gov/MARC21/slim">
<subfield code="a">lcac</subfield>
        </datafield>
   <record>     <datafield tag="050" ind1="0" ind2="0">
<leader>01142cam 2200301 a 4500</leader>         <controlfield<subfield tagcode="001a">92005291</controlfield>>PS3537.A618</subfield>
            <controlfield<subfield tagcode="003b">DLC<>A88 1993</controlfield>subfield>
        <controlfield tag="005">19930521155141.9</controlfield></datafield>
        <controlfield<datafield tag="008082">920219s1993 caua j 000 0 eng</controlfield>ind1="0" ind2="0">
         <datafield tag="010" ind1=" "<subfield ind2code=" ">a">811/.52</subfield>
            <subfield code="a2">92005291<>20</subfield>
        </datafield>
        <datafield tag="020100" ind1=" 1" ind2=" ">
            <subfield code="a">0152038655>Sandburg, :Carl,</subfield>
            <subfield code="cd">$15>1878-1967.95<</subfield>
        </datafield>
        <datafield tag="040245" ind1=" 1" ind2=" 0">
            <subfield code="a">DLC<>Arithmetic /</subfield>
            <subfield code="c">DLC</subfield>>
            <subfield code="d">DLC</subfield>   Carl Sandburg ; illustrated as an </datafield>anamorphic adventure by       <datafield tag="042" ind1=" " ind2=" ">Ted Rand.
             <subfield code="a">lcac<</subfield>
        </datafield>
        <datafield tag="050250" ind1="0 " ind2="0 ">
            <subfield code="a">PS3537>1st ed.A618<</subfield>
        </datafield>

  <subfield code="b">A88 1993</subfield>  </record>
</collection>
        </datafield>        ]]>
<datafield tag="082" ind1="0" ind2="0">             <subfield code="a">811/.52</subfield></content>
        </ingestDocument>
   <subfield code="2">20</subfield>
        </datafield>
        <datafield tag="100" ind1="1" ind2=" ">
            <subfield code="a">Sandburg, Carl,</subfield>
            <subfield code="d">1878-1967.</subfield>
        </datafield>
        <datafield tag="245" ind1="1" ind2="0">
            <subfield code="a">Arithmetic /</subfield>
            <subfield code="c">
                Carl Sandburg ; illustrated as an anamorphic adventure by Ted Rand.
            </subfield>
        </datafield>
        <datafield tag="250" ind1=" " ind2=" ">
            <subfield code="a">1st ed.</subfield>
        </datafield>

    </record>
</collection>
                ]]>
            </content>
        </ingestDocument>
    </requestDocuments>
</request>

{noformat}

| &nbsp;&nbsp; <user>ole-khuntley</user> \\
&nbsp;&nbsp;&nbsp; <operation>*batchIngest*</operation> \\
&nbsp;&nbsp;&nbsp; <requestDocuments> \\
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ingestDocument id="1" category="work" type="bibliographic" format="marc"> \\
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <content> \\
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; See section "*Sample Input XML for Ingest*". \\
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </content> \\
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </ingestDocument> \\
&nbsp;&nbsp;&nbsp; </requestDocuments> \\
</request> | </requestDocuments>
</request>

4. Search

 This functionality allows documents to be searched for by giving keywords or phases. Searching can be based on category, type, format, search fields.

4.1  Quick Search

            Select Doc Category : Work

                      Doc Type : Bibliographic

                      Doc Format : ALL

   Searching on default condition(click search button without specifying any conditions) will give all the records in search result page.

            Select Doc Category : Work

                      Doc Type : Bibliographic

                      Doc Format : MARC

   Type one or more keywords in a text box.

   System shows records with any field matching one or more keywords.

4.2  Advanced Search

            Select Doc Category : Work

                      Doc Type : Bibliographic

                      Doc Format : MARC

   The drop down for search fields will be populated based on the category selected above.

   User specifies a search condition:

             Selects a field.

             Enters one or more keywords.

             Specifies whether the keywords should be searched for as "All of these", "Any of these" or "As a phrase".

                            "All of these"   - Any record with the selected field having all the entered keywords is included in the search results.

                           "Any of these" - Any record with the selected field having at least one of the entered keywords is included in the search results.

                           "As a phrase"  - Any record with the selected field having all the entered keywords in same order is included in the search results.

   User adds another condition:

             Chooses whether to apply this condition in addition to the previous one ("AND") or to apply this condition as an alternative to the previous one ("OR")  ("NOT"???),

             "AND"  - the conditions before and after this operator should be satisfied.

             "OR"    - one of the conditions before and after this operator should be satisfied.

             "NOT"  - the condition after this operator should not be satisfied.

   User repeats previous step as many times as needed using the ADD and DELETE links.

          [+]ADD : click on this link to add fields for a new search condition.

           [-]Delete : click on this link to delete the last search condition.

   Search is performed based on the conditions entered by the user.

For more information refer to the "Search" section in the  document :https://wiki.kuali.org/display/OLE/OLE+Search+Technical+Documentation