X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Fvcard.php;h=b8ccb239090ebef7fdff5399426b70806bc2f7fa;hp=bf9d46f1c499df8a1268b6eb89205660264443e9;hb=e506b6e54f09ec71062b55bf3d72c9db57c89f05;hpb=fab3baa6746c2a20c9477b38dfd7f3e4aeeeeef7 diff --git a/src/vcard.php b/src/vcard.php index bf9d46f1..b8ccb239 100644 --- a/src/vcard.php +++ b/src/vcard.php @@ -3,49 +3,59 @@ /** * 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-2009 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 */ + +$imapConnection = sqimap_login($username, false, $imapServerAddress, $imapPort, 0); sqimap_mailbox_select($imapConnection, $mailbox); +displayPageHeader($color); -displayPageHeader($color, 'None'); - -echo '
' . - html_tag( 'table', '', 'center', '', 'width="100%" border="0" cellspacing="0" cellpadding="2"' ) ."\n" . - html_tag( 'tr' ) . "\n" . - html_tag( 'td', '', 'left', $color[0] ) . - '
' . - _("Viewing a Business Card") . ' - '; -if (isset($where) && isset($what)) { - // from a search - echo '' . _("View message") . ''; -} else { - echo '' . _("View message") . ''; -} -echo '
'; +$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) { @@ -57,7 +67,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); @@ -66,17 +76,21 @@ 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 html_tag( 'tr', - html_tag( 'td', 'vCard Version ' . $vcard_nice['version'] . - ' is not supported. Some information might not be converted ' . - 'correctly.' , - 'center' ) - ) . "\n"; + $oTemplate->assign('note', sprintf(_("vCard Version %s is not supported. Some information might not be converted correctly."), htmlspecialchars($vcard_nice['version']))); + $oTemplate->display('note.tpl'); + + $vcard_nice['firstname'] = ''; + $vcard_nice['lastname'] = ''; } foreach ($vcard_nice as $k => $v) { @@ -88,7 +102,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"), @@ -98,126 +112,79 @@ $ShowValues = array( 'tel;fax' => _("Fax"), 'note' => _("Note")); -echo html_tag( 'tr' ) . html_tag( 'td', '', 'left' ) . '
' . - html_tag( 'table', '', 'center', '', 'border="0" cellpadding="2" cellspacing="0"' ) . "\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 = array(); foreach ($ShowValues as $k => $v) { - if (isset($vcard_safe[$k]) && $vcard_safe[$k]) { - echo "$v:" . $vcard_safe[$k] . - "\n"; + if (isset($vcard_safe[$k]) && $vcard_safe[$k]) { + $vcard[$v] = $vcard_safe[$k]; } } -echo '' . - '
' . - '' . - html_tag( 'table', '', 'center', '', 'border="0" cellpadding="2" cellspacing="0" width="100%"' ) . "\n"; - html_tag( 'tr', - html_tag( 'td', - '
' . - _("Add to Addressbook") . '
' , - 'left', $color[0] ) - ) . - html_tag( 'tr' ) . - html_tag( 'td', '', 'center' ) . - '
' . - html_tag( 'table', '', 'center', '', 'border="0" cellpadding="2" cellspacing="0" width="100%"' ) . - html_tag( 'tr', - html_tag( 'td', - 'Nickname:' , - 'right' ) . - html_tag( 'td', - '' , - 'left' ) - ) . - html_tag( 'tr' ) . - html_tag( 'td', 'Note Field Contains:', 'right' ) . - html_tag( 'td', '', 'left' ) . - '' . - '' . - html_tag( 'tr', - html_tag( 'td', - '' . - '' . - '' . - '' , - 'center', '', 'colspan="2"' ) - ) . - '' . - '
' . - '' . - html_tag( 'tr', - html_tag( 'td', - '' . - _("Download this as a file") . '' , - 'center' ) - ) . - '' . - - html_tag( 'table', - html_tag( 'tr', - html_tag( 'td', ' ', 'left', $color[4] ) - ) , - 'center', '', 'border="0" cellspacing="0" cellpadding="2"' ) . - ''; - -?> + $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');