2018-06-25 08:58:02 -05:00
|
|
|
{# ============= Fetch the list of functions based on given schema_names ============= #}
|
|
|
|
SELECT n.nspname schema_name,
|
|
|
|
p.proname func_name,
|
2018-08-27 04:30:56 -05:00
|
|
|
p.proargnames arg_names,
|
|
|
|
COALESCE(proallargtypes::regtype[], proargtypes::regtype[])::text[] arg_types,
|
|
|
|
p.proargmodes arg_modes,
|
|
|
|
prorettype::regtype::text return_type,
|
2018-06-25 08:58:02 -05:00
|
|
|
CASE WHEN p.prokind = 'a' THEN true ELSE false END is_aggregate,
|
|
|
|
CASE WHEN p.prokind = 'w' THEN true ELSE false END is_window,
|
2018-08-27 04:30:56 -05:00
|
|
|
p.proretset is_set_returning,
|
2020-10-01 02:23:45 -05:00
|
|
|
d.deptype = 'e' is_extension,
|
2021-03-11 23:47:25 -06:00
|
|
|
pg_catalog.pg_get_expr(proargdefaults, 0) AS arg_defaults
|
2018-06-25 08:58:02 -05:00
|
|
|
FROM pg_catalog.pg_proc p
|
|
|
|
INNER JOIN pg_catalog.pg_namespace n ON n.oid = p.pronamespace
|
2021-03-11 23:47:25 -06:00
|
|
|
LEFT JOIN pg_catalog.pg_depend d ON d.objid = p.oid and d.deptype = 'e'
|
2018-08-27 04:30:56 -05:00
|
|
|
WHERE p.prorettype::regtype != 'trigger'::regtype
|
|
|
|
AND n.nspname IN ({{schema_names}})
|
|
|
|
ORDER BY 1, 2
|