#!/usr/bin/perl -w

# MySQL database initialisation script
# Copyright 2000, 2001, 2002 Jrme Marant <jerome@debian.org>
#

use Getopt::Std;
use DBI;

getopt('a:d:u:h:p:o:');

$adminpass = $opt_a;
$database = $opt_d;
$userpass = $opt_u;
$host = $opt_h;
$port = $opt_p;
$options = $opt_o;

usage() if (($adminpass eq "") || ($database eq ""));

my $dsn = "DBI:mysql:database=mysql";

if ($host eq "") {
    $host = 'localhost';
}

# Set the hostname
if ($host ne 'localhost') {
    $dsn .= ";host=$host";

    # Set the port in case of a TCP connection.
    if ($port eq '') {
	$port = "3306";
    }

    $dsn .= ";port=$port";
}

if ($options ne "") {
    $dsn .= ";$options";
}

my $clienthost = `hostname -f`;
chomp($clienthost);

# Connect to mysql
my $dbh = DBI->connect($dsn,
		       "root", $adminpass,
		       {'RaiseError' => 1});

# Create database
eval {$dbh->do("CREATE DATABASE $database")};

# Remove old priviledges if any
$dbh->do("DELETE FROM user WHERE user ='sympa'");
$dbh->do("DELETE FROM db WHERE user ='sympa'");

# Create user sympa
my $command="GRANT DELETE, INSERT, SELECT, UPDATE on $database.* TO sympa\@$host";
if ($userpass ne "") {
    $command .= " IDENTIFIED BY '$userpass'";
}
$dbh->do($command);

$dbh->do("FLUSH PRIVILEGES");

$dbh->disconnect();

# Connect to $database
$dsn =~ s/database=mysql/database=sympa/;

$dbh = DBI->connect($dsn,
		   "root", $adminpass,
		   {'RaiseError' => 1});

# Create tables
eval {$dbh->do("CREATE TABLE user_table (".
	       "email_user          	varchar (100) NOT NULL,".
	       "gecos_user          	varchar (150),".
	       "password_user		varchar (40),".
	       "cookie_delay_user	int,".
	       "lang_user		varchar (10),".
	       "PRIMARY KEY (email_user)".
	       ")")};

eval {$dbh->do("CREATE TABLE subscriber_table (".
	       "list_subscriber       	varchar (50) NOT NULL,".
	       "user_subscriber		varchar (100) NOT NULL,".
	       "date_subscriber		datetime NOT NULL,".
	       "update_subscriber	datetime,".
	       "visibility_subscriber	varchar (20),".
	       "reception_subscriber	varchar (20),".
	       "bounce_subscriber	varchar (30),".
	       "comment_subscriber      varchar (150),".
	       "PRIMARY KEY (list_subscriber, user_subscriber),".
	       "INDEX (user_subscriber,list_subscriber)".
	       ")")};

$dbh->disconnect();

sub usage {
    die "Usage: install-mysql-db.pl -a <adminpass> -d <database> [-u <userpass>] [-h <hostname>] [-p <port>]\n";
}

