# Version: MPL 1.1/GPL 2.0/LGPL 2.1
#
# The contents of this file are subject to the Mozilla Public License Version
# 1.1 (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
# http://www.mozilla.org/MPL/
#
# Software distributed under the License is distributed on an "AS IS" basis,
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
# for the specific language governing rights and limitations under the
# License.
#
# The Original Code is The Tinderbox Client.
#
# The Initial Developer of the Original Code is
# Zach Lipton.
# Portions created by the Initial Developer are Copyright (C) 2001
# the Initial Developer. All Rights Reserved.
#
# Contributor(s): Zach Lipton <zach@zachlipton.com>
#
# Alternatively, the contents of this file may be used under the terms of
# either the GNU General Public License Version 2 or later (the "GPL"), or
# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
# in which case the provisions of the GPL or the LGPL are applicable instead
# of those above. If you wish to allow use of your version of this file only
# under the terms of either the GPL or the LGPL, and not to allow others to
# use your version of this file under the terms of the MPL, indicate your
# decision by deleting the provisions above and replace them with the notice
# and other provisions required by the GPL or the LGPL. If you do not delete
# the provisions above, a recipient may use your version of this file under
# the terms of any one of the MPL, the GPL or the LGPL.

# This script developed August 2001 for Abisource and perl.

# Portions by Jaen Saul.

package Tindermail;
use Exporter;
@ISA =  qw(Exporter);
@EXPORT = qw (sendstartmail sendendmail);

use Tinderconfig;

use Net::SMTP;

### Configuration ###
$smtp_server = 'mail.hot.ee';
$send_address = 'tinderbox-client@zachlipton.com';
$build_family = 'win';
$error_parser = 'unix';
###

sub getsmtp {
        do {
	        print("Trying to connect to SMTP server...\n");
	        $smtp = Net::SMTP->new($smtp_server, Timeout => 60);
	        
	        if(!$smtp) { 
	        	print("Failed to connect\n"); sleep(60); 
	        } else {
	        	print("Connected\n"); 
	        }
        } while (!$smtp);
       
        return $smtp;
}

sub sendstartmail { # to send the start email.
        $time = time();

        $smtp = getsmtp();


        $smtp->mail($send_address);
        $smtp->to($Tinderconfig::serveraddress);

        $smtp->data();

        $smtp->datasend("From: ".$send_address."\n");
        $smtp->datasend("To: ".$Tinderconfig::serveraddress."\n");
        $smtp->datasend("Subject: Tinderbox\n\n");

        $smtp->datasend("tinderbox: tree: $Tinderconfig::tinderboxpage\n");
        $smtp->datasend('tinderbox: builddate: '.$time."\n");
        $smtp->datasend("tinderbox: status: building\n");
        $smtp->datasend("tinderbox: build: $Tinderconfig::boxname\n");
        $smtp->datasend("tinderbox: errorparser: $error_parser\n");
        $smtp->datasend("tinderbox: buildfamily: $build_family\n"); 
        $smtp->datasend("tinderbox: START\n");

        $smtp->dataend(); # my work here is done.

		$smtp->quit();
}

sub sendendmail($$) {
        ($log, $state) = @_; # state is pass, fail, testfailed

        $smtp = getsmtp();

        $smtp->mail($send_address);
        $smtp->to($Tinderconfig::serveraddress);

        $smtp->data();

        $smtp->datasend("From: ".$send_address."\n");
        $smtp->datasend("To: ".$Tinderconfig::serveraddress."\n");
        $smtp->datasend("Subject: Tinderbox\n\n");

        $smtp->datasend("tinderbox: tree: $Tinderconfig::tinderboxpage\n");
        $smtp->datasend('tinderbox: builddate: '.$time."\n");
        if ($state eq "pass") {
                $status = "success";
        } elsif ($state eq "fail") {
                $status = "busted";
        } elsif ($state eq "testfailed") {
                $status = "testfailed";
        } else {
                $status = "success"; # something nuts happend
        }
        $smtp->datasend("tinderbox: status: $status\n");

        $smtp->datasend("tinderbox: build: $Tinderconfig::boxname\n");
        $smtp->datasend("tinderbox: errorparser: $error_parser\n");
        $smtp->datasend("tinderbox: buildfamily: $build_family\n"); 
        $smtp->datasend("tinderbox: END\n\n");
        $smtp->datasend($log); # output our build log

        $smtp->dataend(); # my work here is done.

		$smtp->quit();
}

1;
