<?php
/**
 * EGroupware signatures for eM Client
 *
 * For Apache FCGI you need the following rewrite rule:
 *
 * 	RewriteEngine on
 * 	RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization},L]
 *
 * Otherwise authentication request will be send over and over again, as password is NOT available to PHP!
 *
 * @link http://www.egroupware.org
 * @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
 * @package api
 * @subpackage mail
 * @author Ralf Becker <rb-AT-egroupware.org>
 * @copyright (c) 2016 by Ralf Becker <rb-AT-egroupware.org>
 * @version $Id$
 */

use EGroupware\Api;

$GLOBALS['egw_info'] = array(
	'flags' => array(
		'noheader'  => True,
		'currentapp' => 'mail',
		'no_exception_handler' => 'basic_auth',	// we use a basic auth exception handler (sends exception message as basic auth realm)
		'autocreate_session_callback' => 'EGroupware\\Api\\Header\\Authenticate::autocreate_session_callback',
		// use same REALM as CalDAV/CardDAV eM Client already uses
		'auth_realm' => 'EGroupware CalDAV/CardDAV/GroupDAV server',	// cant use groupdav::REALM as autoloading and include path not yet setup!
	)
);
// if you move this file somewhere else, you need to adapt the path to the header!
$egw_dir = dirname(__DIR__);
include($egw_dir.'/header.inc.php');

header('Content-type: text/xml; charset=UTF-8');

$xml = new XMLWriter;
$xml->openMemory();
$xml->setIndent(true);
$xml->startDocument('1.0', 'UTF-8');
$xml->startElement('signatures');

foreach(Api\Mail\Account::search(true, false) as $acc_id => $account)
{
	foreach($account->identities($account, true, 'params') as $ident_id => $identity)
	{
		// dont write empty signatures
		if (strlen(trim(strip_tags($identity['ident_signature']))) < 10) continue;

		// check if we have an non-empty email address
		foreach(array($identity['ident_email'], $account->ident_email, $account->acc_imap_username,
			$GLOBALS['egw_info']['user']['account_email']) as $email)
		{
			if (strpos($email, '@')) break;
		}
		if (!strpos($email, '@')) continue;

		$xml->startElement('signature');
		$xml->writeAttribute('name', Api\Mail\Account::identity_name($identity+$account->params, true));
		$xml->writeAttribute('allow-edit', 'true');
		$xml->writeAttribute('overwrite', 'true');
		$xml->writeAttribute('targetMail', $email.' <mailto:'.$email.'>');
		$xml->writeCdata($identity['ident_signature']);
		$xml->endElement();
	}
}
$xml->endElement();
$xml->endDocument();

echo $xml->outputMemory();