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( '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"' ) .
- '