photos = $photos; if (is_array($users)) { foreach ($users as $user) { $this->add_user($user, $freetext); } } else { $this->add_user($users, $freetext); } } function escape($text) { return preg_replace('/[,;]/', '\\\\$0', $text); } function format_adr($params, &$smarty) { // $adr1, $adr2, $adr3, $postcode, $city, $region, $country extract($params['adr']); $adr = trim($adr1); $adr = trim("$adr\n$adr2"); $adr = trim("$adr\n$adr3"); return $this->text_encode(';;' . $this->escape($adr) . ';' . $this->escape($city) . ';' . $this->escape($region) . ';' . $this->escape($postcode) . ';' . $this->escape($country), false); } function text_encode($text, $escape = true) { if (is_array($text)) { return implode(',', array_map(array($this, 'text_encode'), $text)); } if ($escape) { $text = $this->escape($text); } return preg_replace("/(\r\n|\n|\r)/", '\n', $text); } function add_user($x, $freetext) { global $globals; $login = get_user_forlife($x); $user = get_user_details($login); if (strlen(trim($user['freetext']))) { $user['freetext'] = html_entity_decode($user['freetext']); } if (!is_null($freetext)) { if (strlen(trim($user['freetext']))) { $user['freetext'] = $freetext . "\n" . $user['freetext']; } else { $user['freetext'] = $freetext; } } // alias virtual $res = XDB::query( "SELECT alias FROM virtual INNER JOIN virtual_redirect USING(vid) INNER JOIN auth_user_quick ON ( user_id = {?} AND emails_alias_pub = 'public' ) WHERE ( redirect={?} OR redirect={?} ) AND alias LIKE '%@{$globals->mail->alias_dom}'", S::v('uid'), $user['forlife'].'@'.$globals->mail->domain, $user['forlife'].'@'.$globals->mail->domain2); $user['virtualalias'] = $res->fetchOneCell(); $user['gpxs_vcardjoin'] = join(',', array_map(array($this, 'text_encode'), $user['gpxs_name'])); $user['binets_vcardjoin'] = join(',', array_map(array($this, 'text_encode'), $user['binets'])); // get photo if ($this->photos) { $res = XDB::query( "SELECT attach, attachmime FROM photo AS p INNER JOIN aliases AS a ON (a.id = p.uid AND a.type = 'a_vie') WHERE a.alias = {?}", $login); if ($res->numRows()) { $user['photo'] = $res->fetchOneAssoc(); } } $this->users[] = $user; } function do_page(&$page) { $page->changeTpl('core/vcard.tpl', NO_SKIN); $page->register_modifier('vcard_enc', array($this, 'text_encode')); $page->register_function('format_adr', array($this, 'format_adr')); $page->assign_by_ref('users', $this->users); header("Pragma: "); header("Cache-Control: "); header("Content-type: text/x-vcard; charset=UTF-8"); header("Content-Transfer-Encoding: 8bit"); } } // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: ?>