X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fvcard.php;h=173e6588acd187386d2979fdff2886a7604f4700;hb=f965aa907a1ead127c5225a524bf86a496294675;hp=5af777dde1dfef8bf5043a0a05ec85a24d27aa93;hpb=895905c0f766ea03e85deab260b4bb1522dd0e3c;p=squirrelmail.git diff --git a/src/vcard.php b/src/vcard.php index 5af777dd..173e6588 100644 --- a/src/vcard.php +++ b/src/vcard.php @@ -1,202 +1,245 @@ ' . "\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 '
' . - '
' . - _("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['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] . - "
' . - '
' . - '
' . - '' . - '' . - '' . - '' . - '
' . - '
' . - _("Add to Addressbook") . - '
' . - '
' . - '' . - '' . - '' . - '' . - '' . - '
Nickname:
Note Field Contains:' . - '' . - '
' . - '' . - '' . - '' . - '' . - '
' . - '
' . - '
' . - '' . - _("Download this as a file") . '' . - '
' . - - '' . - '
' . - '
' . - ''; +/** + * vcard.php + * + * This file shows an attched vcard + * + * @copyright © 1999-2005 The SquirrelMail Project Team + * @license http://opensource.org/licenses/gpl-license.php GNU Public License + * @version $Id$ + * @package squirrelmail + */ + +/** + * Path for SquirrelMail required files. + * @ignore + */ +Define('SM_PATH','../'); + +/* SquirrelMail required files. */ +require_once(SM_PATH . 'include/validate.php'); +require_once(SM_PATH . 'functions/mime.php'); +require_once(SM_PATH . 'functions/url_parser.php'); + +/* globals */ +sqgetGlobalVar('username', $username, SQ_SESSION); +sqgetGlobalVar('key', $key, SQ_COOKIE); +sqgetGlobalVar('onetimepad', $onetimepad, SQ_SESSION); + +sqgetGlobalVar('passed_id', $passed_id, SQ_GET); +sqgetGlobalVar('mailbox', $mailbox, SQ_GET); +sqgetGlobalVar('ent_id', $ent_id, SQ_GET); +sqgetGlobalVar('startMessage', $startMessage, SQ_GET); +/* 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,$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"; + $vcard_nice['firstname'] = ''; + $vcard_nice['lastname'] = ''; +} + +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' => _("E-mail"), + '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") . " - "; + +$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); + +echo ''. _("View message") . '' . + '
' . + sprintf(_("vCard Version %s is not supported. Some information might not be converted correctly."), + htmlspecialchars($vcard_nice['version'])) . + "

' . + '' . "\n"; + +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'] . ''; +} + +foreach ($ShowValues as $k => $v) { + if (isset($vcard_safe[$k]) && $vcard_safe[$k]) { + echo "\n"; + } +} + +?> +
$v:" . + $vcard_safe[$k] . "
+
+
+ + + +
+
+
+
+ + +' . + '' . + ' + +
: +rfc822_header; + $from_name = $header->getAddr_s('from'); + + echo '
' . _("E-mail address") . ':' . + addInput('addaddr[email]', + getEmail(decodeHeader($from_name)), '20'); +} + +echo '
' . _("Additional info") . ':'; + +$opts = array(); +if (isset($vcard_nice['url'])) { + $opts[$vcard_nice['url']] = _("Web Page"); +} +if (isset($vcard_nice['adr'])) { + $opts[$vcard_nice['adr']] = _("Address"); +} +if (isset($vcard_nice['title'])) { + $opts[$vcard_nice['title']] = _("Title"); +} +if (isset($vcard_nice['org'])) { + $opts[$vcard_nice['org']] = _("Organization / Department"); +} +if (isset($vcard_nice['title'])) { + $opts[$vcard_nice['title'].'; '.$vcard_nice['org']] = _("Title & Org. / Dept."); +} +if (isset($vcard_nice['tel;work'])) { + $opts[$vcard_nice['tel;work']] = _("Work Phone"); +} +if (isset($vcard_nice['tel;home'])) { + $opts[$vcard_nice['tel;home']] = _("Home Phone"); +} +if (isset($vcard_nice['tel;cell'])) { + $opts[$vcard_nice['tel;cell']] = _("Cellular Phone"); +} +if (isset($vcard_nice['tel;fax'])) { + $opts[$vcard_nice['tel;fax']] = _("Fax"); +} +if (isset($vcard_nice['note'])) { + $opts[$vcard_nice['note']] = _("Note"); +} + +/* + * If the vcard comes with nothing but name and e-mail address, the user gets + * the chance to type some additional info. If there's more info in the card, + * the user gets to choose what will be added as additional info. + */ +if (count($opts) == 0) { + echo addInput('addaddr[label]', '', '20'); +} else { + echo addSelect('addaddr[label]', $opts, '', TRUE); +} + +?> +

+ +
+ +
+' . + _("Download this as a file") . ''; +?> +
+ +
+
+ \ No newline at end of file