mirror of
https://github.com/postgres/postgres.git
synced 2025-07-30 11:03:19 +03:00
Avoid use of CREATE OR REPLACE FUNCTION in extension installation files.
It was never terribly consistent to use OR REPLACE (because of the lack of comparable functionality for data types, operators, etc), and experimentation shows that it's now positively pernicious in the extension world. We really want a failure to occur if there are any conflicts, else it's unclear what the extension-ownership state of the conflicted object ought to be. Most of the time, CREATE EXTENSION will fail anyway because of conflicts on other object types, but an extension defining only functions can succeed, with bad results.
This commit is contained in:
@ -2,12 +2,12 @@
|
||||
|
||||
-- dblink_connect now restricts non-superusers to password
|
||||
-- authenticated connections
|
||||
CREATE OR REPLACE FUNCTION dblink_connect (text)
|
||||
CREATE FUNCTION dblink_connect (text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_connect'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_connect (text, text)
|
||||
CREATE FUNCTION dblink_connect (text, text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_connect'
|
||||
LANGUAGE C STRICT;
|
||||
@ -15,12 +15,12 @@ LANGUAGE C STRICT;
|
||||
-- dblink_connect_u allows non-superusers to use
|
||||
-- non-password authenticated connections, but initially
|
||||
-- privileges are revoked from public
|
||||
CREATE OR REPLACE FUNCTION dblink_connect_u (text)
|
||||
CREATE FUNCTION dblink_connect_u (text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_connect'
|
||||
LANGUAGE C STRICT SECURITY DEFINER;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_connect_u (text, text)
|
||||
CREATE FUNCTION dblink_connect_u (text, text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_connect'
|
||||
LANGUAGE C STRICT SECURITY DEFINER;
|
||||
@ -28,179 +28,179 @@ LANGUAGE C STRICT SECURITY DEFINER;
|
||||
REVOKE ALL ON FUNCTION dblink_connect_u (text) FROM public;
|
||||
REVOKE ALL ON FUNCTION dblink_connect_u (text, text) FROM public;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_disconnect ()
|
||||
CREATE FUNCTION dblink_disconnect ()
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_disconnect'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_disconnect (text)
|
||||
CREATE FUNCTION dblink_disconnect (text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_disconnect'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_open (text, text)
|
||||
CREATE FUNCTION dblink_open (text, text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_open'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_open (text, text, boolean)
|
||||
CREATE FUNCTION dblink_open (text, text, boolean)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_open'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_open (text, text, text)
|
||||
CREATE FUNCTION dblink_open (text, text, text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_open'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_open (text, text, text, boolean)
|
||||
CREATE FUNCTION dblink_open (text, text, text, boolean)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_open'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_fetch (text, int)
|
||||
CREATE FUNCTION dblink_fetch (text, int)
|
||||
RETURNS setof record
|
||||
AS 'MODULE_PATHNAME','dblink_fetch'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_fetch (text, int, boolean)
|
||||
CREATE FUNCTION dblink_fetch (text, int, boolean)
|
||||
RETURNS setof record
|
||||
AS 'MODULE_PATHNAME','dblink_fetch'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_fetch (text, text, int)
|
||||
CREATE FUNCTION dblink_fetch (text, text, int)
|
||||
RETURNS setof record
|
||||
AS 'MODULE_PATHNAME','dblink_fetch'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_fetch (text, text, int, boolean)
|
||||
CREATE FUNCTION dblink_fetch (text, text, int, boolean)
|
||||
RETURNS setof record
|
||||
AS 'MODULE_PATHNAME','dblink_fetch'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_close (text)
|
||||
CREATE FUNCTION dblink_close (text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_close'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_close (text, boolean)
|
||||
CREATE FUNCTION dblink_close (text, boolean)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_close'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_close (text, text)
|
||||
CREATE FUNCTION dblink_close (text, text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_close'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_close (text, text, boolean)
|
||||
CREATE FUNCTION dblink_close (text, text, boolean)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_close'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink (text, text)
|
||||
CREATE FUNCTION dblink (text, text)
|
||||
RETURNS setof record
|
||||
AS 'MODULE_PATHNAME','dblink_record'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink (text, text, boolean)
|
||||
CREATE FUNCTION dblink (text, text, boolean)
|
||||
RETURNS setof record
|
||||
AS 'MODULE_PATHNAME','dblink_record'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink (text)
|
||||
CREATE FUNCTION dblink (text)
|
||||
RETURNS setof record
|
||||
AS 'MODULE_PATHNAME','dblink_record'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink (text, boolean)
|
||||
CREATE FUNCTION dblink (text, boolean)
|
||||
RETURNS setof record
|
||||
AS 'MODULE_PATHNAME','dblink_record'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_exec (text, text)
|
||||
CREATE FUNCTION dblink_exec (text, text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_exec'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_exec (text, text, boolean)
|
||||
CREATE FUNCTION dblink_exec (text, text, boolean)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_exec'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_exec (text)
|
||||
CREATE FUNCTION dblink_exec (text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_exec'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_exec (text,boolean)
|
||||
CREATE FUNCTION dblink_exec (text,boolean)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_exec'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE TYPE dblink_pkey_results AS (position int, colname text);
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_get_pkey (text)
|
||||
CREATE FUNCTION dblink_get_pkey (text)
|
||||
RETURNS setof dblink_pkey_results
|
||||
AS 'MODULE_PATHNAME','dblink_get_pkey'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_build_sql_insert (text, int2vector, int, _text, _text)
|
||||
CREATE FUNCTION dblink_build_sql_insert (text, int2vector, int, _text, _text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_build_sql_insert'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_build_sql_delete (text, int2vector, int, _text)
|
||||
CREATE FUNCTION dblink_build_sql_delete (text, int2vector, int, _text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_build_sql_delete'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_build_sql_update (text, int2vector, int, _text, _text)
|
||||
CREATE FUNCTION dblink_build_sql_update (text, int2vector, int, _text, _text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_build_sql_update'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_current_query ()
|
||||
CREATE FUNCTION dblink_current_query ()
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME','dblink_current_query'
|
||||
LANGUAGE C;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_send_query(text, text)
|
||||
CREATE FUNCTION dblink_send_query(text, text)
|
||||
RETURNS int4
|
||||
AS 'MODULE_PATHNAME', 'dblink_send_query'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_is_busy(text)
|
||||
CREATE FUNCTION dblink_is_busy(text)
|
||||
RETURNS int4
|
||||
AS 'MODULE_PATHNAME', 'dblink_is_busy'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_get_result(text)
|
||||
CREATE FUNCTION dblink_get_result(text)
|
||||
RETURNS SETOF record
|
||||
AS 'MODULE_PATHNAME', 'dblink_get_result'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_get_result(text, bool)
|
||||
CREATE FUNCTION dblink_get_result(text, bool)
|
||||
RETURNS SETOF record
|
||||
AS 'MODULE_PATHNAME', 'dblink_get_result'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_get_connections()
|
||||
CREATE FUNCTION dblink_get_connections()
|
||||
RETURNS text[]
|
||||
AS 'MODULE_PATHNAME', 'dblink_get_connections'
|
||||
LANGUAGE C;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_cancel_query(text)
|
||||
CREATE FUNCTION dblink_cancel_query(text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME', 'dblink_cancel_query'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_error_message(text)
|
||||
CREATE FUNCTION dblink_error_message(text)
|
||||
RETURNS text
|
||||
AS 'MODULE_PATHNAME', 'dblink_error_message'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_get_notify(
|
||||
CREATE FUNCTION dblink_get_notify(
|
||||
OUT notify_name TEXT,
|
||||
OUT be_pid INT4,
|
||||
OUT extra TEXT
|
||||
@ -209,7 +209,7 @@ RETURNS setof record
|
||||
AS 'MODULE_PATHNAME', 'dblink_get_notify'
|
||||
LANGUAGE C STRICT;
|
||||
|
||||
CREATE OR REPLACE FUNCTION dblink_get_notify(
|
||||
CREATE FUNCTION dblink_get_notify(
|
||||
conname TEXT,
|
||||
OUT notify_name TEXT,
|
||||
OUT be_pid INT4,
|
||||
|
Reference in New Issue
Block a user