#!/usr/bin/perl

# Copyright (C) 2007-2014 X2Go Project - http://wiki.x2go.org
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the
# Free Software Foundation, Inc.,
# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
#
# Copyright (C) 2007-2014 Oleksandr Shneyder <oleksandr.shneyder@obviously-nice.de>
# Copyright (C) 2007-2014 Heinz-Markus Graesing <heinz-m.graesing@obviously-nice.de>

use strict;
use Sys::Hostname;
use Sys::Syslog qw( :standard :macros );

use File::ReadBackwards;

use lib `x2gopath lib`;
use x2godbwrapper; 
use x2gologlevel;


openlog($0,'cons,pid','user');
setlogmask( LOG_UPTO(x2gologlevel()) );

if ( @ARGV ) {
	syslog('info', "x2golistsessions has been called with options: @ARGV");
} else {
	# hiding normal x2golistsessions calls into debug loglevel
	syslog('debug', "x2golistsessions has been called with no option");
}


sub is_suspended
{
	my $sess=shift;
	my $log="$ENV{'HOME'}/.x2go/C-${sess}.log";
	my $log_line;
	my $log_file = File::ReadBackwards->new( $log ) or return 0;
	while( defined( $log_line = $log_file->readline ) ) {
		next if ( ! ( $log_line =~ m/^Session:/ ) );
		last;
	}
	$log_file->close();
	if ($log_line =~ m/Session suspended/)
	{
		return 1;
	}
	return 0;
}


my $serv=shift;
if( ! $serv)
{
	$serv=hostname;
}

my @outp;
if($serv eq "--all-servers")
{
	@outp=db_listsessions_all();
}
else
{
	@outp=db_listsessions($serv);
}

for (my $i=0;$i<@outp;$i++)
{
	@outp[$i] =~ s/ //g;
	@outp[$i] =~ s/\*/ /g;
	my @sinfo=split('\\|',"@outp[$i]");
	if (@sinfo[4]eq 'F')
	{
		print "@outp[$i]\n";
	}
	else
	{ 
		if (@sinfo[4]eq 'R')
		{
			if(is_suspended(@sinfo[1]))
			{
				db_changestatus( 'S', @sinfo[1] );
				@outp[$i] =~ s/\|R\|/\|S\|/;
				system("x2goumount-session", "@sinfo[1]");
			}
		}
		print "@outp[$i]\n";
	}
}

# closing syslog 
closelog;
