-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathpg_auth_mon--1.0--1.1.sql
36 lines (30 loc) · 1.25 KB
/
pg_auth_mon--1.0--1.1.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
/* contrib/pg_auth_mon/pg_auth_mon--1.0--1.1.sql */
/*
* Author: sdudoladov
* Created: Jul 27, 2021
*/
-- complain if script is sourced in psql, rather than via ALTER EXTENSION
\echo Use "CREATE EXTENSION pg_auth_mon UPDATE TO '1.1'" to load this file. \quit
-- re-create both the function and the view to add info about rolenames of deleted users
ALTER EXTENSION pg_auth_mon DROP VIEW pg_auth_mon;
ALTER EXTENSION pg_auth_mon DROP FUNCTION pg_auth_mon();
DROP VIEW IF EXISTS pg_auth_mon;
DROP FUNCTION IF EXISTS pg_auth_mon();
CREATE FUNCTION pg_auth_mon(
OUT uid oid,
OUT successful_attempts int,
OUT last_successful_TS timestampTz,
OUT total_hba_conflicts int,
OUT other_auth_failures int,
OUT last_failed_TS timestampTz,
OUT rolename_at_last_login_attempt name
)
RETURNS SETOF record
AS 'MODULE_PATHNAME', 'pg_auth_mon_1_1'
LANGUAGE C STRICT VOLATILE;
CREATE VIEW pg_auth_mon AS
SELECT
COALESCE(pg_roles.rolname, rolename_at_last_login_attempt) AS rolname,
(pg_roles.rolname IS NULL) AS deleted,
(CASE WHEN pg_roles.rolname IS NULL THEN 0 ELSE uid END) AS uid, successful_attempts, last_successful_TS, total_hba_conflicts, other_auth_failures, last_failed_TS
FROM pg_auth_mon() LEFT JOIN pg_roles ON oid = uid;