SET PATH *LIBL ; CREATE OR REPLACE FUNCTION SAILPOINT.ES_V2_GET_MAPICS_USER_INFO ( ENVIRONMENT CHAR(2) , NAME_OR_ID VARCHAR(60) DEFAULT NULL ) RETURNS CLOB(2147483647) LANGUAGE SQL SPECIFIC SAILPOINT.V2_ESRTVMUSRI NOT DETERMINISTIC MODIFIES SQL DATA CALLED ON NULL INPUT NOT FENCED SET OPTION ALWBLK = *ALLREAD , ALWCPYDTA = *OPTIMIZE , COMMIT = *NONE , DBGVIEW = *SOURCE , DECRESULT = (31, 31, 00) , DLYPRP = *NO , DYNDFTCOL = *NO , DYNUSRPRF = *OWNER , SRTSEQ = *HEX BEGIN SET CISTOOLS . LIBL = CISTOOLS . SET_LIBRARY_LIST ( ENVIRONMENT ) ; RETURN ( SELECT JSON_OBJECT ( 'data' : JSON_ARRAYAGG ( JSON_OBJECT ( 'envId' VALUE CISTOOLS . MAPICS_ENV , 'userId' VALUE TRIM ( CAST ( F0BUCD AS VARCHAR ( 10 ) CCSID 37 ) ) , 'userName' VALUE TRIM ( CAST ( F0H1TX AS VARCHAR ( 60 ) CCSID 37 ) ) , 'operatorId' VALUE TRIM ( CAST ( GUAAHY AS VARCHAR ( 5 ) CCSID 37 ) ) , 'userType' VALUE TRIM ( CAST ( CASE EXTYPE WHEN ' ' THEN 'General User' WHEN 'A' THEN 'Administrator' WHEN 'S' THEN 'System/Application User' WHEN 'G' THEN 'Generic User' ELSE '(Unknown)' END AS VARCHAR ( 50 ) CCSID 37 ) ) , 'userDept' VALUE JSON_OBJECT ( TRIM ( CAST ( EXDEPT AS VARCHAR ( 10 ) CCSID 37 ) ) VALUE TRIM ( CAST ( EUDESC AS VARCHAR ( 60 ) CCSID 37 ) ) ABSENT ON NULL ) , 'userEmpNo' VALUE TRIM ( CAST ( EXT08A AS VARCHAR ( 10 ) CCSID 37 ) ) , 'status' VALUE TRIM ( CAST ( CASE EXSTAT WHEN 'A' THEN 'Active' WHEN ' ' THEN 'Unknown' WHEN 'D' THEN 'Disabled' END AS VARCHAR ( 15 ) CCSID 37 ) ) , 'startMenu' VALUE TRIM ( CAST ( GUADMW AS VARCHAR ( 15 ) CCSID 37 ) ) , 'roles' VALUE JSON_ARRAY ( SELECT JSON_OBJECT ( TRIM ( CAST ( EUROLE AS VARCHAR ( 20 ) CCSID 37 ) ) VALUE TRIM ( CAST ( EUDESC AS VARCHAR ( 60 ) CCSID 37 ) ) ) FROM ESUSRP JOIN ESROLP USING ( EUROLE ) WHERE EUUSER = MZ . F0BUCD FORMAT JSON ) , 'isGroupId' VALUE CASE MZ . F0UGRP WHEN 1 THEN 'true' WHEN 0 THEN 'false' END FORMAT JSON ) ) , 'errors' : JSON_ARRAY ( ) ) FROM MZF0REP MZ JOIN ESUEXP LEFT JOIN ESDPTP ON EXDEPT = EUDEPT ON MZ . F0BUCD = EXUSER LEFT JOIN MZGUCPS0 ON GUBUCD = MZ . F0BUCD WHERE EXTYPE <> 'R' AND ( LOCATE ( UPPER ( TRIM ( IFNULL ( NAME_OR_ID , MZ . F0BUCD ) ) ) , UPPER ( MZ . F0BUCD ) ) > 0 OR LOCATE ( UPPER ( TRIM ( IFNULL ( NAME_OR_ID , MZ . F0BUCD ) ) ) , UPPER ( MZ . F0H1TX ) ) > 0 ) ) ; END ; GRANT ALTER , EXECUTE ON SPECIFIC FUNCTION SAILPOINT.V2_ESRTVMUSRI TO AMAPICS WITH GRANT OPTION ; GRANT EXECUTE ON SPECIFIC FUNCTION SAILPOINT.V2_ESRTVMUSRI TO PUBLIC ;