X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fvcard.php;h=cd104b9a6c98e87bd50997b15ffceba0ba08b30f;hb=0fa230016e399929e51d8e007b1509421424c7de;hp=5af777dde1dfef8bf5043a0a05ec85a24d27aa93;hpb=895905c0f766ea03e85deab260b4bb1522dd0e3c;p=squirrelmail.git diff --git a/src/vcard.php b/src/vcard.php index 5af777dd..cd104b9a 100644 --- a/src/vcard.php +++ b/src/vcard.php @@ -1,132 +1,140 @@ ' . "\n" . +/** + * vcard.php + * + * Copyright (c) 1999-2003 The SquirrelMail Project Team + * Licensed under the GNU GPL. For full terms see the file COPYING. + * + * This file shows an attched vcard + * + * $Id$ + */ + +/* Path for SquirrelMail required files. */ +Define('SM_PATH','../'); + +/* SquirrelMail required files. */ +require_once(SM_PATH . 'include/validate.php'); +require_once(SM_PATH . 'functions/date.php'); +require_once(SM_PATH . 'functions/page_header.php'); +require_once(SM_PATH . 'functions/mime.php'); +require_once(SM_PATH . 'include/load_prefs.php'); + +/* globals */ +$key = $_COOKIE['key']; +$username = $_SESSION['username']; +$onetimepad = $_SESSION['onetimepad']; +$mailbox = urldecode($_GET['mailbox']); +$passed_id = (int) $_GET['passed_id']; +$ent_id = $_GET['ent_id']; +$startMessage = (int) $_GET['startMessage']; +/* end globals */ + +$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0); +sqimap_mailbox_select($imapConnection, $mailbox); + + +displayPageHeader($color, 'None'); + +echo '
' . "\n" . ''; - - $message = sqimap_get_message($imapConnection, $passed_id, $mailbox); - - $entity_vcard = getEntity($message,$passed_ent_id); - - $vcard = mime_fetch_body ($imapConnection, $passed_id, $passed_ent_id); - $vcard = decodeBody($vcard, $entity_vcard->header->encoding); - $vcard = explode ("\n",$vcard); - foreach ($vcard as $l) - { - $k = substr($l, 0, strpos($l, ':')); - $v = substr($l, strpos($l, ':') + 1); - $attributes = explode(';', $k); - $k = strtolower(array_shift($attributes)); - foreach ($attributes as $attr) - { - if ($attr == 'quoted-printable') - $v = quoted_printable_decode($v); - else - $k .= ';' . $attr; - } - - $v = ereg_replace(';', "\n", $v); - $vcard_nice[$k] = $v; - } - - 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")); - } - else - { - echo '\n"; - } - - foreach ($vcard_nice as $k => $v) - { - $v = htmlspecialchars($v); - $v = trim($v); - $vcard_safe[$k] = trim(nl2br($v)); - } - - $ShowValues = array( - 'fn' => _("Name"), - 'title' => _("Title"), - 'email;internet' => _("Email"), - 'url' => _("Web Page"), - 'org' => _("Organization / Department"), - 'adr' => _("Address"), - 'tel;work' => _("Work Phone"), - 'tel;home' => _("Home Phone"), - 'tel;cell' => _("Cellular Phone"), - 'tel;fax' => _("Fax"), - 'note' => _("Note")); - - echo ''; + +$message = sqimap_get_message($imapConnection, $passed_id, $mailbox); + +$entity_vcard = getEntity($message,$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) { + $k = substr($l, 0, strpos($l, ':')); + $v = substr($l, strpos($l, ':') + 1); + $attributes = explode(';', $k); + $k = strtolower(array_shift($attributes)); + foreach ($attributes as $attr) { + if ($attr == 'quoted-printable') + $v = quoted_printable_decode($v); + else + $k .= ';' . strtolower($attr); + } + + $v = str_replace(';', "\n", $v); + $vcard_nice[$k] = $v; +} + +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")); + // 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"; +} + +foreach ($vcard_nice as $k => $v) { + $v = htmlspecialchars($v); + $v = trim($v); + $vcard_safe[$k] = trim(nl2br($v)); +} + +$ShowValues = array( + 'fn' => _("Name"), + 'title' => _("Title"), + 'email;internet' => _("Email"), + 'url' => _("Web Page"), + 'org' => _("Organization / Department"), + 'adr' => _("Address"), + 'tel;work' => _("Work Phone"), + 'tel;home' => _("Home Phone"), + 'tel;cell' => _("Cellular Phone"), + '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.

' . +$msg_url = 'read_body.php?mailbox='.urlencode($mailbox). + '&startMessage='.$startMessage. + '&passed_id='.$passed_id; + +$msg_url = set_url_var($msg_url, 'ent_id', 0); + +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['url'])) { - $vcard_safe['url'] = '' . - $vcard_safe['url'] . ''; - } - - foreach ($ShowValues as $k => $v) - { - if (isset($vcard_safe[$k]) && $vcard_safe[$k]) - { - echo "\n"; - } - } + } +} - echo '
$v:" . $vcard_safe[$k] . + +if (isset($vcard_safe['email;internet'])) { $vcard_safe['email;internet'] = '' . $vcard_safe['email;internet'] . + ''; +} +if (isset($vcard_safe['url'])) { + $vcard_safe['url'] = '' . + $vcard_safe['url'] . ''; +} + +foreach ($ShowValues as $k => $v) { + if (isset($vcard_safe[$k]) && $vcard_safe[$k]) { + echo "
$v:" . $vcard_safe[$k] . "
' . +echo '
' . '
' . '' . '' . + 'align="center">' . '' . '' . '' . '
' . '
' . @@ -142,57 +150,66 @@ '
Note Field Contains:' . '' . +if (isset($vcard_nice['url'])) { + echo '\n"; +} +if (isset($vcard_nice['adr'])) { + echo '\n"; +} +if (isset($vcard_nice['title'])) { + echo '\n"; +} +if (isset($vcard_nice['org'])) { + echo '\n"; +} +if (isset($vcard_nice['title'])) { + echo '\n"; +} +if (isset($vcard_nice['tel;work'])) { + echo '\n"; +} +if (isset($vcard_nice['tel;home'])) { + echo '\n"; +} +if (isset($vcard_nice['tel;cell'])) { + echo '\n"; +} +if (isset($vcard_nice['tel;fax'])) { + echo '\n"; +} +if (isset($vcard_nice['note'])) { + echo '\n"; +} +echo '' . '
' . '' . + htmlspecialchars($vcard_nice['email;internet']) . '">' . '' . + $vcard_safe['firstname'] . '">' . '' . + $vcard_safe['lastname'] . '">' . '' . + 'VALUE="Add to Address Book">' . '
' . '' . '' . '' . - '' . + '' . _("Download this as a file") . '' . '' . @@ -200,3 +217,5 @@ '' . '' . ''; + +?>