diff options
author | jfitz <jfitz@FreeBSD.org> | 1996-09-24 06:40:15 +0800 |
---|---|---|
committer | jfitz <jfitz@FreeBSD.org> | 1996-09-24 06:40:15 +0800 |
commit | 4d5246b270a1ddcd8403d3f85adccc7a8ecc92b8 (patch) | |
tree | 25b6a3179deae61aa77de1199c961eb1fdf447eb /databases/postgresql74-server/scripts | |
parent | 212dc87b45243cfeb5746ca50ce2ca741f66a3d0 (diff) | |
download | freebsd-ports-gnome-4d5246b270a1ddcd8403d3f85adccc7a8ecc92b8.tar.gz freebsd-ports-gnome-4d5246b270a1ddcd8403d3f85adccc7a8ecc92b8.tar.zst freebsd-ports-gnome-4d5246b270a1ddcd8403d3f85adccc7a8ecc92b8.zip |
Import of Postgres95, a next-generation DMBS research prototype.
Reviewed by: jfitz@FreeBSD.ORG
Submitted by: Matthew Stein <matt@bdd.net>
Diffstat (limited to 'databases/postgresql74-server/scripts')
-rw-r--r-- | databases/postgresql74-server/scripts/createuser | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/databases/postgresql74-server/scripts/createuser b/databases/postgresql74-server/scripts/createuser new file mode 100644 index 000000000000..4c24a164fbd6 --- /dev/null +++ b/databases/postgresql74-server/scripts/createuser @@ -0,0 +1,50 @@ +#!/usr/bin/perl +# + +eval '(exit $?0)' && eval 'exec /usr/bin/perl -S $0 ${1+"$@"}' +& eval 'exec /usr/bin/perl -S $0 $argv:q' +if 0; + +if( $> ) { + print "\nYou must be root to run this step!\n\n"; + exit 1; +} + +if( getpwnam( "postgres" ) ) { + ( $null, $null, $pgUID ) = getpwnam( "postgres" ); +} else { + $pgUID = 70; + while( getpwuid( $pgUID ) ) { + $pgUID++; + } +} + +if( getgrnam( "postgres" ) ) { + ( $null, $null, $pgGID ) = getgrnam( "postgres" ); +} else { + $pgGID = 70; + while( getgrgid( $pgGID ) ) { + $pgGID++; + } + &append_file( "/etc/group", "postgres:*:$pgGID:" ); +} + +print "postgres user using uid $pgUID\n"; +print "postgres user using gid $pgGID\n"; + +system( "/usr/bin/chpass -a \"postgres:*:$pgUID:$pgGID::0:0:Postgres95 pseudo-user:$ENV{'PREFIX'}/postgres95:/bin/sh\"" ); + +sub append_file { + local($file,@list) = @_; + local($LOCK_EX) = 2; + local($LOCK_NB) = 4; + local($LOCK_UN) = 8; + + open(F, ">> $file") || die "$file: $!\n"; + while( ! flock( F, $LOCK_EX | $LOCK_NB ) ) { + exit 1; + } + print F join( "\n", @list) . "\n"; + close F; + flock( F, $LOCK_UN ); +} |