#!/usr/bin/perl
# ************************************************************************* 
# Copyright (c) 2014-2015, SUSE LLC
# 
# All rights reserved.
# 
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
# 
# 1. Redistributions of source code must retain the above copyright notice,
# this list of conditions and the following disclaimer.
# 
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
# 
# 3. Neither the name of SUSE LLC nor the names of its contributors may be
# used to endorse or promote products derived from this software without
# specific prior written permission.
# 
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
# ************************************************************************* 
#
# - initialize a pristine Dochazka database

use 5.012;
use strict;
use warnings;

#use App::CELL::Test::LogToFile;
use App::CELL qw( $CELL $site $log );
use App::Dochazka::REST;
use Try::Tiny;
use Web::MREST;
use Web::MREST::CLI qw( normalize_filespec );

my $app_distro = 'App-Dochazka-REST';
my $sitedir = '/etc/dochazka-rest';
print "Loading configuration parameters from $sitedir\n";
my $status = Web::MREST::init(
    distro => $app_distro,
    sitedir => $sitedir,
);
die $status->text unless $status->ok;

print "Setting up logging\n";
my $log_file = normalize_filespec( $site->MREST_LOG_FILE );
my $should_reset = $site->MREST_LOG_FILE_RESET;
unlink $log_file if $should_reset;
Log::Any::Adapter->set( 'File', $log_file );
my $message = "Logging to $log_file";
print "$message\n";
$log->info( $message );
if ( ! $site->MREST_APPNAME ) {
    die "Site parameter MREST_APPNAME is undefined - please investigate!";
}
$log->init(
    ident => $site->MREST_APPNAME,
    debug_mode => ( $site->MREST_DEBUG_MODE || 0 ),
);

$status = App::Dochazka::REST::reset_db();
if ( $status->not_ok ) {
    die "PostgreSQL server is unreachable";
}

print "Dochazka database initialized\n";
