Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Info
titleJira Link

https://jira.kuali.org/browse/OLE-30

Info
titleJira Link

https://jira.kuali.org/browse/OLE-31

Info
titleJira Link

https://jira.kuali.org/browse/OLE-32

Info
titleRice2.x Framework

License Request is going to be developed using the new Rice2.x codebase which offers rich UI via the KRAD framework. The various features pertaining to License Request will be tested and demonstrated independently of OLE_Rice1.x. Workflow for License Request will be developed using KRMS framework. License workflow will be integrated with Requisition workflow which exist in OLE_Rice1.x.

License Request :

...

  • A KRAD Document used to create/view/update a License Request Document.
  • Participants:

License Request Create UI

Description Tab:

  • OwnerAssignee – default will be Initiator which will have KIM Person lookup
  • Initiate licensing Workflow – drop down for manual workflow selection, used by KRMS to initiate Peopleflow
  • Current Location – Editable by Initiator if the document not in current Rice workflow
  • License Request Type – New/Renewal/Addendum
    • Renewal - New or final Agreement if method is renewal, will have an Active Date, where the new Agreement becomes the Current/Active, and the original is archived, but still linked
    • Addendum - Amended Agreement will become a supplemental to the original Agreement.Both are active. The parent/primary Agreement stays active, but is versioned by any changes in Addendum once final. Docstore needs to version these.

Event Log Tab:

  • This tab will capture manual adds, and also system generated logs for each file attachment and workflow/routing completion
  • For the manual adding and for Event view, a new UI - Event log view is used.

Agreement Documents Tab:

  • This will provide in adding of all types of agreement documents.
  • This will have the columns date,user,agreement document type,label,file, notes and version.

Agreement(links):

  • If agreement is not linked, then user can see the Create button.
  • If a agreement is linked, then the user can see the Edit button and also displays the datas such as last edited date,user,type status, method, and links of that agreement.
  • Create/Edit button will link to the ONIX-PL Editor.

View Related Documents:

  • This will have a link to the Requisition Document from which it is created.

Notes and Attachments:

  • These will not be linked with agreements and stored in docstore. This will be used

Adhoc Recipients:

  • Used for undefined routing not in standard workflow – not for approval, but for FYI and Acknowledgement.

Route Log:

  • Used for predefined workflow/routing per workflow table and also for ad hoc tracking

License Request Workflow

Image Removed

Compare License Flow
Image Removed 

  • FrameWork: Rice2.x
  • workflow:

License Request Workflow

Image Added

Compare License Flow
Image Added 

License Negotiation Flow
Image Added

License Request Search:

  • Simple KRAD screen will be used to search the License Request Documents using the Title, License Request Status, Owned By, Current Location.
  • The Result fields will be Doc Id, Bib Title, License Request Status, Date Last Modified, Initiator, Current Location.
  • This Search will have the option for saving with a name.
  • Participants:
  • FrameWork: Rice2.x

Manage CheckList:

  • A simple KRAD Maintenance Document will used for upload/create, search, delete past checklist and update checklist description and active status
  • This will have checklist name,checklist author and active indicator as the search criterias.
  • Participants:
  • FrameWork: Rice2.x

Agreement Search:

  • A simple KRAD screen which will search the agreement details from the docstore.
  • Search filters will be agreement title, contract number, licensee, licensor/agent and the result fields will be agreement title, licensee, licensor/agent, date modified and the agreement method.
  • Participants:
  • FrameWork: Rice2.x

Requistion :

  • Existing Transactional Document in Rice 1.x
  • Contains a checkbox for the License Request initiation.
  • Participants:
  • FrameWork: Rice1.x
  • workflow:

Image Added

Requisition Search:

  • Existing Requisition Search screen in Rice 1.x.Extended the Requisition Search to have the new Licensing Workflow value ALNC- Awaiting Licensing Negotiation Completion, DLNF- Disapproved- License Negotiation Failed in the Requisition Status.
  • Participants:
  • FrameWork : Rice1.x

Order Holding Queue Search:

  • Existing Order Holding Queue Search screen in Rice 1.x.Modified Order Holding Queue to have the new Licensing Workflow value ALNC- Awaiting Licensing Negotiation Completion, DLNF- Disapproved- License Negotiation Failed in the Requisition Status.
  • Participants:
  • FrameWork : Rice1.x

Security:

General Business Rules :

  • Requisition can link to only one or no License Request.
  • A License request can link to one or many Agreement documents.
  • A License request can link to only one Agreement if License Request Type is New.
  • A License request can link to one or more Agreement if License Request Type is Renewal or Addendum.
  • Agreements can be linked to 1:Many Agreement Documents.
  • Version all Agreement Documents.
  • Upon uploading Agreement Documents through the License Request- the License Request, Requisition, Agreement, and Agreement Documents should be linked with each other.
  • Agreements can be linked to 1:Many License Requests.
  • Agreement meta data and content can only be “viewed” from the License Request. It can be edited only through ONIX-PL license Editor.       

 Roles :

 a) OLE_Licenses : OLE_Licenses are the assignees for Requisitions requiring licenses or license negotiations. This role is the “owner” of the license agreement, and has full edit, attachment, routing, and status change permissions. Can create, edit, and delete Agreements. Can upload, edit, and delete Agreement Documents. Can edit a License Request to record events or send a license request. Can select only from allowable "intiate licensing workflow" options: License Needed, License Requested, Licence Received, In Process, In Negotiation

 b) OLE_LicenseManager : OLE_Licenses are the assignees for Requisitions requiring licenses or license negotiations. This role is the “owner” of the license agreement, and has full edit, attachment, routing, and status change permissions. Can create, edit, and delete Agreements. Can upload, edit, and delete Agreement Documents. Can edit a License Request to record events or send a license request. Can initiate any selection from "initiate licensing
workflow"

 c) OLE_Licensing_Approver : Permission to add to event log, execute Action buttons, Ad hoc routing, edoc Notes/Attachments. Cannot edit Agreements,change or upload Agreement documents, or edit status. Blanket Approve (to complete workflow), or Disapprove (requires Event Log entry and returns edoc to designated workflow.

 d) OLE_LicenseConfiguration : View, Edit, Create, delete Checklists only.

 e) OLE_Signatory : View, Edit, download/upload Agreement Documents. Can edit a License Request to change status, store correspondence, or add notes.

 f) OLE_User : Can add to Event log, upload Agreement Docs, and Submit if routed adhoc FYI or Acknowledge. Cannot modify Agreements (view only). Cannot delete anything. Cannot download.

 g) OLE_LicenseViewer : This role can "view only" Agreements, Agreement docs, License Requests. No editing or download.

 h) OLE_LicenseReviewer: View only License Request and Agreement; download & upload agreement docs.

People Flow Logic : Below table lists the People Work flow based on the Rule. The rule need to pass two determinants (License Request Type and Agreement Method). Based on the Rule evaluation People Flow (workflow) Allowed,Not Allowed, Required determined.

Based on the user selection in drop down provided for Initiate License Workflow (selected by user in OLE_LicenseManager Role) and upon submission of document, the rule is evaluated and document routed to the users in People flow based on the selection.

If unallowable workflow status is selected, determined by the rule evaluation, the exception message (“Owner must select allowable workflow for this license request type and Agreement Method.” ) is shown.

Rule

Allowed

*Not Allowed*

Required

Approval Requirements

License Request Type = New and Agreement Method= Negotiated License

 

Manual (Self), Signatory Only, Review Only, Approval Only Renewal, Addendum

Full Approval

Need to be approved by ALL USERS in role.

License Request Type = New and Agreement Method= SERU

Full Approval,Signatory Only
Review Only, Approval Only

Manual (Self), Renewal,Addendum

 

Need to be approved by ALL USERS in role.

License Request Type = New and Agreement Method = *Copyright Law*

Full Approval,Review Only, Approval Only

Manual (Self), Renewal,Addendum

 

ANY in Role.

License Request Type = New and Agreement Method = *Click Thru*

Review Only, Approval Only

Manual (Self), Renewal,Addendum

 

ANY in Role.

License Request Type = New and Agreement Method = *Shrink Wrap*

Review Only, Approval Only 

Manual (Self), Renewal,Addendum, Full Approval

 

ANY in Role.

License Request Type = Renewal and Agreement Method= Negotiated License

 

Manual (Self),Signatory Only, Review Only, Approval Only Full Approval, Addendum

Renewal

Need to be approved by ALL USERS in role.

License Request Type = Renewal and Agreement Method= SERU

Manual (Self),Signatory Only, Review Only, Approval Only Full Approval, Renewal

Addendum

 

ANY in Role.

License Request Type = Renewal and Agreement Method = *Copyright Law*

Manual (Self), Signatory Only, Review Only, Approval Only Full Approval, Renewal

Addendum

 

ANY in Role.

License Request Type = Addendum and Agreement Method= Negotiated License

Manual (Self),Signatory Only, Review Only, Approval Only Full Approval, Addendum

Renewal

 

ANY in Role.

License Request Type = Addendum and Agreement Method = SERU

Manual (Self), Signatory Only, Review Only, Approval Only Full Approval, Addendum

Renewal

 

ANY in Role.

 

Roles assigned to People Flow :

Manual (Self) : Blanket Approve by the owner of the Document.

Review Only : Initiated by selecting Pending Review (PREV) by OLE_LicenseManager and submits the document. OLE_LicensingReveiwer Role approves the document. Upon Complete status changed to Review Complete (RVWC) .

Signatory Only : Initiated by selecting Pending Signature(PSIG) by OLE_LicenseManager and submits the document. Document moves to action list of OLE_Signatory Role. Upon Complete status changed to Signature Complete(SIGC).

Approval Only : Initiated by selecting Pending Approval (PAPP) by OLE_LicenseManager and submits the document. OLE_LicensingApprover Role approves or disapproves the document. If document is approved status changed to Complete (LC) and document continues with Requisition workflow, else status changed to Negotiation Failed. (LNF) . Requisition document owner is notified of the status change.

Full Approval : Document first goes to Review Step. Upon completion status changed to Pending University (PUNI) . University processing complete (UNIC) selected manually by OLE_LicenseManager and document submitted again. Document goes to Signatory step and upon completion goes to Approval step.

Renewal : Document first goes to Review Step. Upon completion status changed to Pending University (PUNI) . University processing complete (UNIC) selected manually by OLE_LicenseManager and document submitted again. Document goes to Signatory step and upon completion goes to Approval step.

Addendum : Document first goes to Review Step. Upon completion document goes to Signatory step and upon completion goes to Approval step.

Services:

Agreement lookup search :

  • OleAgreementSearchService
    • getAgreementSearchResults
    • getAgreementSearchResults(Map agreementFilters)

License Request create/Search:

  • OleLicenseRequestCreateService (invoked by requisition submit)
    • createLicenseRequest
  • OleLicenseRequestService
    • generateAgreement
    • ingestAgreement
    • processAgreementResponse
    • getLicenseRequestSearchResults(Map licenseFilters)
    • Data Model

Image Added

XML Ingest for KRMS Builder:

        Related jira - https://jira.kuali.org/browse/OLE-3144

   Sample xml for creating Rules:  license.xml

   1) The above xml contains list of Agendas.

   2) An Agenda contains list of Rules,each rule contains either a simple proposition or compound proposition and true Actions.

      a) A Simple proposition can be validated in two different ways namely

                        LHS & RHS  validations (LHS-Term,RHS-Constant)

                        Function validations(Term as argument).

      b) A Compound proposition is a collection of Simple proposition with an operand.

      c) If Proposition of the given rule becomes true, true Actions will be executed which contain list of action.

                      An Action contain  i) service name (e.g.approvalPeopleFlowActionTypeService,notificationPeopleFlowActionTypeService) - to define whether to approve or notify the document.

                                                  j) name - people flow name which is already defined through script, the defined people flow contain certain predefined roles(e.g. OLE_Signatory etc.).

   3)The Following rules are implemented:

   a) Rule1 (newNegFAppCheck) : Validates whether the licenseType is New,the agreementMethod is Negotiated License and the workflowName is Full Approval, if this validation becomes true, newNegFApp People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer,OLE_LicenseManager,OLE_Signatory and OLE_Licensing_Approver.

   b) Rule2 (newSERUSignCheck) : Validates whether the licenseType is New,the agreementMethod is SERU and the workflowName is Signatory Only, if this validation becomes true, newSERUSign People Flow Action  will be executed which contains certain predefined roles namely OLE_Signatory and OLE_LicenseManager.

   c) Rule3 (newSERURevCheck) : Validates whether the licenseType is New,the agreementMethod is SERU and the workflowName is Review Only, if this validation becomes true, newSERURev People Flow Action   will be executed which contains certain predefined roles namely OLE_LicenseReviewer and OLE_LicenseManager.

   d) Rule4 (newSERUAppCheck) : Validates whether the licenseType is New,the agreementMethod is SERU and the workflowName is Approval Only, if this validation becomes true, newSERUApp People Flow Action  will be executed which contains certain predefined roles namely OLE_Licensing_Approver and OLE_LicenseManager.

   e) Rule5 (newSERUFAppCheck) : Validates whether the licenseType is New,the agreementMethod is SERU and the workflowName is Full Approval, if this validation becomes true, newSERUFApp People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer,OLE_LicenseManager,OLE_Signatory and OLE_Licensing_Approver.

   f) Rule6 (newCopyRevCheck) : Validates whether the licenseType is New,the agreementMethod is CopyrightLaw and the workflowName is Review Only, if this validation becomes true, newCopyRev People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer and OLE_LicenseManager.

   g) Rule7 (newCopyAppCheck) : Validates whether the licenseType is New,the agreementMethod is CopyrightLaw and the workflowName is Approval Only, if this validation becomes true, newCopyApp People Flow Action  will be executed which contains certain predefined roles namely OLE_Licensing_Approver and OLE_LicenseManager.

   h) Rule8 (newCopyFAppCheck) : Validates whether the licenseType is New,the agreementMethod is CopyrightLaw and the workflowName is Full Approval, if this validation becomes true, newCopyFApp People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer,OLE_LicenseManager,OLE_Signatory and OLE_Licensing_Approver.

   i) Rule9 (newClickRevCheck) : Validates whether the licenseType is New,the agreementMethod is ClickThru and the workflowName is Review Only, if this validation becomes true, newClickRev People Flow Action   will be executed which contains certain predefined roles namely OLE_LicenseReviewer and OLE_LicenseManager.

   j) Rule10 (newClickAppCheck) : Validates whether the licenseType is New,the agreementMethod is ClickThru and the workflowName is Approval Only, if this validation becomes true, newClickApp People Flow Action  will be executed which contains certain predefined roles namely OLE_Licensing_Approver and OLE_LicenseManager.

   k) Rule11 (newShrinkRevCheck) : Validates whether the licenseType is New,the agreementMethod is ShrinkWrap and the workflowName is Review Only, if this validation becomes true, newShrinkRev People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer and OLE_LicenseManager.

   l) Rule12 (newShrinkAppCheck) : Validates whether the licenseType is New,the agreementMethod is ShrinkWrap and the workflowName is Approval Only, if this validation becomes true, newShrinkApp People Flow Action  will be executed which contains certain predefined roles namely OLE_Licensing_Approver and OLE_LicenseManager.

   m) Rule13 (RenNegRenCheck) : Validates whether the licenseType is Renewal,the agreementMethod is Negotiated License and the workflowName is Renewal, if this validation becomes true, RenNegRen People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer,OLE_LicenseManager,OLE_Signatory and OLE_Licensing_Approver.

   n) Rule14 (renSERUSignCheck) : Validates whether the licenseType is Renewal,the agreementMethod is SERU and the workflowName is Signatory Only, if this validation becomes true, renSERUSign People Flow Action  will be executed which contains certain predefined roles OLE_Signatory and OLE_LicenseManager.

   o) Rule15 (renSERURevCheck) : Validates whether the licenseType is Renewal,the agreementMethod is SERU and the workflowName is Review Only, if this validation becomes true, renSERURev People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer and OLE_LicenseManager.

   p) Rule16 (renSERUAppCheck) : Validates whether the licenseType is Renewal,the agreementMethod is SERU and the workflowName is Approval Only, if this validation becomes true, renSERUApp People Flow Action  will be executed which contains certain predefined roles namely OLE_Licensing_Approver and OLE_LicenseManager.

   q) Rule17 (renSERUFAppCheck) : Validates whether the licenseType is Renewal,the agreementMethod is SERU and the workflowName is Full Approval, if this validation becomes true, renSERUFApp People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer,OLE_LicenseManager,OLE_Signatory and OLE_Licensing_Approver.

   r) Rule18 (renSERURenCheck) :Validates whether the licenseType is Renewal,the agreementMethod is SERU and the workflowName is Renewal, if this validation becomes true, renSERURen People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer,OLE_LicenseManager,OLE_Signatory and OLE_Licensing_Approver.

   s) Rule19 (renCopyRevCheck) : Validates whether the licenseType is Renewal,the agreementMethod is CopyrightLaw and the workflowName is Review Only, if this validation becomes true, renCopyRev People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer and OLE_LicenseManager.

   t) Rule16 (renCopyAppCheck) : Validates whether the licenseType is Renewal,the agreementMethod is CopyrightLaw and the workflowName is Approval Only,, if this validation becomes true, renCopyApp People Flow Action  will be executed which contains certain predefined roles namely OLE_Licensing_Approver and OLE_LicenseManager.

   u) Rule17 (renCopyFAppCheck) : Validates whether the licenseType is Renewal,the agreementMethod is CopyrightLaw and the workflowName is Full Approval, if this validation becomes true, renCopyFApp People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer,OLE_LicenseManager,OLE_Signatory and OLE_Licensing_Approver.

   v) Rule18 (renCopyRenCheck) : Validates whether the licenseType is Renewal,the agreementMethod is CopyrightLaw and the workflowName is Renewal, if this validation becomes true, renCopyRen People Flow Action  will be executed which contains certain predefined roles namely OLE_LicenseReviewer,OLE_LicenseManager,OLE_Signatory and OLE_Licensing_Approver.

etc..

If None of the above rules becomes true, validation message should be thrown in the screen.

4) Admin can add a new rule by adding a rule tag in the license.xml , changing the constant for licenseType,agreementMethod and workflowName if needed, and the People Flow Action should be predefined with certain roles,the  name of Predefined People Flow should be given under action name.