Re: Converting contrib SQL functions to new style - Mailing list pgsql-hackers
From | Vik Fearing |
---|---|
Subject | Re: Converting contrib SQL functions to new style |
Date | |
Msg-id | 5c2edf80-d1e3-cb9a-e5a8-41f3ad59515a@postgresfriends.org Whole thread Raw |
In response to | Re: Converting contrib SQL functions to new style (Mark Dilger <mark.dilger@enterprisedb.com>) |
Responses |
Re: Converting contrib SQL functions to new style
|
List | pgsql-hackers |
On 4/15/21 12:18 AM, Mark Dilger wrote: > > >> On Apr 14, 2021, at 2:47 PM, Vik Fearing <vik@postgresfriends.org> wrote: >> >> On 4/14/21 7:36 PM, Tom Lane wrote: >>> Mark Dilger <mark.dilger@enterprisedb.com> writes: >>>>> On Apr 13, 2021, at 3:26 PM, Tom Lane <tgl@sss.pgh.pa.us> wrote: >>>>> However I think we may still need an assumption that earthdistance >>>>> and cube are in the same schema --- any comments on that? >>> >>>> This is probably not worth doing, and we are already past feature >>>> freeze, but adding syntax to look up the namespace of an extension might >>>> help. >>> >>> Yeah, that idea was discussed before (perhaps only in private >>> security-team threads, though). We didn't do anything about it because >>> at the time there didn't seem to be pressing need, but in the context >>> of SQL function bodies there's an obvious use-case. >>> >>>> We could get something like this working just inside the CREATE EXTENSION command if we expanded on the @extschema@idea a bit. At first I thought this idea would suffer race conditions with concurrent modifications of pg_extensionor pg_namespace, but it looks like we already have a snapshot when processing the script file, so: >>> >>>> -CREATE DOMAIN earth AS cube >>>> +CREATE DOMAIN @@earthdistance@@::earth AS @@cube@@::cube >>> >>> Right, extending the @extschema@ mechanism is what was discussed, >>> though I think I'd lean towards something like @extschema:cube@ >>> to denote the schema of a referenced extension "cube". >>> >>> I'm not sure this is useful enough to break feature freeze for, >>> but I'm +1 for investigating it for v15. >> Just like we have a pseudo "$user" schema, could we have a pseudo >> "$extension" catalog? That should avoid changing grammar rules too much. >> >> CREATE TABLE unaccented_words ( >> word "$extension".citext.citext, >> CHECK (word = "$extension".unaccent.unaccent(word) >> ); > > Having a single variable $extension might help in many cases, but I don't see how to use it to handle the remaining cross-extensionreferences, such as earthdistance needing to reference cube. Sorry, I hadn't realized that was a real example so I made up my own. Basically my idea is to use the fully qualified catalog.schema.object syntax where the catalog is a special "$extension" value (meaning we would have to forbid that as an actual database name) and the schema is the name of the extension whose schema we want. The object is then just the object. CREATE DOMAIN earth AS "$extension".cube.cube CONSTRAINT not_point check("$extension".cube.cube_is_point(value)) CONSTRAINT not_3d check("$extension".cube.cube_dim(value <= 3) ...; CREATE FUNCTION earth_box(earth, float8) RETURNS "$extension".cube.cube LANGUAGE sql IMMUTABLE PARALLEL SAFE STRICT RETURN "$extension".cube.cube_enlarge($1, gc_to_sec($2), 3); If I had my druthers, we would spell it pg_extension instead of "$extension" because I hate double-quoting identifiers, but that's just bikeshedding and has little to do with the concept itself. -- Vik Fearing
pgsql-hackers by date: