From af15205846ae2463f1f060da26287b1cd1edf560 Mon Sep 17 00:00:00 2001 From: Alex Zaw Date: Wed, 25 Feb 2026 23:06:49 +0000 Subject: [PATCH] Update Function ES_GET_EMPLOYEE_NUMBER --- .../Functions/ES_GET_EMPLOYEE_NUMBER.sql | 104 +++++++++++++++++- 1 file changed, 103 insertions(+), 1 deletion(-) diff --git a/SAILPOINT/Functions/ES_GET_EMPLOYEE_NUMBER.sql b/SAILPOINT/Functions/ES_GET_EMPLOYEE_NUMBER.sql index 1afd5b9..1dfb0e1 100644 --- a/SAILPOINT/Functions/ES_GET_EMPLOYEE_NUMBER.sql +++ b/SAILPOINT/Functions/ES_GET_EMPLOYEE_NUMBER.sql @@ -1 +1,103 @@ -@@\@^@ % %@@@@Kmmm@M@ %@M]@]@ %@M]@@@ %@@ %@K@ %@@ %@@@ %@@@@ %@@ %@@@@~@\@k@ %@~@\@k@ %@~@\@k@ %@~@Mk@k@]@k@ %@~@\@k@ %@~@\@k@ %@~@\@@@ %@ %@@@@@ %@ %@m@@M@@]@^@ %@mmm@@^@ %@mmm@@M@@]@^@ %@mm@@M@@]@^@ %``@Á@@@ %@@@@ %mmm@~@mm@k@ %m@~@m@k@ %mm@~@m@k@ %mmm@~@mm@^@ %@ %M@ %@m@M@ %}}@@}}@k@}ɕ}@@m@M@ %}⣁}@@m@k@ %}Ö}@@mmm@k@ %}}@@mmm@k@ %}}@@mm@k@ %}㉔}@@m@ %]@ %]@]@^@ %@^@ %@@@@@K@m@M@ %@@M@@]@k@@@M@@]@k@@@M@@]@k@@@M@@]@]@ %@@^@ %@@@@K@@k@@M@}}@OO@ %@@K@@ %@}}@@}}@ %@@M@@K@@k@@]@ %@]@@@ %@@M@ %@m@M@]@@M@ %]@@@k@@ %@m@M@ %@K@mmmm@M@]@k@ %}[K\}@ %@M@ %@@M@@]@@@@}[KɄ}@ %]@ %]@ %]@@ %@ %@ %@@@@@ %@ %@^@ %@@K@m@~@ %}@@Km@}@OO@}⅓@}}}@OO@ %@OO@}}}k@}}}@OO@@OO@}}}k@ŧ䢅k@ŧ@}@ %OO@}@}@OO@@OO@}K@@ŧ䢅@~@}}}@ %OO@@M@@]@OO@}}}}@^@ %@@@K@m@^@ %@^@ %@@^@ %@ %@M@ %m@M@ %}}@z@}}@k@}}@@M@ %@m@M@ %m@M@ %}Ʉ}@@@k@}Ŕ}@@@M@ %@]@ %]@@@ %]@ %@@K@m@]@@@@@@ %]@k@m@M@ %}}@@}}@k@}ɕ}@@m@M@ %}}@@}}@k@ %}}@@}م@@@@}@k@ %}㉔}@@m@ %]@ %]@]@^@ %@@^@ % %@@k@@@@ %@@@K@ %@@@@@^@ % %@@@@ %@@@K@ %@@^@ % % \ No newline at end of file +SET PATH *LIBL ; + +CREATE OR REPLACE FUNCTION SAILPOINT.ES_GET_EMPLOYEE_NUMBER ( + USERNAME CHAR(10) ) + RETURNS CLOB(2147483647) + LANGUAGE SQL + SPECIFIC SAILPOINT.ESMEMPNO + NOT DETERMINISTIC + MODIFIES SQL DATA + CALLED ON NULL INPUT + NOT FENCED + SET OPTION ALWBLK = *ALLREAD , + ALWCPYDTA = *OPTIMIZE , + COMMIT = *NONE , + DECRESULT = (31, 31, 00) , + DYNDFTCOL = *NO , + DYNUSRPRF = *USER , + SRTSEQ = *HEX + BEGIN +DECLARE CONTINUE HANDLER FOR SQLEXCEPTION +BEGIN +DECLARE V_SQLSTATE CHAR ( 5 ) ; +DECLARE V_DB2_RETURN_CODE INT ; +DECLARE V_DB2_MESSAGE_ID CHAR ( 7 ) ; +DECLARE V_ERROR_MESSAGE CLOB ( 2048 ) ; +-- Capture diagnostic info +GET DIAGNOSTICS CONDITION 1 +V_DB2_RETURN_CODE = DB2_RETURNED_SQLCODE , +V_SQLSTATE = RETURNED_SQLSTATE , +V_ERROR_MESSAGE = MESSAGE_TEXT , +V_DB2_MESSAGE_ID = DB2_MESSAGE_ID ; +RETURN +( +VALUES JSON_OBJECT ( +'success' VALUE 'false' , 'SQLInfo' VALUE JSON_OBJECT ( +'SQLState' VALUE V_SQLSTATE , +'SQLCode' VALUE V_DB2_RETURN_CODE , +'messageID' VALUE V_DB2_MESSAGE_ID , +'message' VALUE V_ERROR_MESSAGE , +'currentTimestamp' VALUE CURRENT_TIMESTAMP +) +) ) ; +END ; +DECLARE GLOBAL TEMPORARY TABLE SESSION . EMPNO_LIST ( +ENVID CHAR ( 2 ) , LIB CHAR ( 10 ) , EXUSER CHAR ( 10 ) , EMPNO CHAR ( 8 ) ) +WITH REPLACE ; +FOR SELECT DISTINCT A . ENVID , TRIM ( 'CESLIB' || +CASE A . ENVID +WHEN 'MM' THEN '' +ELSE RIGHT ( A . ENVID , 1 ) +END ) AS CESLIB +FROM TABLE ( +SELECT ROW_NUMBER ( ) OVER ( +) AS RN , ENVID +FROM JSON_TABLE ( +SAILPOINT . ES_GET_ALL_MAPICS_ENVIRONMENTS ( ) , +'$.data[*]' +COLUMNS ( +ENVID VARCHAR ( 2 ) CCSID 37 PATH '$.envId' +) +) +) A +DO +BEGIN +DECLARE CONTINUE HANDLER FOR SQLEXCEPTION +BEGIN +END ; +SET CISTOOLS . SQL_STATEMENT = +'INSERT INTO SESSION.EMPNO_LIST ' || 'Select ''' || +ENVID || ''', ''' || CESLIB || ''', ExUser, Ext08A ' +|| 'FROM ' || CESLIB || '.ESUEXP WHERE ExUser = ''' +|| TRIM ( USERNAME ) || '''' ; +EXECUTE IMMEDIATE CISTOOLS . SQL_STATEMENT ; +END ; +END FOR ; +RETURN +COALESCE ( +JSON_OBJECT ( +'success' : 'true' , 'data' VALUE ( +SELECT JSON_ARRAYAGG ( +JSON_OBJECT ( +'envId' VALUE ENVID , 'userEmpno' VALUE TRIM ( +EMPNO ) +) FORMAT JSON +) +FROM SESSION . EMPNO_LIST ) FORMAT JSON ABSENT ON NULL +) , JSON_OBJECT ( +'success' VALUE 'false' , 'SQLInfo' VALUE JSON_OBJECT ( +'messageID' VALUE 'SQL02000' , +'message' VALUE 'Requested resouce not found ' , +'currentTimestamp' VALUE CURRENT_TIMESTAMP +) +) ) ; +END ; + +GRANT ALTER , EXECUTE +ON SPECIFIC FUNCTION SAILPOINT.ESMEMPNO +TO AMAPICS WITH GRANT OPTION ; + +GRANT EXECUTE +ON SPECIFIC FUNCTION SAILPOINT.ESMEMPNO +TO PUBLIC ; +