| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 | <?phprequire_once 'inc/vars.inc.php';require_once 'inc/functions.inc.php';$default_autodiscover_config = $autodiscover_config;if(file_exists('inc/vars.local.inc.php')) {  include_once 'inc/vars.local.inc.php';}$configuration = array_merge($default_autodiscover_config, $autodiscover_config);// Redis$redis = new Redis();$redis->connect('redis-mailcow', 6379);error_reporting(0);$data = trim(file_get_contents("php://input"));// Desktop client needs IMAP, unless it's Outlook 2013 or higher on Windowsif (strpos($data, 'autodiscover/outlook/responseschema') !== false) { // desktop client  $configuration['autodiscoverType'] = 'imap';  if ($configuration['useEASforOutlook'] == 'yes' &&    // Office for macOS does not support EAS    strpos($_SERVER['HTTP_USER_AGENT'], 'Mac') === false &&    // Outlook 2013 (version 15) or higher    preg_match('/(Outlook|Office).+1[5-9]\./', $_SERVER['HTTP_USER_AGENT'])  ) {    $configuration['autodiscoverType'] = 'activesync';  }}$dsn = $database_type . ":host=" . $database_host . ";dbname=" . $database_name;$opt = [  PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,  PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,  PDO::ATTR_EMULATE_PREPARES   => false,];$pdo = new PDO($dsn, $database_user, $database_pass, $opt);$login_user = strtolower(trim($_SERVER['PHP_AUTH_USER']));$login_role = check_login($login_user, $_SERVER['PHP_AUTH_PW']);if (!isset($_SERVER['PHP_AUTH_USER']) OR $login_role !== "user") {  header('WWW-Authenticate: Basic realm=""');  header('HTTP/1.0 401 Unauthorized');  exit(0);}else {  if (isset($_SERVER['PHP_AUTH_USER']) && isset($_SERVER['PHP_AUTH_PW'])) {    if ($login_role === "user") {      header("Content-Type: application/xml");      echo '<?xml version="1.0" encoding="utf-8" ?>' . PHP_EOL;?><Autodiscover xmlns="http://schemas.microsoft.com/exchange/autodiscover/responseschema/2006"><?php      if(!$data) {        list($usec, $sec) = explode(' ', microtime());?>  <Response>    <Error Time="<?=date('H:i:s', $sec) . substr($usec, 0, strlen($usec) - 2);?>" Id="2477272013">      <ErrorCode>600</ErrorCode>      <Message>Invalid Request</Message>      <DebugData />    </Error>  </Response></Autodiscover><?php        exit(0);      }      try {        $discover = new SimpleXMLElement($data);        $email = $discover->Request->EMailAddress;      } catch (Exception $e) {        $email = $_SERVER['PHP_AUTH_USER'];      }      $username = trim($email);      try {        $stmt = $pdo->prepare("SELECT `name` FROM `mailbox` WHERE `username`= :username");        $stmt->execute(array(':username' => $username));        $MailboxData = $stmt->fetch(PDO::FETCH_ASSOC);      }      catch(PDOException $e) {        die("Failed to determine name from SQL");      }      if (!empty($MailboxData['name'])) {        $displayname = utf8_encode($MailboxData['name']);      }      else {        $displayname = $email;      }      if ($configuration['autodiscoverType'] == 'imap') {?>  <Response xmlns="http://schemas.microsoft.com/exchange/autodiscover/outlook/responseschema/2006a">    <User>      <DisplayName><?=$displayname;?></DisplayName>    </User>    <Account>      <AccountType>email</AccountType>      <Action>settings</Action>      <Protocol>        <Type>IMAP</Type>        <Server><?=$configuration['imap']['server'];?></Server>        <Port><?=$configuration['imap']['port'];?></Port>        <DomainRequired>off</DomainRequired>        <LoginName><?=$email;?></LoginName>        <SPA>off</SPA>        <SSL>on</SSL>        <AuthRequired>on</AuthRequired>      </Protocol>      <Protocol>        <Type>SMTP</Type>        <Server><?=$configuration['smtp']['server'];?></Server>        <Port><?=$configuration['smtp']['port'];?></Port>        <DomainRequired>off</DomainRequired>        <LoginName><?=$email;?></LoginName>        <SPA>off</SPA>        <SSL>on</SSL>        <AuthRequired>on</AuthRequired>        <UsePOPAuth>on</UsePOPAuth>        <SMTPLast>off</SMTPLast>      </Protocol>      <Protocol>        <Type>CalDAV</Type>        <Server>https://<?=$configuration['caldav']['server'];?><?php if ($configuration['caldav']['port'] != 443) echo ':'.$configuration['caldav']['port']; ?>/SOGo/dav/<?=$email;?>/Calendar</Server>        <DomainRequired>off</DomainRequired>        <LoginName><?=$email;?></LoginName>      </Protocol>      <Protocol>        <Type>CardDAV</Type>        <Server>https://<?=$configuration['carddav']['server'];?><?php if ($configuration['caldav']['port'] != 443) echo ':'.$configuration['carddav']['port']; ?>/SOGo/dav/<?=$email;?>/Contacts</Server>        <DomainRequired>off</DomainRequired>        <LoginName><?=$email;?></LoginName>      </Protocol>    </Account>  </Response><?php      }      else if ($configuration['autodiscoverType'] == 'activesync') {?>  <Response xmlns="http://schemas.microsoft.com/exchange/autodiscover/mobilesync/responseschema/2006">    <Culture>en:en</Culture>    <User>      <DisplayName><?=$displayname;?></DisplayName>      <EMailAddress><?=$email;?></EMailAddress>    </User>    <Action>      <Settings>        <Server>        <Type>MobileSync</Type>        <Url><?=$configuration['activesync']['url'];?></Url>        <Name><?=$configuration['activesync']['url'];?></Name>        </Server>      </Settings>    </Action>  </Response><?php      }?></Autodiscover><?php    }  }}?>
 |