X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Fvcard.php;h=b7555a9bccb9ce24d4632deec02417eee1a5acf8;hp=e6343006b2804e278a9a9cea0d44219db3cc6a68;hb=353d074afac6827c90f4bb03e846c5e453d3b5b1;hpb=5e9e90fd78a930cc74432034fad600d38ac50563 diff --git a/src/vcard.php b/src/vcard.php index e6343006..b7555a9b 100644 --- a/src/vcard.php +++ b/src/vcard.php @@ -3,48 +3,60 @@ /** * vcard.php * - * Copyright (c) 1999-2002 The SquirrelMail Project Team - * Licensed under the GNU GPL. For full terms see the file COPYING. - * * This file shows an attched vcard * - * $Id$ + * @copyright 1999-2018 The SquirrelMail Project Team + * @license http://opensource.org/licenses/gpl-license.php GNU Public License + * @version $Id$ + * @package squirrelmail */ -require_once('../src/validate.php'); -require_once('../functions/date.php'); -require_once('../functions/page_header.php'); -require_once('../functions/mime.php'); -require_once('../src/load_prefs.php'); +/** This is the vcard page */ +define('PAGE_NAME', 'vcard'); -$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0); +/** + * Include the SquirrelMail initialization file. + */ +require('../include/init.php'); + +/* SquirrelMail required files. */ + +/** imap functions depend on date functions */ +include_once(SM_PATH . 'functions/date.php'); +/** form functions */ +include_once(SM_PATH . 'functions/forms.php'); +/** mime decoding */ +include_once(SM_PATH . 'functions/mime.php'); +/** url parser */ +include_once(SM_PATH . 'functions/url_parser.php'); +/** imap functions used to retrieve vcard */ +include_once(SM_PATH . 'functions/imap_general.php'); +include_once(SM_PATH . 'functions/imap_messages.php'); + +/* globals */ + +sqgetGlobalVar('passed_id', $passed_id, SQ_GET, NULL, SQ_TYPE_BIGINT); +sqgetGlobalVar('mailbox', $mailbox, SQ_GET); +sqgetGlobalVar('ent_id', $ent_id, SQ_GET); +sqgetGlobalVar('startMessage', $startMessage, SQ_GET); +/* end globals */ + +global $imap_stream_options; // in case not defined in config +$imapConnection = sqimap_login($username, false, $imapServerAddress, $imapPort, 0, $imap_stream_options); sqimap_mailbox_select($imapConnection, $mailbox); +displayPageHeader($color); -displayPageHeader($color, 'None'); - -echo '
' . "\n" . - ''; +$msg_url = 'read_body.php?mailbox='.urlencode($mailbox). + '&startMessage='.urlencode($startMessage). + '&passed_id='.urlencode($passed_id); +$msg_url = set_url_var($msg_url, 'ent_id', 0); $message = sqimap_get_message($imapConnection, $passed_id, $mailbox); -$entity_vcard = getEntity($message,$passed_ent_id); +$entity_vcard = getEntity($message,$ent_id); -$vcard = mime_fetch_body ($imapConnection, $passed_id, $passed_ent_id); +$vcard = mime_fetch_body($imapConnection, $passed_id, $ent_id); $vcard = decodeBody($vcard, $entity_vcard->header->encoding); $vcard = explode ("\n",$vcard); foreach ($vcard as $l) { @@ -56,7 +68,7 @@ foreach ($vcard as $l) { if ($attr == 'quoted-printable') $v = quoted_printable_decode($v); else - $k .= ';' . $attr; + $k .= ';' . strtolower($attr); } $v = str_replace(';', "\n", $v); @@ -65,18 +77,25 @@ foreach ($vcard as $l) { if ($vcard_nice['version'] == '2.1') { // get firstname and lastname for sm addressbook - $vcard_nice["firstname"] = substr($vcard_nice["n"], - strpos($vcard_nice["n"], "\n") + 1, strlen($vcard_nice["n"])); - $vcard_nice["lastname"] = substr($vcard_nice["n"], 0, - strpos($vcard_nice["n"], "\n")); + $vcard_nice['firstname'] = substr($vcard_nice['n'], + strpos($vcard_nice['n'], "\n") + 1, strlen($vcard_nice['n'])); + $vcard_nice['lastname'] = substr($vcard_nice['n'], 0, + strpos($vcard_nice['n'], "\n")); + // workaround for Outlook, should be fixed in a better way, + // maybe in new 'vCard' class. + if (isset($vcard_nice['email;pref;internet'])) { + $vcard_nice['email;internet'] = $vcard_nice['email;pref;internet']; + } } else { - echo '\n"; + $oTemplate->assign('note', sprintf(_("vCard Version %s is not supported. Some information might not be converted correctly."), sm_encode_html_special_chars($vcard_nice['version']))); + $oTemplate->display('note.tpl'); + + $vcard_nice['firstname'] = ''; + $vcard_nice['lastname'] = ''; } foreach ($vcard_nice as $k => $v) { - $v = htmlspecialchars($v); + $v = sm_encode_html_special_chars($v); $v = trim($v); $vcard_safe[$k] = trim(nl2br($v)); } @@ -84,7 +103,7 @@ foreach ($vcard_nice as $k => $v) { $ShowValues = array( 'fn' => _("Name"), 'title' => _("Title"), - 'email;internet' => _("Email"), + 'email;internet' => _("E-mail"), 'url' => _("Web Page"), 'org' => _("Organization / Department"), 'adr' => _("Address"), @@ -94,111 +113,79 @@ $ShowValues = array( 'tel;fax' => _("Fax"), 'note' => _("Note")); -echo '
' . - '
' . - _("Viewing a Business Card") . " - "; -if (isset($where) && isset($what)) { - // from a search - echo '' . _("View message") . ''; -} else { - echo '' . _("View message") . ''; -} -echo '
vCard Version ' . $vcard_nice['version'] . - ' is not supported. Some information might not be converted ' . - "correctly.

' . - '' . "\n"; - -if (isset($vcard_safe['email;internet'])) { $vcard_safe['email;internet'] = '' . $vcard_safe['email;internet'] . - ''; +if (isset($vcard_safe['email;internet'])) { + $vcard_safe['email;internet'] = makeComposeLink('src/compose.php?send_to='.urlencode($vcard_safe['email;internet']), + $vcard_safe['email;internet']); } + if (isset($vcard_safe['url'])) { - $vcard_safe['url'] = '' . - $vcard_safe['url'] . ''; + $vcard_safe['url'] = '' . + $vcard_safe['url'] . ''; } +$vcard = array(); foreach ($ShowValues as $k => $v) { - if (isset($vcard_safe[$k]) && $vcard_safe[$k]) { - echo "\n"; + if (isset($vcard_safe[$k]) && $vcard_safe[$k]) { + $vcard[$v] = $vcard_safe[$k]; } } -echo '
$v:" . $vcard_safe[$k] . - "
' . - '
' . - '
' . - '' . - '' . - '' . - '' . - '
' . - '
' . - _("Add to Addressbook") . - '
' . - '
' . - '' . - '' . - '' . - '' . - '' . - '
Nickname:
Note Field Contains:' . - '' . - '
' . - '' . - '' . - '' . - '' . - '
' . - '
' . - '
' . - '' . - _("Download this as a file") . '' . - '
' . - - '' . - '
' . - '
' . - ''; - -?> + $opts[$vcard_nice['note']] = _("Note"); +} + +$oTemplate->assign('view_message_link', $msg_url); +$oTemplate->assign('download_link', $dl); +$oTemplate->assign('vcard', $vcard); + +$oTemplate->assign('nickname', $vcard_nice['firstname'].'-'.$vcard_safe['lastname']); +$oTemplate->assign('firstname', $vcard_safe['firstname']); +$oTemplate->assign('lastname', $vcard_safe['lastname']); +$oTemplate->assign('email', $email); +$oTemplate->assign('info', $opts); + +$oTemplate->display('vcard.tpl'); + +$oTemplate->display('footer.tpl');