Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
8ae0d476
Commit
8ae0d476
authored
Aug 14, 2005
by
Tom Lane
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update the createuser utility for the ROLEs world. Alvaro Herrera
parent
e36de181
Changes
2
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
243 additions
and
108 deletions
+243
-108
doc/src/sgml/ref/createuser.sgml
doc/src/sgml/ref/createuser.sgml
+124
-60
src/bin/scripts/createuser.c
src/bin/scripts/createuser.c
+119
-48
No files found.
doc/src/sgml/ref/createuser.sgml
View file @
8ae0d476
This diff is collapsed.
Click to expand it.
src/bin/scripts/createuser.c
View file @
8ae0d476
...
@@ -5,7 +5,7 @@
...
@@ -5,7 +5,7 @@
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
* Portions Copyright (c) 1994, Regents of the University of California
*
*
* $PostgreSQL: pgsql/src/bin/scripts/createuser.c,v 1.1
7 2005/06/21 04:02:3
3 tgl Exp $
* $PostgreSQL: pgsql/src/bin/scripts/createuser.c,v 1.1
8 2005/08/14 20:16:0
3 tgl Exp $
*
*
*-------------------------------------------------------------------------
*-------------------------------------------------------------------------
*/
*/
...
@@ -30,9 +30,18 @@ main(int argc, char *argv[])
...
@@ -30,9 +30,18 @@ main(int argc, char *argv[])
{
"quiet"
,
no_argument
,
NULL
,
'q'
},
{
"quiet"
,
no_argument
,
NULL
,
'q'
},
{
"createdb"
,
no_argument
,
NULL
,
'd'
},
{
"createdb"
,
no_argument
,
NULL
,
'd'
},
{
"no-createdb"
,
no_argument
,
NULL
,
'D'
},
{
"no-createdb"
,
no_argument
,
NULL
,
'D'
},
{
"superuser"
,
no_argument
,
NULL
,
's'
},
{
"no-superuser"
,
no_argument
,
NULL
,
'S'
},
{
"createrole"
,
no_argument
,
NULL
,
'r'
},
{
"no-createrole"
,
no_argument
,
NULL
,
'R'
},
{
"inherit"
,
no_argument
,
NULL
,
'i'
},
{
"no-inherit"
,
no_argument
,
NULL
,
'I'
},
{
"login"
,
no_argument
,
NULL
,
'l'
},
{
"no-login"
,
no_argument
,
NULL
,
'L'
},
/* adduser is obsolete, undocumented spelling of superuser */
{
"adduser"
,
no_argument
,
NULL
,
'a'
},
{
"adduser"
,
no_argument
,
NULL
,
'a'
},
{
"no-adduser"
,
no_argument
,
NULL
,
'A'
},
{
"no-adduser"
,
no_argument
,
NULL
,
'A'
},
{
"
sysid"
,
required_argument
,
NULL
,
'i
'
},
{
"
conn-limit"
,
required_argument
,
NULL
,
'c
'
},
{
"pwprompt"
,
no_argument
,
NULL
,
'P'
},
{
"pwprompt"
,
no_argument
,
NULL
,
'P'
},
{
"encrypted"
,
no_argument
,
NULL
,
'E'
},
{
"encrypted"
,
no_argument
,
NULL
,
'E'
},
{
"unencrypted"
,
no_argument
,
NULL
,
'N'
},
{
"unencrypted"
,
no_argument
,
NULL
,
'N'
},
...
@@ -51,8 +60,11 @@ main(int argc, char *argv[])
...
@@ -51,8 +60,11 @@ main(int argc, char *argv[])
bool
echo
=
false
;
bool
echo
=
false
;
bool
quiet
=
false
;
bool
quiet
=
false
;
int
createdb
=
0
;
int
createdb
=
0
;
int
adduser
=
0
;
int
superuser
=
0
;
char
*
sysid
=
NULL
;
int
createrole
=
0
;
int
inherit
=
0
;
int
login
=
0
;
char
*
conn_limit
=
NULL
;
bool
pwprompt
=
false
;
bool
pwprompt
=
false
;
int
encrypted
=
0
;
/* 0 uses server default */
int
encrypted
=
0
;
/* 0 uses server default */
char
*
newpassword
=
NULL
;
char
*
newpassword
=
NULL
;
...
@@ -67,7 +79,8 @@ main(int argc, char *argv[])
...
@@ -67,7 +79,8 @@ main(int argc, char *argv[])
handle_help_version_opts
(
argc
,
argv
,
"createuser"
,
help
);
handle_help_version_opts
(
argc
,
argv
,
"createuser"
,
help
);
while
((
c
=
getopt_long
(
argc
,
argv
,
"h:p:U:WeqaAdDi:PEN"
,
long_options
,
&
optindex
))
!=
-
1
)
while
((
c
=
getopt_long
(
argc
,
argv
,
"h:p:U:WeqdDsSaArRiIlLc:PEN"
,
long_options
,
&
optindex
))
!=
-
1
)
{
{
switch
(
c
)
switch
(
c
)
{
{
...
@@ -89,20 +102,40 @@ main(int argc, char *argv[])
...
@@ -89,20 +102,40 @@ main(int argc, char *argv[])
case
'q'
:
case
'q'
:
quiet
=
true
;
quiet
=
true
;
break
;
break
;
case
'a'
:
adduser
=
+
1
;
break
;
case
'A'
:
adduser
=
-
1
;
break
;
case
'd'
:
case
'd'
:
createdb
=
+
1
;
createdb
=
+
1
;
break
;
break
;
case
'D'
:
case
'D'
:
createdb
=
-
1
;
createdb
=
-
1
;
break
;
break
;
case
's'
:
case
'a'
:
superuser
=
+
1
;
break
;
case
'S'
:
case
'A'
:
superuser
=
-
1
;
break
;
case
'r'
:
createrole
=
+
1
;
break
;
case
'R'
:
createrole
=
-
1
;
break
;
case
'i'
:
case
'i'
:
sysid
=
optarg
;
inherit
=
+
1
;
break
;
case
'I'
:
inherit
=
-
1
;
break
;
case
'l'
:
login
=
+
1
;
break
;
case
'L'
:
login
=
-
1
;
break
;
case
'c'
:
conn_limit
=
optarg
;
break
;
break
;
case
'P'
:
case
'P'
:
pwprompt
=
true
;
pwprompt
=
true
;
...
@@ -133,26 +166,15 @@ main(int argc, char *argv[])
...
@@ -133,26 +166,15 @@ main(int argc, char *argv[])
exit
(
1
);
exit
(
1
);
}
}
if
(
sysid
)
{
char
*
endptr
;
if
(
strtol
(
sysid
,
&
endptr
,
10
)
<=
0
||
*
endptr
!=
'\0'
)
{
fprintf
(
stderr
,
_
(
"%s: user ID must be a positive number
\n
"
),
progname
);
exit
(
1
);
}
}
if
(
newuser
==
NULL
)
if
(
newuser
==
NULL
)
newuser
=
simple_prompt
(
"Enter name of
user
to add: "
,
128
,
true
);
newuser
=
simple_prompt
(
"Enter name of
role
to add: "
,
128
,
true
);
if
(
pwprompt
)
if
(
pwprompt
)
{
{
char
*
pw1
,
char
*
pw1
,
*
pw2
;
*
pw2
;
pw1
=
simple_prompt
(
"Enter password for new
user
: "
,
100
,
false
);
pw1
=
simple_prompt
(
"Enter password for new
role
: "
,
100
,
false
);
pw2
=
simple_prompt
(
"Enter it again: "
,
100
,
false
);
pw2
=
simple_prompt
(
"Enter it again: "
,
100
,
false
);
if
(
strcmp
(
pw1
,
pw2
)
!=
0
)
if
(
strcmp
(
pw1
,
pw2
)
!=
0
)
{
{
...
@@ -163,33 +185,61 @@ main(int argc, char *argv[])
...
@@ -163,33 +185,61 @@ main(int argc, char *argv[])
free
(
pw2
);
free
(
pw2
);
}
}
if
(
superuser
==
0
)
{
char
*
reply
;
reply
=
simple_prompt
(
"Shall the new role be a superuser? (y/n) "
,
1
,
true
);
if
(
check_yesno_response
(
reply
)
==
1
)
superuser
=
+
1
;
else
superuser
=
-
1
;
}
if
(
superuser
==
+
1
)
{
/* Not much point in trying to restrict a superuser */
createdb
=
+
1
;
createrole
=
+
1
;
}
if
(
createdb
==
0
)
if
(
createdb
==
0
)
{
{
char
*
reply
;
char
*
reply
;
reply
=
simple_prompt
(
"Shall the new
user
be allowed to create databases? (y/n) "
,
1
,
true
);
reply
=
simple_prompt
(
"Shall the new
role
be allowed to create databases? (y/n) "
,
1
,
true
);
if
(
check_yesno_response
(
reply
)
==
1
)
if
(
check_yesno_response
(
reply
)
==
1
)
createdb
=
+
1
;
createdb
=
+
1
;
else
else
createdb
=
-
1
;
createdb
=
-
1
;
}
}
if
(
adduser
==
0
)
if
(
createrole
==
0
)
{
{
char
*
reply
;
char
*
reply
;
reply
=
simple_prompt
(
"Shall the new
user be allowed to create more new user
s? (y/n) "
,
1
,
true
);
reply
=
simple_prompt
(
"Shall the new
role be allowed to create more new role
s? (y/n) "
,
1
,
true
);
if
(
check_yesno_response
(
reply
)
==
1
)
if
(
check_yesno_response
(
reply
)
==
1
)
adduser
=
+
1
;
createrole
=
+
1
;
else
else
adduser
=
-
1
;
createrole
=
-
1
;
}
if
(
inherit
==
0
)
{
/* silently default to YES */
inherit
=
+
1
;
}
if
(
login
==
0
)
{
/* silently default to YES */
login
=
+
1
;
}
}
initPQExpBuffer
(
&
sql
);
initPQExpBuffer
(
&
sql
);
printfPQExpBuffer
(
&
sql
,
"CREATE USER %s"
,
fmtId
(
newuser
));
printfPQExpBuffer
(
&
sql
,
"CREATE ROLE %s"
,
fmtId
(
newuser
));
if
(
sysid
)
appendPQExpBuffer
(
&
sql
,
" SYSID %s"
,
sysid
);
if
(
newpassword
)
if
(
newpassword
)
{
{
if
(
encrypted
==
+
1
)
if
(
encrypted
==
+
1
)
...
@@ -199,14 +249,28 @@ main(int argc, char *argv[])
...
@@ -199,14 +249,28 @@ main(int argc, char *argv[])
appendPQExpBuffer
(
&
sql
,
" PASSWORD "
);
appendPQExpBuffer
(
&
sql
,
" PASSWORD "
);
appendStringLiteral
(
&
sql
,
newpassword
,
false
);
appendStringLiteral
(
&
sql
,
newpassword
,
false
);
}
}
if
(
superuser
==
+
1
)
appendPQExpBuffer
(
&
sql
,
" SUPERUSER"
);
if
(
superuser
==
-
1
)
appendPQExpBuffer
(
&
sql
,
" NOSUPERUSER"
);
if
(
createdb
==
+
1
)
if
(
createdb
==
+
1
)
appendPQExpBuffer
(
&
sql
,
" CREATEDB"
);
appendPQExpBuffer
(
&
sql
,
" CREATEDB"
);
if
(
createdb
==
-
1
)
if
(
createdb
==
-
1
)
appendPQExpBuffer
(
&
sql
,
" NOCREATEDB"
);
appendPQExpBuffer
(
&
sql
,
" NOCREATEDB"
);
if
(
adduser
==
+
1
)
if
(
createrole
==
+
1
)
appendPQExpBuffer
(
&
sql
,
" CREATEUSER"
);
appendPQExpBuffer
(
&
sql
,
" CREATEROLE"
);
if
(
adduser
==
-
1
)
if
(
createrole
==
-
1
)
appendPQExpBuffer
(
&
sql
,
" NOCREATEUSER"
);
appendPQExpBuffer
(
&
sql
,
" NOCREATEROLE"
);
if
(
inherit
==
+
1
)
appendPQExpBuffer
(
&
sql
,
" INHERIT"
);
if
(
inherit
==
-
1
)
appendPQExpBuffer
(
&
sql
,
" NOINHERIT"
);
if
(
login
==
+
1
)
appendPQExpBuffer
(
&
sql
,
" LOGIN"
);
if
(
login
==
-
1
)
appendPQExpBuffer
(
&
sql
,
" NOLOGIN"
);
if
(
conn_limit
!=
NULL
)
appendPQExpBuffer
(
&
sql
,
" CONNECTION LIMIT %s"
,
conn_limit
);
appendPQExpBuffer
(
&
sql
,
";
\n
"
);
appendPQExpBuffer
(
&
sql
,
";
\n
"
);
conn
=
connectDatabase
(
"postgres"
,
host
,
port
,
username
,
password
,
progname
);
conn
=
connectDatabase
(
"postgres"
,
host
,
port
,
username
,
password
,
progname
);
...
@@ -217,7 +281,7 @@ main(int argc, char *argv[])
...
@@ -217,7 +281,7 @@ main(int argc, char *argv[])
if
(
PQresultStatus
(
result
)
!=
PGRES_COMMAND_OK
)
if
(
PQresultStatus
(
result
)
!=
PGRES_COMMAND_OK
)
{
{
fprintf
(
stderr
,
_
(
"%s: creation of new
user
failed: %s"
),
fprintf
(
stderr
,
_
(
"%s: creation of new
role
failed: %s"
),
progname
,
PQerrorMessage
(
conn
));
progname
,
PQerrorMessage
(
conn
));
PQfinish
(
conn
);
PQfinish
(
conn
);
exit
(
1
);
exit
(
1
);
...
@@ -226,7 +290,7 @@ main(int argc, char *argv[])
...
@@ -226,7 +290,7 @@ main(int argc, char *argv[])
PQfinish
(
conn
);
PQfinish
(
conn
);
if
(
!
quiet
)
if
(
!
quiet
)
{
{
puts
(
"CREATE
USER
"
);
puts
(
"CREATE
ROLE
"
);
fflush
(
stdout
);
fflush
(
stdout
);
}
}
exit
(
0
);
exit
(
0
);
...
@@ -236,18 +300,25 @@ main(int argc, char *argv[])
...
@@ -236,18 +300,25 @@ main(int argc, char *argv[])
static
void
static
void
help
(
const
char
*
progname
)
help
(
const
char
*
progname
)
{
{
printf
(
_
(
"%s creates a new PostgreSQL
user
.
\n\n
"
),
progname
);
printf
(
_
(
"%s creates a new PostgreSQL
role
.
\n\n
"
),
progname
);
printf
(
_
(
"Usage:
\n
"
));
printf
(
_
(
"Usage:
\n
"
));
printf
(
_
(
" %s [OPTION]... [USERNAME]
\n
"
),
progname
);
printf
(
_
(
" %s [OPTION]... [USERNAME]
\n
"
),
progname
);
printf
(
_
(
"
\n
Options:
\n
"
));
printf
(
_
(
"
\n
Options:
\n
"
));
printf
(
_
(
" -a, --adduser user can add new users
\n
"
));
printf
(
_
(
" -s, --superuser role will be superuser
\n
"
));
printf
(
_
(
" -A, --no-adduser user cannot add new users
\n
"
));
printf
(
_
(
" -S, --no-superuser role will not be superuser
\n
"
));
printf
(
_
(
" -d, --createdb user can create new databases
\n
"
));
printf
(
_
(
" -d, --createdb role can create new databases
\n
"
));
printf
(
_
(
" -D, --no-createdb user cannot create databases
\n
"
));
printf
(
_
(
" -D, --no-createdb role cannot create databases
\n
"
));
printf
(
_
(
" -P, --pwprompt assign a password to new user
\n
"
));
printf
(
_
(
" -r, --createrole role can create new roles
\n
"
));
printf
(
_
(
" -R, --no-createrole role cannot create roles
\n
"
));
printf
(
_
(
" -l, --login role can login (default)
\n
"
));
printf
(
_
(
" -L, --no-login role cannot login
\n
"
));
printf
(
_
(
" -i, --inherit role inherits permissions of roles
\n
"
));
printf
(
_
(
" it is a member of (default)
\n
"
));
printf
(
_
(
" -I, --no-inherit role does not inherit permissions
\n
"
));
printf
(
_
(
" -c, --conn-limit=N max connections for role (default: no limit)
\n
"
));
printf
(
_
(
" -P, --pwprompt assign a password to new role
\n
"
));
printf
(
_
(
" -E, --encrypted encrypt stored password
\n
"
));
printf
(
_
(
" -E, --encrypted encrypt stored password
\n
"
));
printf
(
_
(
" -N, --unencrypted do not encrypt stored password
\n
"
));
printf
(
_
(
" -N, --unencrypted do not encrypt stored password
\n
"
));
printf
(
_
(
" -i, --sysid=SYSID select sysid for new user
\n
"
));
printf
(
_
(
" -e, --echo show the commands being sent to the server
\n
"
));
printf
(
_
(
" -e, --echo show the commands being sent to the server
\n
"
));
printf
(
_
(
" -q, --quiet don't write any messages
\n
"
));
printf
(
_
(
" -q, --quiet don't write any messages
\n
"
));
printf
(
_
(
" --help show this help, then exit
\n
"
));
printf
(
_
(
" --help show this help, then exit
\n
"
));
...
@@ -257,7 +328,7 @@ help(const char *progname)
...
@@ -257,7 +328,7 @@ help(const char *progname)
printf
(
_
(
" -p, --port=PORT database server port
\n
"
));
printf
(
_
(
" -p, --port=PORT database server port
\n
"
));
printf
(
_
(
" -U, --username=USERNAME user name to connect as (not the one to create)
\n
"
));
printf
(
_
(
" -U, --username=USERNAME user name to connect as (not the one to create)
\n
"
));
printf
(
_
(
" -W, --password prompt for password to connect
\n
"
));
printf
(
_
(
" -W, --password prompt for password to connect
\n
"
));
printf
(
_
(
"
\n
If one of -
a, -A, -d, -D, and USERNAME is not specified, you will
\n
"
printf
(
_
(
"
\n
If one of -
s, -S, -d, -D, -r, -R and USERNAME is not specified,
\n
"
"be prompted interactively.
\n
"
));
"
you will
be prompted interactively.
\n
"
));
printf
(
_
(
"
\n
Report bugs to <pgsql-bugs@postgresql.org>.
\n
"
));
printf
(
_
(
"
\n
Report bugs to <pgsql-bugs@postgresql.org>.
\n
"
));
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment