Add a new option, -g, to createuser, to add membership in a role.
authorRobert Haas <rhaas@postgresql.org>
Wed, 11 Dec 2013 12:50:36 +0000 (07:50 -0500)
committerRobert Haas <rhaas@postgresql.org>
Wed, 11 Dec 2013 12:50:36 +0000 (07:50 -0500)
Chistopher Browne, reviewed by Sameer Thakur, Amit Kapila, and
Peter Eisentraut.

doc/src/sgml/ref/createuser.sgml
src/bin/scripts/createuser.c

index 2f1ea2fb73bb9fdd463cefcd965a40610fb13d8b..63d4c6c4a81b05d702fffc9e283e3f8c902103bb 100644 (file)
@@ -130,6 +130,19 @@ PostgreSQL documentation
       </listitem>
      </varlistentry>
 
+     <varlistentry>
+      <term><option>-g <replaceable class="parameter">role</replaceable></></term>
+      <term><option>--role=<replaceable class="parameter">role</replaceable></></term>
+      <listitem>
+       <para>
+         Indicates role to which this role will be added immediately as a new
+         member. Multiple roles to which this role will be added as a member
+         can be specified by writing multiple
+         <option>-g</> switches.
+         </para>
+      </listitem>
+     </varlistentry>
+
      <varlistentry>
       <term><option>-i</></term>
       <term><option>--inherit</></term>
index 83623ea87920f67a7c8d960cbe250abbe9d02ad9..61805917704a0e34fdf137483ff8f4a81ca58ab3 100644 (file)
@@ -24,6 +24,7 @@ main(int argc, char *argv[])
        {"host", required_argument, NULL, 'h'},
        {"port", required_argument, NULL, 'p'},
        {"username", required_argument, NULL, 'U'},
+       {"role", required_argument, NULL, 'g'},
        {"no-password", no_argument, NULL, 'w'},
        {"password", no_argument, NULL, 'W'},
        {"echo", no_argument, NULL, 'e'},
@@ -57,6 +58,7 @@ main(int argc, char *argv[])
    char       *host = NULL;
    char       *port = NULL;
    char       *username = NULL;
+   SimpleStringList roles = {NULL, NULL};
    enum trivalue prompt_password = TRI_DEFAULT;
    bool        echo = false;
    bool        interactive = false;
@@ -83,7 +85,7 @@ main(int argc, char *argv[])
 
    handle_help_version_opts(argc, argv, "createuser", help);
 
-   while ((c = getopt_long(argc, argv, "h:p:U:wWedDsSaArRiIlLc:PEN",
+   while ((c = getopt_long(argc, argv, "h:p:U:g:wWedDsSaArRiIlLc:PEN",
                            long_options, &optindex)) != -1)
    {
        switch (c)
@@ -97,6 +99,9 @@ main(int argc, char *argv[])
            case 'U':
                username = pg_strdup(optarg);
                break;
+           case 'g':
+               simple_string_list_append(&roles, optarg);
+               break;
            case 'w':
                prompt_password = TRI_NO;
                break;
@@ -302,6 +307,19 @@ main(int argc, char *argv[])
        appendPQExpBufferStr(&sql, " NOREPLICATION");
    if (conn_limit != NULL)
        appendPQExpBuffer(&sql, " CONNECTION LIMIT %s", conn_limit);
+   if (roles.head != NULL)
+   {
+       SimpleStringListCell *cell;
+       appendPQExpBufferStr(&sql, " IN ROLE ");
+
+       for (cell = roles.head; cell; cell = cell->next)
+       {
+           if (cell->next)
+               appendPQExpBuffer(&sql, "%s,", fmtId(cell->val));
+           else
+               appendPQExpBuffer(&sql, "%s", fmtId(cell->val));
+       }
+   }
    appendPQExpBufferStr(&sql, ";\n");
 
    if (echo)
@@ -334,6 +352,7 @@ help(const char *progname)
    printf(_("  -D, --no-createdb         role cannot create databases (default)\n"));
    printf(_("  -e, --echo                show the commands being sent to the server\n"));
    printf(_("  -E, --encrypted           encrypt stored password\n"));
+   printf(_("  -g, --role=ROLE           new role will be a member of this role\n"));
    printf(_("  -i, --inherit             role inherits privileges of roles it is a\n"
             "                            member of (default)\n"));
    printf(_("  -I, --no-inherit          role does not inherit privileges\n"));