Commit 09f08930 authored by Peter Eisentraut's avatar Peter Eisentraut

initdb: Change authentication defaults

Change the defaults for the pg_hba.conf generated by initdb to "peer"
for local (if supported, else "md5") and "md5" for host.

(Changing from "md5" to SCRAM is left as a separate exercise.)

"peer" is currently not supported on AIX, HP-UX, and Windows.  Users
on those operating systems will now either have to provide a password
to initdb or choose a different authentication method when running
initdb.
Reviewed-by: default avatarJulien Rouhaud <rjuju123@gmail.com>
Discussion: https://www.postgresql.org/message-id/flat/bec17f0a-ddb1-8b95-5e69-368d9d0a3390%40postgresql.org
parent 1e6a7598
...@@ -136,9 +136,24 @@ PostgreSQL documentation ...@@ -136,9 +136,24 @@ PostgreSQL documentation
replication connections. replication connections.
</para> </para>
<para>
The default is <literal>peer</literal> for Unix-domain socket
connections on operating systems that support it, otherwise
<literal>md5</literal>, and <literal>md5</literal> for TCP/IP
connections.
</para>
<para>
When running <command>initdb</command> on a platform that does not
support <literal>peer</literal> authentication, either a password must
be provided (see <option>-W</option> and other options) or a different
authentication method must be chosen, otherwise
<command>initdb</command> will error.
</para>
<para> <para>
Do not use <literal>trust</literal> unless you trust all local users on your Do not use <literal>trust</literal> unless you trust all local users on your
system. <literal>trust</literal> is the default for ease of installation. system.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
......
...@@ -156,24 +156,19 @@ postgres$ <userinput>initdb -D /usr/local/pgsql/data</userinput> ...@@ -156,24 +156,19 @@ postgres$ <userinput>initdb -D /usr/local/pgsql/data</userinput>
</para> </para>
<para> <para>
However, while the directory contents are secure, the default The default client authentication setup is such that users can connect over
client authentication setup allows any local user to connect to the the Unix-domain socket to the same database user name as their operating
database and even become the database superuser. If you do not system user names (on operating systems that support this, which are most
trust other local users, we recommend you use one of modern Unix-like systems, but not Windows) and otherwise with a password.
To assign a password to the initial database superuser, use one of
<command>initdb</command>'s <option>-W</option>, <option>--pwprompt</option> <command>initdb</command>'s <option>-W</option>, <option>--pwprompt</option>
or <option>--pwfile</option> options to assign a password to the or <option>--pwfile</option> options.<indexterm>
database superuser.<indexterm>
<primary>password</primary> <primary>password</primary>
<secondary>of the superuser</secondary> <secondary>of the superuser</secondary>
</indexterm> </indexterm>
Also, specify <option>-A md5</option> or This configuration is secure and sufficient to get started. Later, see
<option>-A password</option> so that the default <literal>trust</literal> authentication <xref linkend="client-authentication"/> for more information about setting
mode is not used; or modify the generated <filename>pg_hba.conf</filename> up client authentication.
file after running <command>initdb</command>, but
<emphasis>before</emphasis> you start the server for the first time. (Other
reasonable approaches include using <literal>peer</literal> authentication
or file system permissions to restrict connections. See <xref
linkend="client-authentication"/> for more information.)
</para> </para>
<para> <para>
......
...@@ -63,15 +63,6 @@ postgres$ <userinput>/usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data</useri ...@@ -63,15 +63,6 @@ postgres$ <userinput>/usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data</useri
</para> </para>
</step> </step>
<step>
<para>
At this point, if you did not use the <command>initdb</command> <literal>-A</literal>
option, you might want to modify <filename>pg_hba.conf</filename> to control
local access to the server before you start it. The default is to
trust all local users.
</para>
</step>
<step> <step>
<para> <para>
The previous <command>initdb</command> step should have told you how to The previous <command>initdb</command> step should have told you how to
......
...@@ -185,7 +185,6 @@ static const char *default_timezone = NULL; ...@@ -185,7 +185,6 @@ static const char *default_timezone = NULL;
"# allows any local user to connect as any PostgreSQL user, including\n" \ "# allows any local user to connect as any PostgreSQL user, including\n" \
"# the database superuser. If you do not trust all your local users,\n" \ "# the database superuser. If you do not trust all your local users,\n" \
"# use another authentication method.\n" "# use another authentication method.\n"
static bool authwarning = false;
/* /*
* Centralized knowledge of switches to pass to backend * Centralized knowledge of switches to pass to backend
...@@ -2391,16 +2390,6 @@ usage(const char *progname) ...@@ -2391,16 +2390,6 @@ usage(const char *progname)
printf(_("\nReport bugs to <pgsql-bugs@lists.postgresql.org>.\n")); printf(_("\nReport bugs to <pgsql-bugs@lists.postgresql.org>.\n"));
} }
static void
check_authmethod_unspecified(const char **authmethod)
{
if (*authmethod == NULL)
{
authwarning = true;
*authmethod = "trust";
}
}
static void static void
check_authmethod_valid(const char *authmethod, const char *const *valid_methods, const char *conntype) check_authmethod_valid(const char *authmethod, const char *const *valid_methods, const char *conntype)
{ {
...@@ -3248,8 +3237,16 @@ main(int argc, char *argv[]) ...@@ -3248,8 +3237,16 @@ main(int argc, char *argv[])
exit(1); exit(1);
} }
check_authmethod_unspecified(&authmethodlocal); if (authmethodlocal == NULL)
check_authmethod_unspecified(&authmethodhost); {
#ifdef HAVE_AUTH_PEER
authmethodlocal = "peer";
#else
authmethodlocal = "md5";
#endif
}
if (authmethodhost == NULL)
authmethodhost = "md5";
check_authmethod_valid(authmethodlocal, auth_methods_local, "local"); check_authmethod_valid(authmethodlocal, auth_methods_local, "local");
check_authmethod_valid(authmethodhost, auth_methods_host, "host"); check_authmethod_valid(authmethodhost, auth_methods_host, "host");
...@@ -3332,14 +3329,6 @@ main(int argc, char *argv[]) ...@@ -3332,14 +3329,6 @@ main(int argc, char *argv[])
else else
printf(_("\nSync to disk skipped.\nThe data directory might become corrupt if the operating system crashes.\n")); printf(_("\nSync to disk skipped.\nThe data directory might become corrupt if the operating system crashes.\n"));
if (authwarning)
{
printf("\n");
pg_log_warning("enabling \"trust\" authentication for local connections");
fprintf(stderr, _("You can change this by editing pg_hba.conf or using the option -A, or\n"
"--auth-local and --auth-host, the next time you run initdb.\n"));
}
/* /*
* Build up a shell command to tell the user how to start the server * Build up a shell command to tell the user how to start the server
*/ */
......
...@@ -361,6 +361,11 @@ extern int fls(int mask); ...@@ -361,6 +361,11 @@ extern int fls(int mask);
extern int getpeereid(int sock, uid_t *uid, gid_t *gid); extern int getpeereid(int sock, uid_t *uid, gid_t *gid);
#endif #endif
/* must match src/port/getpeereid.c */
#if defined(HAVE_GETPEEREID) || defined(SO_PEERCRED) || defined(LOCAL_PEERCRED) || defined(HAVE_GETPEERUCRED)
#define HAVE_AUTH_PEER 1
#endif
#ifndef HAVE_ISINF #ifndef HAVE_ISINF
extern int isinf(double x); extern int isinf(double x);
#else #else
......
...@@ -2302,7 +2302,7 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2302,7 +2302,7 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
/* initdb */ /* initdb */
header(_("initializing database system")); header(_("initializing database system"));
snprintf(buf, sizeof(buf), snprintf(buf, sizeof(buf),
"\"%s%sinitdb\" -D \"%s/data\" --no-clean --no-sync%s%s > \"%s/log/initdb.log\" 2>&1", "\"%s%sinitdb\" -D \"%s/data\" -A trust --no-clean --no-sync%s%s > \"%s/log/initdb.log\" 2>&1",
bindir ? bindir : "", bindir ? bindir : "",
bindir ? "/" : "", bindir ? "/" : "",
temp_instance, temp_instance,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment