Re: SQL-standard function bodies and creating SECURITY DEFINER routines securely

From: Noah Misch <noah(at)leadboat(dot)com>
To: Bruce Momjian <bruce(at)momjian(dot)us>
Cc: Erki Eessaar <erki(dot)eessaar(at)taltech(dot)ee>, "pgsql-docs(at)lists(dot)postgresql(dot)org" <pgsql-docs(at)lists(dot)postgresql(dot)org>, Peter Eisentraut <peter(dot)eisentraut(at)enterprisedb(dot)com>
Subject: Re: SQL-standard function bodies and creating SECURITY DEFINER routines securely
Date: 2022-10-09 13:21:43
Message-ID: 20221009132143.GA2391199@rfd.leadboat.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-docs

On Fri, Oct 07, 2022 at 09:35:49AM -0400, Bruce Momjian wrote:
> On Fri, Oct 7, 2022 at 08:05:36AM +0000, Erki Eessaar wrote:
> > I confirmed, that setting search_path is indeed sometimes needed in case of
> > SECURITY DEFINER routines that have SQL-standard bodies. See an example at the
> > end of the letter.
> >
> > I suggest the following paragraph to the documentation:
> >
> > Starting from PostgreSQL 14 SQL-standard bodies can be used in SQL-language
> > functions. This form tracks dependencies between the function and objects used
> > in the function body. However, there is still a possibility that such function
> > calls other code that reacts to search path. Thus, as a best practice, SECURITY
> > DEFINER functions with SQL-standard bodies should also override search_path.
>
> I think this gets back to what Noah said about this section not needing
> to explain all the details but rather give general guidance. I am not
> sure adding the reasons for _why_ you should use search path for
> SQL-standard bodies is really adding anything. Noah, is that accurate?

Yes, that's my thinking. It's hard to make objective decisions about how
deeply to cover each topic in the documentation. I'm content with the present
state of this particular section, though.

In response to

Browse pgsql-docs by date

  From Date Subject
Next Message PG Doc comments form 2022-10-10 03:16:54 regression tests require some file(s) to be installed first.
Previous Message Ben Koshy 2022-10-07 21:52:34 Re: Comparison Predicates - example - documentation seems contradictory?