pg_tle--1.0.4--1.1.1.sql (159 lines of code) (raw):
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
-- complain if script is sourced in psql, rather than via CREATE EXTENSION
\echo Use "CREATE EXTENSION pg_tle" to load this file. \quit
CREATE FUNCTION pgtle.create_shell_type
(
typenamespace regnamespace,
typename name
)
RETURNS void
SET search_path TO 'pgtle'
STRICT
AS 'MODULE_PATHNAME', 'pg_tle_create_shell_type'
LANGUAGE C;
CREATE FUNCTION pgtle.create_shell_type_if_not_exists
(
typenamespace regnamespace,
typename name
)
RETURNS boolean
SET search_path TO 'pgtle'
STRICT
AS 'MODULE_PATHNAME', 'pg_tle_create_shell_type_if_not_exists'
LANGUAGE C;
CREATE FUNCTION pgtle.create_base_type
(
typenamespace regnamespace,
typename name,
infunc regprocedure,
outfunc regprocedure,
internallength int4
)
RETURNS void
SET search_path TO 'pgtle'
STRICT
AS 'MODULE_PATHNAME', 'pg_tle_create_base_type'
LANGUAGE C;
CREATE FUNCTION pgtle.create_base_type_if_not_exists
(
typenamespace regnamespace,
typename name,
infunc regprocedure,
outfunc regprocedure,
internallength int4
)
RETURNS boolean
SET search_path TO 'pgtle'
AS $_pgtleie_$
BEGIN
PERFORM pgtle.create_base_type(typenamespace, typename, infunc, outfunc, internallength);
RETURN TRUE;
EXCEPTION
-- only catch the duplicate_object exception, let all other exceptions pass through.
WHEN duplicate_object THEN
RETURN FALSE;
END;
$_pgtleie_$
LANGUAGE plpgsql STRICT;
CREATE FUNCTION pgtle.create_operator_func
(
typenamespace regnamespace,
typename name,
opfunc regprocedure
)
RETURNS void
SET search_path TO 'pgtle'
STRICT
AS 'MODULE_PATHNAME', 'pg_tle_create_operator_func'
LANGUAGE C;
CREATE FUNCTION pgtle.create_operator_func_if_not_exists
(
typenamespace regnamespace,
typename name,
opfunc regprocedure
)
RETURNS boolean
SET search_path TO 'pgtle'
AS $_pgtleie_$
BEGIN
PERFORM pgtle.create_operator_func(typenamespace, typename, opfunc);
RETURN TRUE;
EXCEPTION
-- only catch the duplicate_object exception, let all other exceptions pass through.
WHEN duplicate_object THEN
RETURN FALSE;
END;
$_pgtleie_$
LANGUAGE plpgsql STRICT;
REVOKE EXECUTE ON FUNCTION pgtle.create_shell_type
(
typenamespace regnamespace,
typename name
) FROM PUBLIC;
REVOKE EXECUTE ON FUNCTION pgtle.create_shell_type_if_not_exists
(
typenamespace regnamespace,
typename name
) FROM PUBLIC;
REVOKE EXECUTE ON FUNCTION pgtle.create_base_type
(
typenamespace regnamespace,
typename name,
infunc regprocedure,
outfunc regprocedure,
internallength int4
) FROM PUBLIC;
REVOKE EXECUTE ON FUNCTION pgtle.create_base_type_if_not_exists
(
typenamespace regnamespace,
typename name,
infunc regprocedure,
outfunc regprocedure,
internallength int4
) FROM PUBLIC;
REVOKE EXECUTE ON FUNCTION pgtle.create_operator_func
(
typenamespace regnamespace,
typename name,
opfunc regprocedure
) FROM PUBLIC;
REVOKE EXECUTE ON FUNCTION pgtle.create_operator_func_if_not_exists
(
typenamespace regnamespace,
typename name,
opfunc regprocedure
) FROM PUBLIC;
GRANT EXECUTE ON FUNCTION pgtle.create_shell_type
(
typenamespace regnamespace,
typename name
) TO pgtle_admin;
GRANT EXECUTE ON FUNCTION pgtle.create_shell_type_if_not_exists
(
typenamespace regnamespace,
typename name
) TO pgtle_admin;
GRANT EXECUTE ON FUNCTION pgtle.create_base_type
(
typenamespace regnamespace,
typename name,
infunc regprocedure,
outfunc regprocedure,
internallength int4
) TO pgtle_admin;
GRANT EXECUTE ON FUNCTION pgtle.create_base_type_if_not_exists
(
typenamespace regnamespace,
typename name,
infunc regprocedure,
outfunc regprocedure,
internallength int4
) TO pgtle_admin;
GRANT EXECUTE ON FUNCTION pgtle.create_operator_func
(
typenamespace regnamespace,
typename name,
opfunc regprocedure
) TO pgtle_admin;
GRANT EXECUTE ON FUNCTION pgtle.create_operator_func_if_not_exists
(
typenamespace regnamespace,
typename name,
opfunc regprocedure
) TO pgtle_admin;