Pages

Custom Search

How to flush an existing data from a grid placed on level 2

Local Rowset &rsLvl1, &rsLvl2;

/* Get Level 1 Rowset */
&rsLvl1 = GetLevel0()(1).GetRowset(Scroll.XXX1); /* Gets the current row of Level 0. */

For &i = 1 To &rsLvl1.ActiveRowCount
 
   /* Get Level 2 Rowset */
   &rsLvl2 = &rsLvl1(&i).GetRowset(Scroll.XXX2);
 
   /* Flush Record */
   &rsLvl2.Flush();
   /* Select Record */
   &rsLvl2.Select(Record.XXX2, "WHERE TERM = :1", &rsLvl1.GetRow(&i).XXX1.STRM.Value);
 
End-For;

Copying Rowsets

What I want is to copy the like-name fields between &rsExample and &rsExampleAudit (the fields EMPLID and NAME).

The following code will NOT work:
&rsExample.CopyTo(&rsExampleAudit)

Why? Because &rsExample consists of a record named EXAMPLE, but &rsExampleAudit consists of a record named AUDIT_EXAMPLE. Because the two rowsets do not have the same underlying record name, the copy does absolutely nothing.

In this scenario, we need to specify a record list, so it knows the source and target record names. This how I need to write this code to make it work:
&rsExample.CopyTo(&rsExampleAudit, Record.EXAMPLE, Record.AUDIT_EXAMPLE)

Generically the syntax is:
&rsSource.CopyTo(&rsTarget, Record.SOURCE_RECNAME, Record.TARGET_RECNAME)

You are not authorized to access this component. (40,20)

It is clear that when this message is shown, it means we have a security issue.









We can assign security to the permission list and this will fix the issue., but sometimes the security is already assigned and then you are wondering what can be the other issue. 

So, there are two fixes which you can do -

1. Uncheck the security, hit save and then reassign the security to the permission list.

2. Run Portal Security Sync. This will fix the problem. It's an application engine which will run and fix the security problems.

  • PeopleTools   >
  • Portal
  • Portal Security Sync

You are trying to hide a grid using group box, but it's still showing up.

If you are trying to hide a grid using a group box, but grid still shows up then check the group box on the page. Group box will touching border of the grid. When the border of group box touches the grid, even if you have added the code to hide it, it won't hide it.

Order tab will be correct, i.e. Group box will be on level 0 and Grid will be on level 1., but because of the borders touching the grid won't hide.

Opening a new window

Soure: http://peoplesoft.wikidot.com/opening-a-new-window

/*****************************************************************************
 NewWinUrl(&strUrl)

 This function modifies a URL to return a new window URL
 It allows a new state block to be generated in a separate browser instance.
 http://server:port/psp/ps/EMPLOYEE/HRMS/c/......
 turns into
 http://server:port/psp/ps_newwin/EMPLOYEE/HRMS/c/......
 which renders to the browser as
 http://server:port/psp/ps_1/EMPLOYEE/HRMS/c/......

 Input parameters:  &strUrl - a URL to manipulate
 Output parameters: &strUrlModified - New URL with _newwin parameter

 ****************************************************************************/

Function NewWinUrl(&strUrl As string) Returns string;
   Local string &sRegex, &sReplace, &Result;
   /* Declare java object */
   Local JavaObject &jUrl;
 
   /**
    * Peoplesoft Content types:
    * -------------------------
    * Component: c
    * Script: s
    * External: e
    * Homepage: h
    * Template: t
    * Query: q
    * Worklist: w
    * Navigation: n
    * File: f
   **/
 
   /* Regex strings */
   /*          psc/psp  Site      Portal    Node      Content Type */
   &sRegex = "/(ps[cp])/([^\/]*)?/([^\/]*)?/([^\/]*)?/([csehtqwnf]{1})/";
   &sReplace = "/$1/$2_newwin/$3/$4/$5/";
 
   /* Instantiate objects and replace */
   &jUrl = CreateJavaObject("java.lang.String", &strUrl);
 
   &Result = &jUrl.replaceAll(&sRegex, &sReplace);
 
   /* Return modified URL */
   Return &Result;
End-Function;

SQL.Fetch: SamFetch: [Microsoft][SQL Server Native Client 11.0]Function sequence error (SQLSTATE S1010) 0. (2,294)

This error occurs when your code is binding with Data-At-Execution.  
The function sequence error must be in SQLFetch or the next API after SQLExecute. 
SQL_NEED_DATA is returned when a parameter is bound with a StrLenOrInd value of SQL_LEN_DATA_AT_EXEC(x) or SQL_DATA_AT_EXEC.  
If you are not explicitly setting this in the SQLBindParameter call, then it is likely an uninitialized variable that is occasionally being set to these values. 
If you don't want to stream input parameters, the best way to deal with it is to fix StrLen_or_IndPtr to the appropriate value for the type.  
If you do want to send Data at exec, you need to call SQLParamData after SQLExecute.  It will return the value you passed in for "ParameterValuePtr" below.  
You can then use this to key into the stream to send with SQLPutData.  You use SQLPutData to push the data up in chunks until you are done, then call SQLParamData again to get the next parameter to fill or to finish streaming.  
The final SQLParamData will return the return code that would originally have been returned by SQLExecute.

SQLRETURN SQLBindParameter(
      SQLHSTMT        StatementHandle,
      SQLUSMALLINT    ParameterNumber,
      SQLSMALLINT     InputOutputType,
      SQLSMALLINT     ValueType,
      SQLSMALLINT     ParameterType,
      SQLULEN         ColumnSize,
      SQLSMALLINT     DecimalDigits,
      SQLPOINTER      ParameterValuePtr,
      SQLLEN          BufferLength,
      SQLLEN *        StrLen_or_IndPtr); <--- this is the value that is causing SQL_NEED_DATA to be returned

Invalid Item_Type

If you are getting invalid ITEM_TYPE, do the following steps:

1. Check the institution set.
2. Check the effective date on your item type page. It should match with your default term.
     
           Setup SACR > Product Related > Student Financials > Item Types > Item Types

      3. Check the effective date on Charge Priority list.

            Setup SACR > Product Related > Student Financials> Charges and Payments> Charge Priority List


         

FieldChange PeopleCode event won’t fire

Sometimes (on radio buttons for instance) FieldChange PeopleCode event won’t fire if the component is set to deferred processing and at the field level, the allow deferred processing checkbox is selected.

To always ensure that FieldChange (and other) PeopleCode events fire, leave the allow deferred processing checkbox unchecked for in the page-field settings.

OR 

In the component properties, change it to Interactive instead of Deferred.

Integrating population selection

Found an interesting source on how to integrate population selection into custom processes.

Source : http://www.udeps.com/Articles/Pop_Select.pdf

Download it here: http://www.udeps.com/Articles/Pop_Select.pdf

Adding Pop Select to your own processes

Here are the links to some documentation about Population Selection and how to integrate it into a custom process.

You can also check out the run control page for some of the PS delivered processes in CS:

·         Campus Community > Service Indicators > Person > Mass Assign
·         Student Financials > Charges and Payments > Group Processing > Mass Select Transactions
·         Records and Enrollment > Career and Program Information >Process Student Groups

PeopleBooks:


HEUG
Oracle over view on how to enable Pop Select in your own processes:

Example from a school that used it to build a process to assign advisors to students


Grade Change Audit Table Triggers

Grade Change Audit is done through table triggers. 

There's a bit of info on this Customer Connection article: https://support.oracle.com/epmos/faces/DocContentDisplay?id=1495960.1

To turn on Grade Auditing, a SQL script just needs to be run against environment.

The grade audit one is called ssr_mss_grade_tr.sql. 

You'll also see a bunch of other scripts in there starting with ssr_ to audit other tables.

If any future auditing is needed, just run the appropriate script in that folder. Only run scripts that contain _mss_ (Microsoft SQL Server); the other scripts are for Oracle and DB2.

Altering a PS table?

You cannot directly create tables using SQL when you’re on a PeopleSoft system. 

PeopleSoft tables must be created using the create script generated by App Designer. 

If you try and do it manually, the table is assigned a different schema. 

Schema’s limit your results to only one user instead of all users.




Adding Homepage Tabs

Adding Homepage Tabs
To add a new homepage tab:
  1. Select PeopleTools, Portal, Structure and Content.
  2. Click the Portal Objects link.
  3. Click the Homepage link.
  4. Click the Tabs link.
  5. Click the Add Content Reference link.

Creating Homepage Tabs
To create homepage tabs:
  1. Click the Add Content Reference link.
  2. Enter a name and label for the new tab.
Note. The label value appears as the homepage tab name.
  1. In the Usage Type field, select Homepage tab.
After selecting Homepage tab, the page refreshes to display two additional pages, the Tab Content and Tab Layout pages.
  1. In the Valid from date field, enter the date that you want the tab to first appear for your users. Optionally, enter a valid to date to remove the tab from use.
  2. Select the homepage tab attributes.
  3. Define the tab content and tab layout.
  1. Click the Save button.
  2. To view the newly defined tab, click Home to return to your homepage.
Rearranging the Tab Order
The sequence number determines the homepage tab order. The tabs appear with the lowest sequence number first. If any numbers are identical, then the order is alphanumeric. If no sequence numbers exist, the default is considered to be zero. For example, if no sequence numbers are entered, the default is zero, and the order is alphanumeric.
To rearrange the tab order:
  1. Select PeopleTools, Portal, Structure and Content.
  2. Click the Portal Objects link.
  3. Click the Homepage link.
  4. Click the Tabs link.
  5. Click the Edit link for each tab that you want to reorder.
  6. Enter a number in the Sequence field.
If caching is turned on for the portal, the tab order change does not take effect until the caching recycles or the web server is restarted.


Student Administration Integration Pack (SAIP)



1.       Introduction

Oracle’s Enterprise Student Administration Integration Pack (SAIP) offered in Campus Solutions 9.0 provides an effective and cost-reliable way to integrate manage administrative, teaching and learning systems on Campus. It is a web-based interface for passing person, course, and enrollment data from PS Campus Solutions to external systems, such as Moodle.

It integrates with following PS applications:
-          Campus Solutions Student Administration, specifically Student Records
-          Campus Community
-          Integration Broker
-          Campus Self-Service
By implementing SAIP, it allows us to move and update large amounts of academic data from PS to external systems with minimal manual intervention.
2.       SAIP Key Elements

Functional:
-          Scoping and Association of classes
-          Flexible section association, including cross-listed courses
-          Cascading and overrideable defaults
Technical:
-          Standard Based (IMS Learning Information Services)
-          Web Services
-          Batch and Real Time Integration

3.       PeopleSoft Enterprise Student Administration Integration Pack Details

-          Higher education institutions have traditionally implemented learning management systems which allow instructors to manage their courses and exchange information with students independently, providing minimal integration with their student administrative systems. This approach requires institutions to develop complex, customized integrations between systems to improve visibility into curriculum and enrollment data. Customized integration cannot deliver the highly-accessible, user-friendly online experience today's Web-savvy students expect.

-          SAIP delivers a flexible, scalable, Web services-based interface for sharing academic data between the PeopleSoft Enterprise student information system and standards-based learning management systems delivering unprecedented access to information.

For example, when an administrator creates a course in the student system, the interface passes information to the learning management system, which automatically creates a corresponding course site or virtual learning space. As students enroll in the course through PeopleSoft Enterprise Campus Solutions, their enrollment information flows directly into the learning management system and they receive all appropriate access privileges.

-          This approach eliminates the need for re-entering data or re-synchronizing the two systems with every update, particularly helpful for final grade reporting, a previously disconnected process that required administrators to re-key grades into the student information system.

-          To build on existing knowledge, contribute to a community of users and developers and ensure future maintainability and extensibility, Oracle has employed open standards in SAIP and is participating in discussions to extend, modify or create standards and specifications where none exist.

The product leverages the IMS Learning Information Services (LIS) standard specification: http://www.imsglobal.org/es/index.html, which defines standard information models and protocols for people, courses, enrollments and outcomes.

-          Oracle has also partnered with Blackboard Inc., Desire2Learn Inc, Sakai and Moodle to make integration with these learning management systems less costly, more flexible and extensible to future technologies, enhancements and upgrades. This provides customers with flexibility in vendor choice.

-          Oracle and its partners plan to continue developing the Academic Enterprise Solutions platform, eventually integrating and extending the broad range of systems that support the education experience including student systems, learning management, collaboration and communication, analytics, identity management, library systems, parking and housing systems and more.

Snapshot Integration

A snapshot enables you to move the full set of relevant academic data from your PeopleSoft Campus Solutions system to the target external system when needed. Snapshots are tolerant of lost messages or missed data objects. Any subsequent snapshot transmittal sets the target system back in synchronization with the source system.
Grade Import

When enabled, Grade Import allows faculty members to import final grades on a per-course basis from your LMS into the PeopleSoft Student Records online grade roster.

The IMS LIS specification allows for two different models of Outcomes integration: a "pull" methodology in which one system (usually the final system of record, such as the student information system) requests the grades from the system in grades have initially been entered (such as a learning management system); and a "push" methodology in which the system, in which the grades have initially been entered, sends the grades to the final system of record based on an action within that initial system. SAIP supports both of these models.

Event-Based Trigger Integration

Event-driven integration enables near real-time synchronization between your PeopleSoft Campus Solutions systems and the external system. For example, if a student successfully enrolls in a course in PeopleSoft Student Administration, and a corresponding course site exists in your external system, that student is added in near real time as a valid participant in the course site.


4.       SAIP with Moodle

SAIP Integration with Moodle will help in providing near-real-time synchronization between two systems. For example,

1. Creating a user/student in PS - Creates a user in Moodle.

2. Creating a Course in PS - Creates a course in Moodle.

3. Enrolling a student to a course in PS - Enrolls the student to course in Moodle.

Tools that support Moodle Integration

-          Moodlerooms: The new tools developed by Moodlerooms take the integration between SAIP and Moodle further, providing continuous synchronization of course, student, and enrollment information between the two systems as opposed to having to manually export and import the data--an extremely valuable function for managing constant drop/adds during course enrollment periods each semester.

-          Psydev : Psydev’s LIS Gateway for Moodle is a certified Moodle LIS implementation and can be used to integrate Moodle with any LIS-conformant Student Information System.



XMLP Steps for peoplesoft


1.       Creating Data Source
-          Add a new value
-          Select Data Source as PS Query and Data source ID as the name of the query
-          Hit “Add”
Click on Generate and it will generate the file. Do not click on regenerate.
 
-          Hit Save
-          Click on XML and save the xml file at local directory

2.       Open .XML file that was generated and save it on your desktop.
3.       Open word document and go to Add-Ins tab. Click Data > load XML data. Select the XML file you’ve saved and click Ok. Data will be saved.
4.       Go to Insert and select fields and insert it as you would want it to be displayed.
5.       Create Report Definition of the same name as XMLP report

6.       Create Application EngineXMLP Steps
1.       Creating Data Source
-          Add a new value
-          Select Data Source as PS Query and Data source ID as the name of the query
-          Hit “Add”
Click on Generate and it will generate the file. Do not click on regenerate.
 

-          Hit Save
-          Click on XML and save the xml file at local directory

2.       Open .XML file that was generated and save it on your desktop.
3.       Open word document and go to Add-Ins tab. Click Data > load XML data. Select the XML file you’ve saved and click Ok. Data will be saved.
4.       Go to Insert and select fields and insert it as you would want it to be displayed.
5.       Create Report Definition of the same name as XMLP report
6.       Create Application Engine