aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNoah Misch <noah@leadboat.com>2020-08-10 09:22:54 -0700
committerNoah Misch <noah@leadboat.com>2020-08-10 09:22:58 -0700
commitd4d0ec9e79af554410d840d98d4f5b8832d74229 (patch)
tree979a5e799e7de253dc9a4cdc4969ff4d316d9546
parent3ba96708470a2c55c018fcb9ba2cb0f4c51a6d55 (diff)
downloadpostgresql-d4d0ec9e79af554410d840d98d4f5b8832d74229.tar.gz
postgresql-d4d0ec9e79af554410d840d98d4f5b8832d74229.zip
Move connect.h from fe_utils to src/include/common.
Any libpq client can use the header. Clients include backend components postgres_fdw, dblink, and logical replication apply worker. Back-patch to v10, because another fix needs this. In released branches, just copy the header and keep the original.
-rw-r--r--src/include/common/connect.h28
1 files changed, 28 insertions, 0 deletions
diff --git a/src/include/common/connect.h b/src/include/common/connect.h
new file mode 100644
index 00000000000..2cc5d7dd251
--- /dev/null
+++ b/src/include/common/connect.h
@@ -0,0 +1,28 @@
+/*-------------------------------------------------------------------------
+ *
+ * Interfaces in support of FE/BE connections.
+ *
+ *
+ * Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
+ * Portions Copyright (c) 1994, Regents of the University of California
+ *
+ * src/include/common/connect.h
+ *
+ *-------------------------------------------------------------------------
+ */
+#ifndef CONNECT_H
+#define CONNECT_H
+
+/*
+ * This SQL statement installs an always-secure search path, so malicious
+ * users can't take control. CREATE of an unqualified name will fail, because
+ * this selects no creation schema. This does not demote pg_temp, so it is
+ * suitable where we control the entire FE/BE connection but not suitable in
+ * SECURITY DEFINER functions. This is portable to PostgreSQL 7.3, which
+ * introduced schemas. When connected to an older version from code that
+ * might work with the old server, skip this.
+ */
+#define ALWAYS_SECURE_SEARCH_PATH_SQL \
+ "SELECT pg_catalog.set_config('search_path', '', false);"
+
+#endif /* CONNECT_H */