]> granicus.if.org Git - postgresql/commit
Require execute permission on the trigger function for CREATE TRIGGER.
authorTom Lane <tgl@sss.pgh.pa.us>
Thu, 23 Feb 2012 20:38:56 +0000 (15:38 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Thu, 23 Feb 2012 20:38:56 +0000 (15:38 -0500)
commit891e6e7bfd9bb72687522af08c18689f795cb60a
tree712c343bd83a23e56bbfb7aa6ad16c002debbc23
parent74e29162a4f0ec0ad1c7224b8be936d1f9a51f7e
Require execute permission on the trigger function for CREATE TRIGGER.

This check was overlooked when we added function execute permissions to the
system years ago.  For an ordinary trigger function it's not a big deal,
since trigger functions execute with the permissions of the table owner,
so they couldn't do anything the user issuing the CREATE TRIGGER couldn't
have done anyway.  However, if a trigger function is SECURITY DEFINER,
that is not the case.  The lack of checking would allow another user to
install it on his own table and then invoke it with, essentially, forged
input data; which the trigger function is unlikely to realize, so it might
do something undesirable, for instance insert false entries in an audit log
table.

Reported by Dinesh Kumar, patch by Robert Haas

Security: CVE-2012-0866
doc/src/sgml/ref/create_trigger.sgml
src/backend/commands/trigger.c