aboutsummaryrefslogtreecommitdiffstats
path: root/databases/postgresql74-server/scripts
diff options
context:
space:
mode:
authorjfitz <jfitz@FreeBSD.org>1996-09-24 06:40:15 +0800
committerjfitz <jfitz@FreeBSD.org>1996-09-24 06:40:15 +0800
commit4d5246b270a1ddcd8403d3f85adccc7a8ecc92b8 (patch)
tree25b6a3179deae61aa77de1199c961eb1fdf447eb /databases/postgresql74-server/scripts
parent212dc87b45243cfeb5746ca50ce2ca741f66a3d0 (diff)
downloadfreebsd-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/createuser50
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 );
+}