SET PATH *LIBL ; CREATE OR REPLACE FUNCTION SAILPOINT.ES_GET_ALL_MAPICS_ENVIRONMENTS ( ) RETURNS CLOB(2147483647) LANGUAGE SQL SPECIFIC SAILPOINT.ESALLENVS 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) , DYNDFTCOL = *NO , DYNUSRPRF = *OWNER , 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 ; RETURN COALESCE ( JSON_OBJECT ( 'success' : 'true' , 'data' VALUE ( SELECT JSON_ARRAYAGG ( JSON_OBJECT ( 'envId' VALUE ENVID , 'envDsc' VALUE ENDSC , 'esInstalled' VALUE ES_INSTALLED ) ) FROM TABLE ( SELECT ENVID , ENDSC , CASE WHEN FILECOUNT > 0 THEN 'true' ELSE 'false' END AS ES_INSTALLED FROM TABLE ( SELECT DISTINCT ENVID , ENDSC , COUNT ( CESLIB ) OVER ( PARTITION BY ENVID , ENDSC ) AS FILECOUNT FROM TABLE ( SELECT LIDES || FIDES AS ENVID , 'CESLIB' || CASE LIDES || FIDES WHEN 'MM' THEN '' ELSE FIDES END AS CESLIB , ENDSC FROM QGPL . MMLIST WHERE RCDCD = 'M3' AND ACREC = 'A' ) JOIN TABLE ( QSYS2 . OBJECT_STATISTICS ( CESLIB , '*FILE' ) ) ON 1 = 1 ) ) ) FORMAT JSON ) , 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.ESALLENVS TO AMAPICS WITH GRANT OPTION ; GRANT EXECUTE ON SPECIFIC FUNCTION SAILPOINT.ESALLENVS TO PUBLIC ;