Perils of DataMover Access– Part 2a
PeopleSoft provides trigger-based auditing functionality as an alternative to the record-based auditing that PeopleSoft Application Designer provides. Perform the following steps to setup trigger based auditing for PSAUTHITEM.
1. Create a custom table to store the audit data for PSAUTHITEM. And build the record in the database.
data:image/s3,"s3://crabby-images/2b9cc/2b9cc12109c2fddfdeeb1aa7ed7d7a9f8ac47694" alt="datamover2a1 datamover2a1"
data:image/s3,"s3://crabby-images/2b9cc/2b9cc12109c2fddfdeeb1aa7ed7d7a9f8ac47694" alt="datamover2a1 datamover2a1"
2. Navigate to PeopleTools –> Utilities –> Audit –> Update Database Level Auditing.
data:image/s3,"s3://crabby-images/4f57d/4f57d21931a7e3b75c9dc524bc7516a4d2965582" alt="datamover2a2 datamover2a2"
3. Add a New Value and select Record Name PSAUTHITEM
data:image/s3,"s3://crabby-images/8a3e8/8a3e83b870a7962eeb18f165593a5e083913fe58" alt="datamover2a3 datamover2a3"
data:image/s3,"s3://crabby-images/8a3e8/8a3e83b870a7962eeb18f165593a5e083913fe58" alt="datamover2a3 datamover2a3"
4. Select the record AUDIT_AUTHITEM (we created in step 1) as the Audit Record.
data:image/s3,"s3://crabby-images/227a7/227a7c45918a6ac3fb3faecb5aff4a810cd191e8" alt="datamover2a4 datamover2a4"
data:image/s3,"s3://crabby-images/227a7/227a7c45918a6ac3fb3faecb5aff4a810cd191e8" alt="datamover2a4 datamover2a4"
5. Check all the audit options.
6. Click on Generate Code button. This will generate the SQL for creating the trigger..
data:image/s3,"s3://crabby-images/0a612/0a612f4bc777b79ea7b78a4229649506d2901504" alt="datamover2a5 datamover2a5"
7. Modify the script as below to include the MENUNAME.
CREATE OR REPLACE TRIGGER PSAUTHITEM_TR
8. Ensure that the GET_PS_OPRID function exists. Copy the SQL and execute it in SQLPLUS .
Now we are ready to audit any changes to PSAUTHITEM.
Summary
In my next post, I will demonstrate a test scenario and also provide insights into monitoring the audit results.
Summary
In my next post, I will demonstrate a test scenario and also provide insights into monitoring the audit results.
AFTER INSERT OR UPDATE OR DELETE ON PSAUTHITEM
FOR EACH ROW
DECLARE
V_AUDIT_OPRID VARCHAR2(64);
BEGIN
DBMS_APPLICATION_INFO.READ_CLIENT_INFO(V_AUDIT_OPRID);
IF INSERTING
THEN
INSERT INTO PS_AUDIT_AUTHITEM
VALUES (GET_PS_OPRID(V_AUDIT_OPRID),SYSDATE,’A',:NEW.CLASSID,
:NEW.MENUNAME,:NEW.BARITEMNAME,:NEW.PNLITEMNAME,:
NEW.DISPLAYONLY,
NEW.DISPLAYONLY,
:NEW.AUTHORIZEDACTIONS);
ELSE
IF DELETING
THEN
INSERT INTO PS_AUDIT_AUTHITEM
VALUES (GET_PS_OPRID(V_AUDIT_OPRID),SYSDATE,’D',:OLD.CLASSID,
:OLD.MENUNAME,:OLD.BARITEMNAME,:OLD.PNLITEMNAME,:
OLD.DISPLAYONLY,
OLD.DISPLAYONLY,
:OLD.AUTHORIZEDACTIONS);
ELSE
INSERT INTO PS_AUDIT_AUTHITEM
VALUES (GET_PS_OPRID(V_AUDIT_OPRID),SYSDATE,’K',:OLD.CLASSID,
:OLD.MENUNAME,:OLD.BARITEMNAME,:OLD.PNLITEMNAME,:
OLD.DISPLAYONLY,
OLD.DISPLAYONLY,
:OLD.AUTHORIZEDACTIONS);
INSERT INTO PS_AUDIT_AUTHITEM
VALUES (GET_PS_OPRID(V_AUDIT_OPRID),SYSDATE,’N',:NEW.CLASSID,
:NEW.MENUNAME,:NEW.BARITEMNAME,:NEW.PNLITEMNAME,:
NEW.DISPLAYONLY,
NEW.DISPLAYONLY,
:NEW.AUTHORIZEDACTIONS);
END IF;
END IF;
END PSAUTHITEM_TR;
0 comments:
Post a Comment