From ee4db3d21c17928913566d6a2b65cb36b677fa73 Mon Sep 17 00:00:00 2001 From: Evan Prodromou Date: Sat, 20 Dec 2008 19:30:16 -0500 Subject: [PATCH] reformatting for phpcs in lib/util.php darcs-hash:20081221003016-84dde-0e80268e95235462e069d4d1e6b949bc891ccdbd.gz --- _darcs/inventory | 4 +- ...e80268e95235462e069d4d1e6b949bc891ccdbd.gz | Bin 0 -> 22612 bytes _darcs/pristine/lib/util.php | 3273 ++++++++-------- _darcs/tentative_pristine | 3418 ++++++++++++++++- lib/util.php | 3273 ++++++++-------- 5 files changed, 6642 insertions(+), 3326 deletions(-) create mode 100644 _darcs/patches/20081221003016-84dde-0e80268e95235462e069d4d1e6b949bc891ccdbd.gz diff --git a/_darcs/inventory b/_darcs/inventory index 49dc7559d3..83b5a479fc 100644 --- a/_darcs/inventory +++ b/_darcs/inventory @@ -21,4 +21,6 @@ Sarven Capadisli **20081218003302 [more information in subscription notices Evan Prodromou **20081212171135] [first step of phpcs-cleanup of index.php -Evan Prodromou **20081221002332] \ No newline at end of file +Evan Prodromou **20081221002332] +[reformatting for phpcs in lib/util.php +Evan Prodromou **20081221003016] \ No newline at end of file diff --git a/_darcs/patches/20081221003016-84dde-0e80268e95235462e069d4d1e6b949bc891ccdbd.gz b/_darcs/patches/20081221003016-84dde-0e80268e95235462e069d4d1e6b949bc891ccdbd.gz new file mode 100644 index 0000000000000000000000000000000000000000..344e0693f4d95d1431ba08568a73be68c9c50462 GIT binary patch literal 22612 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 'Internal Server Error', - 501 => 'Not Implemented', - 502 => 'Bad Gateway', - 503 => 'Service Unavailable', - 504 => 'Gateway Timeout', - 505 => 'HTTP Version Not Supported'); - - if (!array_key_exists($code, $status)) { - $code = 500; - } + static $status = array(500 => 'Internal Server Error', + 501 => 'Not Implemented', + 502 => 'Bad Gateway', + 503 => 'Service Unavailable', + 504 => 'Gateway Timeout', + 505 => 'HTTP Version Not Supported'); + + if (!array_key_exists($code, $status)) { + $code = 500; + } - $status_string = $status[$code]; + $status_string = $status[$code]; - header('HTTP/1.1 '.$code.' '.$status_string); - header('Content-type: text/plain'); + header('HTTP/1.1 '.$code.' '.$status_string); + header('Content-type: text/plain'); - print $msg; - print "\n"; - exit(); + print $msg; + print "\n"; + exit(); } -# Show a user error +// Show a user error function common_user_error($msg, $code=400) { - static $status = array(400 => 'Bad Request', - 401 => 'Unauthorized', - 402 => 'Payment Required', - 403 => 'Forbidden', - 404 => 'Not Found', - 405 => 'Method Not Allowed', - 406 => 'Not Acceptable', - 407 => 'Proxy Authentication Required', - 408 => 'Request Timeout', - 409 => 'Conflict', - 410 => 'Gone', - 411 => 'Length Required', - 412 => 'Precondition Failed', - 413 => 'Request Entity Too Large', - 414 => 'Request-URI Too Long', - 415 => 'Unsupported Media Type', - 416 => 'Requested Range Not Satisfiable', - 417 => 'Expectation Failed'); - - if (!array_key_exists($code, $status)) { - $code = 400; - } - - $status_string = $status[$code]; - - header('HTTP/1.1 '.$code.' '.$status_string); - - common_show_header('Error'); - common_element('div', array('class' => 'error'), $msg); - common_show_footer(); + static $status = array(400 => 'Bad Request', + 401 => 'Unauthorized', + 402 => 'Payment Required', + 403 => 'Forbidden', + 404 => 'Not Found', + 405 => 'Method Not Allowed', + 406 => 'Not Acceptable', + 407 => 'Proxy Authentication Required', + 408 => 'Request Timeout', + 409 => 'Conflict', + 410 => 'Gone', + 411 => 'Length Required', + 412 => 'Precondition Failed', + 413 => 'Request Entity Too Large', + 414 => 'Request-URI Too Long', + 415 => 'Unsupported Media Type', + 416 => 'Requested Range Not Satisfiable', + 417 => 'Expectation Failed'); + + if (!array_key_exists($code, $status)) { + $code = 400; + } + + $status_string = $status[$code]; + + header('HTTP/1.1 '.$code.' '.$status_string); + + common_show_header('Error'); + common_element('div', array('class' => 'error'), $msg); + common_show_footer(); } $xw = null; -# Start an HTML element -function common_element_start($tag, $attrs=NULL) { - global $xw; - $xw->startElement($tag); - if (is_array($attrs)) { - foreach ($attrs as $name => $value) { - $xw->writeAttribute($name, $value); - } - } else if (is_string($attrs)) { - $xw->writeAttribute('class', $attrs); - } +// Start an HTML element +function common_element_start($tag, $attrs=null) { + global $xw; + $xw->startElement($tag); + if (is_array($attrs)) { + foreach ($attrs as $name => $value) { + $xw->writeAttribute($name, $value); + } + } else if (is_string($attrs)) { + $xw->writeAttribute('class', $attrs); + } } function common_element_end($tag) { - static $empty_tag = array('base', 'meta', 'link', 'hr', - 'br', 'param', 'img', 'area', - 'input', 'col'); - global $xw; - # XXX: check namespace - if (in_array($tag, $empty_tag)) { - $xw->endElement(); - } else { - $xw->fullEndElement(); - } -} - -function common_element($tag, $attrs=NULL, $content=NULL) { - common_element_start($tag, $attrs); - global $xw; - if (!is_null($content)) { - $xw->text($content); - } - common_element_end($tag); -} - -function common_start_xml($doc=NULL, $public=NULL, $system=NULL, $indent=true) { - global $xw; - $xw = new XMLWriter(); - $xw->openURI('php://output'); - $xw->setIndent($indent); - $xw->startDocument('1.0', 'UTF-8'); - if ($doc) { - $xw->writeDTD($doc, $public, $system); - } + static $empty_tag = array('base', 'meta', 'link', 'hr', + 'br', 'param', 'img', 'area', + 'input', 'col'); + global $xw; + // XXX: check namespace + if (in_array($tag, $empty_tag)) { + $xw->endElement(); + } else { + $xw->fullEndElement(); + } +} + +function common_element($tag, $attrs=null, $content=null) { + common_element_start($tag, $attrs); + global $xw; + if (!is_null($content)) { + $xw->text($content); + } + common_element_end($tag); +} + +function common_start_xml($doc=null, $public=null, $system=null, $indent=true) { + global $xw; + $xw = new XMLWriter(); + $xw->openURI('php://output'); + $xw->setIndent($indent); + $xw->startDocument('1.0', 'UTF-8'); + if ($doc) { + $xw->writeDTD($doc, $public, $system); + } } function common_end_xml() { - global $xw; - $xw->endDocument(); - $xw->flush(); + global $xw; + $xw->endDocument(); + $xw->flush(); } function common_init_locale($language=null) { @@ -138,433 +138,433 @@ function common_init_locale($language=null) { putenv('LANGUAGE='.$language); putenv('LANG='.$language); return setlocale(LC_ALL, $language . ".utf8", - $language . ".UTF8", - $language . ".utf-8", - $language . ".UTF-8", - $language); + $language . ".UTF8", + $language . ".utf-8", + $language . ".UTF-8", + $language); } function common_init_language() { - mb_internal_encoding('UTF-8'); - $language = common_language(); - # So we don't have to make people install the gettext locales - $locale_set = common_init_locale($language); - bindtextdomain("laconica", common_config('site','locale_path')); - bind_textdomain_codeset("laconica", "UTF-8"); - textdomain("laconica"); - setlocale(LC_CTYPE, 'C'); - if(!$locale_set) { - common_log(LOG_INFO,'Language requested:'.$language.' - locale could not be set:',__FILE__); - } + mb_internal_encoding('UTF-8'); + $language = common_language(); + // So we don't have to make people install the gettext locales + $locale_set = common_init_locale($language); + bindtextdomain("laconica", common_config('site','locale_path')); + bind_textdomain_codeset("laconica", "UTF-8"); + textdomain("laconica"); + setlocale(LC_CTYPE, 'C'); + if(!$locale_set) { + common_log(LOG_INFO,'Language requested:'.$language.' - locale could not be set:',__FILE__); + } } define('PAGE_TYPE_PREFS', 'text/html,application/xhtml+xml,application/xml;q=0.3,text/xml;q=0.2'); -function common_show_header($pagetitle, $callable=NULL, $data=NULL, $headercall=NULL) { +function common_show_header($pagetitle, $callable=null, $data=null, $headercall=null) { - global $config, $xw; + global $config, $xw; global $action; /* XXX: kind of cheating here. */ - common_start_html(); - - common_element_start('head'); - common_element('title', NULL, - $pagetitle . " - " . $config['site']['name']); - common_element('link', array('rel' => 'stylesheet', - 'type' => 'text/css', - 'href' => theme_path('display.css') . '?version=' . LACONICA_VERSION, - 'media' => 'screen, projection, tv')); - foreach (array(6,7) as $ver) { - if (file_exists(theme_file('ie'.$ver.'.css'))) { - # Yes, IE people should be put in jail. - $xw->writeComment('[if lte IE '.$ver.']> 'text/javascript', - 'src' => common_path('js/jquery.min.js')), - ' '); - common_element('script', array('type' => 'text/javascript', - 'src' => common_path('js/jquery.form.js')), - ' '); - common_element('script', array('type' => 'text/javascript', - 'src' => common_path('js/xbImportNode.js')), - ' '); - common_element('script', array('type' => 'text/javascript', - 'src' => common_path('js/util.js?version='.LACONICA_VERSION)), - ' '); - common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', - 'href' => common_local_url('opensearch', array('type' => 'people')), - 'title' => common_config('site', 'name').' People Search')); - - common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', - 'href' => common_local_url('opensearch', array('type' => 'notice')), - 'title' => common_config('site', 'name').' Notice Search')); - - if ($callable) { - if ($data) { - call_user_func($callable, $data); - } else { - call_user_func($callable); - } - } - common_element_end('head'); - common_element_start('body', $action); - common_element_start('div', array('id' => 'wrap')); - common_element_start('div', array('id' => 'header')); - common_nav_menu(); - if ((isset($config['site']['logo']) && is_string($config['site']['logo']) && (strlen($config['site']['logo']) > 0)) - || file_exists(theme_file('logo.png'))) - { - common_element_start('a', array('href' => common_local_url('public'))); - common_element('img', array('src' => isset($config['site']['logo']) ? - ($config['site']['logo']) : theme_path('logo.png'), - 'alt' => $config['site']['name'], - 'id' => 'logo')); - common_element_end('a'); - } else { - common_element_start('p', array('id' => 'branding')); - common_element('a', array('href' => common_local_url('public')), - $config['site']['name']); - common_element_end('p'); - } - - common_element('h1', 'pagetitle', $pagetitle); - - if ($headercall) { - if ($data) { - call_user_func($headercall, $data); - } else { - call_user_func($headercall); - } - } - common_element_end('div'); - common_element_start('div', array('id' => 'content')); -} - -function common_start_html($type=NULL, $indent=true) { - - if (!$type) { - $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ? $_SERVER['HTTP_ACCEPT'] : NULL; - - # XXX: allow content negotiation for RDF, RSS, or XRDS - - $type = common_negotiate_type(common_accept_to_prefs($httpaccept), - common_accept_to_prefs(PAGE_TYPE_PREFS)); - - if (!$type) { - common_user_error(_('This page is not available in a media type you accept'), 406); - exit(0); - } - } - - header('Content-Type: '.$type); - - common_start_xml('html', - '-//W3C//DTD XHTML 1.0 Strict//EN', - 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd', $indent); - - # FIXME: correct language for interface - - $language = common_language(); - - common_element_start('html', array('xmlns' => 'http://www.w3.org/1999/xhtml', - 'xml:lang' => $language, - 'lang' => $language)); + common_start_html(); + + common_element_start('head'); + common_element('title', null, + $pagetitle . " - " . $config['site']['name']); + common_element('link', array('rel' => 'stylesheet', + 'type' => 'text/css', + 'href' => theme_path('display.css') . '?version=' . LACONICA_VERSION, + 'media' => 'screen, projection, tv')); + foreach (array(6,7) as $ver) { + if (file_exists(theme_file('ie'.$ver.'.css'))) { + // Yes, IE people should be put in jail. + $xw->writeComment('[if lte IE '.$ver.']> 'text/javascript', + 'src' => common_path('js/jquery.min.js')), + ' '); + common_element('script', array('type' => 'text/javascript', + 'src' => common_path('js/jquery.form.js')), + ' '); + common_element('script', array('type' => 'text/javascript', + 'src' => common_path('js/xbImportNode.js')), + ' '); + common_element('script', array('type' => 'text/javascript', + 'src' => common_path('js/util.js?version='.LACONICA_VERSION)), + ' '); + common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', + 'href' => common_local_url('opensearch', array('type' => 'people')), + 'title' => common_config('site', 'name').' People Search')); + + common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', + 'href' => common_local_url('opensearch', array('type' => 'notice')), + 'title' => common_config('site', 'name').' Notice Search')); + + if ($callable) { + if ($data) { + call_user_func($callable, $data); + } else { + call_user_func($callable); + } + } + common_element_end('head'); + common_element_start('body', $action); + common_element_start('div', array('id' => 'wrap')); + common_element_start('div', array('id' => 'header')); + common_nav_menu(); + if ((isset($config['site']['logo']) && is_string($config['site']['logo']) && (strlen($config['site']['logo']) > 0)) + || file_exists(theme_file('logo.png'))) + { + common_element_start('a', array('href' => common_local_url('public'))); + common_element('img', array('src' => isset($config['site']['logo']) ? + ($config['site']['logo']) : theme_path('logo.png'), + 'alt' => $config['site']['name'], + 'id' => 'logo')); + common_element_end('a'); + } else { + common_element_start('p', array('id' => 'branding')); + common_element('a', array('href' => common_local_url('public')), + $config['site']['name']); + common_element_end('p'); + } + + common_element('h1', 'pagetitle', $pagetitle); + + if ($headercall) { + if ($data) { + call_user_func($headercall, $data); + } else { + call_user_func($headercall); + } + } + common_element_end('div'); + common_element_start('div', array('id' => 'content')); +} + +function common_start_html($type=null, $indent=true) { + + if (!$type) { + $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ? $_SERVER['HTTP_ACCEPT'] : null; + + // XXX: allow content negotiation for RDF, RSS, or XRDS + + $type = common_negotiate_type(common_accept_to_prefs($httpaccept), + common_accept_to_prefs(PAGE_TYPE_PREFS)); + + if (!$type) { + common_user_error(_('This page is not available in a media type you accept'), 406); + exit(0); + } + } + + header('Content-Type: '.$type); + + common_start_xml('html', + '-//W3C//DTD XHTML 1.0 Strict//EN', + 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd', $indent); + + // FIXME: correct language for interface + + $language = common_language(); + + common_element_start('html', array('xmlns' => 'http://www.w3.org/1999/xhtml', + 'xml:lang' => $language, + 'lang' => $language)); } function common_show_footer() { - global $xw, $config; - common_element_end('div'); # content div - common_foot_menu(); - common_element_start('div', array('id' => 'footer')); - common_element_start('div', 'laconica'); - if (common_config('site', 'broughtby')) { - $instr = _('**%%site.name%%** is a microblogging service brought to you by [%%site.broughtby%%](%%site.broughtbyurl%%). '); - } else { - $instr = _('**%%site.name%%** is a microblogging service. '); - } - $instr .= sprintf(_('It runs the [Laconica](http://laconi.ca/) microblogging software, version %s, available under the [GNU Affero General Public License](http://www.fsf.org/licensing/licenses/agpl-3.0.html).'), LACONICA_VERSION); + global $xw, $config; + common_element_end('div'); // content div + common_foot_menu(); + common_element_start('div', array('id' => 'footer')); + common_element_start('div', 'laconica'); + if (common_config('site', 'broughtby')) { + $instr = _('**%%site.name%%** is a microblogging service brought to you by [%%site.broughtby%%](%%site.broughtbyurl%%). '); + } else { + $instr = _('**%%site.name%%** is a microblogging service. '); + } + $instr .= sprintf(_('It runs the [Laconica](http://laconi.ca/) microblogging software, version %s, available under the [GNU Affero General Public License](http://www.fsf.org/licensing/licenses/agpl-3.0.html).'), LACONICA_VERSION); $output = common_markup_to_html($instr); common_raw($output); - common_element_end('div'); - common_element('img', array('id' => 'cc', - 'src' => $config['license']['image'], - 'alt' => $config['license']['title'])); - common_element_start('p'); - common_text(_('Unless otherwise specified, contents of this site are copyright by the contributors and available under the ')); - common_element('a', array('class' => 'license', - 'rel' => 'license', - 'href' => $config['license']['url']), - $config['license']['title']); - common_text(_('. Contributors should be attributed by full name or nickname.')); - common_element_end('p'); - common_element_end('div'); - common_element_end('div'); - common_element_end('body'); - common_element_end('html'); - common_end_xml(); + common_element_end('div'); + common_element('img', array('id' => 'cc', + 'src' => $config['license']['image'], + 'alt' => $config['license']['title'])); + common_element_start('p'); + common_text(_('Unless otherwise specified, contents of this site are copyright by the contributors and available under the ')); + common_element('a', array('class' => 'license', + 'rel' => 'license', + 'href' => $config['license']['url']), + $config['license']['title']); + common_text(_('. Contributors should be attributed by full name or nickname.')); + common_element_end('p'); + common_element_end('div'); + common_element_end('div'); + common_element_end('body'); + common_element_end('html'); + common_end_xml(); } function common_text($txt) { - global $xw; - $xw->text($txt); + global $xw; + $xw->text($txt); } function common_raw($xml) { - global $xw; - $xw->writeRaw($xml); + global $xw; + $xw->writeRaw($xml); } function common_nav_menu() { - $user = common_current_user(); - common_element_start('ul', array('id' => 'nav')); - if ($user) { - common_menu_item(common_local_url('all', array('nickname' => $user->nickname)), - _('Home')); - } - common_menu_item(common_local_url('peoplesearch'), _('Search')); - if ($user) { - common_menu_item(common_local_url('profilesettings'), - _('Settings')); - common_menu_item(common_local_url('invite'), - _('Invite')); - common_menu_item(common_local_url('logout'), - _('Logout')); - } else { - common_menu_item(common_local_url('login'), _('Login')); - if (!common_config('site', 'closed')) { - common_menu_item(common_local_url('register'), _('Register')); - } - common_menu_item(common_local_url('openidlogin'), _('OpenID')); - } - common_menu_item(common_local_url('doc', array('title' => 'help')), - _('Help')); - common_element_end('ul'); + $user = common_current_user(); + common_element_start('ul', array('id' => 'nav')); + if ($user) { + common_menu_item(common_local_url('all', array('nickname' => $user->nickname)), + _('Home')); + } + common_menu_item(common_local_url('peoplesearch'), _('Search')); + if ($user) { + common_menu_item(common_local_url('profilesettings'), + _('Settings')); + common_menu_item(common_local_url('invite'), + _('Invite')); + common_menu_item(common_local_url('logout'), + _('Logout')); + } else { + common_menu_item(common_local_url('login'), _('Login')); + if (!common_config('site', 'closed')) { + common_menu_item(common_local_url('register'), _('Register')); + } + common_menu_item(common_local_url('openidlogin'), _('OpenID')); + } + common_menu_item(common_local_url('doc', array('title' => 'help')), + _('Help')); + common_element_end('ul'); } function common_foot_menu() { - common_element_start('ul', array('id' => 'nav_sub')); - common_menu_item(common_local_url('doc', array('title' => 'help')), - _('Help')); - common_menu_item(common_local_url('doc', array('title' => 'about')), - _('About')); - common_menu_item(common_local_url('doc', array('title' => 'faq')), - _('FAQ')); - common_menu_item(common_local_url('doc', array('title' => 'privacy')), - _('Privacy')); - common_menu_item(common_local_url('doc', array('title' => 'source')), - _('Source')); - common_menu_item(common_local_url('doc', array('title' => 'contact')), - _('Contact')); - common_element_end('ul'); -} - -function common_menu_item($url, $text, $title=NULL, $is_selected=false) { - $lattrs = array(); - if ($is_selected) { - $lattrs['class'] = 'current'; - } - common_element_start('li', $lattrs); - $attrs['href'] = $url; - if ($title) { - $attrs['title'] = $title; - } - common_element('a', $attrs, $text); - common_element_end('li'); -} - -function common_input($id, $label, $value=NULL,$instructions=NULL) { - common_element_start('p'); - common_element('label', array('for' => $id), $label); - $attrs = array('name' => $id, - 'type' => 'text', - 'class' => 'input_text', - 'id' => $id); - if ($value) { - $attrs['value'] = htmlspecialchars($value); - } - common_element('input', $attrs); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); -} - -function common_checkbox($id, $label, $checked=false, $instructions=NULL, $value='true', $disabled=false) + common_element_start('ul', array('id' => 'nav_sub')); + common_menu_item(common_local_url('doc', array('title' => 'help')), + _('Help')); + common_menu_item(common_local_url('doc', array('title' => 'about')), + _('About')); + common_menu_item(common_local_url('doc', array('title' => 'faq')), + _('FAQ')); + common_menu_item(common_local_url('doc', array('title' => 'privacy')), + _('Privacy')); + common_menu_item(common_local_url('doc', array('title' => 'source')), + _('Source')); + common_menu_item(common_local_url('doc', array('title' => 'contact')), + _('Contact')); + common_element_end('ul'); +} + +function common_menu_item($url, $text, $title=null, $is_selected=false) { + $lattrs = array(); + if ($is_selected) { + $lattrs['class'] = 'current'; + } + common_element_start('li', $lattrs); + $attrs['href'] = $url; + if ($title) { + $attrs['title'] = $title; + } + common_element('a', $attrs, $text); + common_element_end('li'); +} + +function common_input($id, $label, $value=null,$instructions=null) { + common_element_start('p'); + common_element('label', array('for' => $id), $label); + $attrs = array('name' => $id, + 'type' => 'text', + 'class' => 'input_text', + 'id' => $id); + if ($value) { + $attrs['value'] = htmlspecialchars($value); + } + common_element('input', $attrs); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); +} + +function common_checkbox($id, $label, $checked=false, $instructions=null, $value='true', $disabled=false) { - common_element_start('p'); - $attrs = array('name' => $id, - 'type' => 'checkbox', - 'class' => 'checkbox', - 'id' => $id); - if ($value) { - $attrs['value'] = htmlspecialchars($value); - } - if ($checked) { - $attrs['checked'] = 'checked'; - } - if ($disabled) { - $attrs['disabled'] = 'true'; - } - common_element('input', $attrs); - common_text(' '); - common_element('label', array('class' => 'checkbox_label', 'for' => $id), $label); - common_text(' '); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); -} - -function common_dropdown($id, $label, $content, $instructions=NULL, $blank_select=FALSE, $selected=NULL) { - common_element_start('p'); - common_element('label', array('for' => $id), $label); - common_element_start('select', array('id' => $id, 'name' => $id)); - if ($blank_select) { - common_element('option', array('value' => '')); - } - foreach ($content as $value => $option) { - if ($value == $selected) { - common_element('option', array('value' => $value, 'selected' => $value), $option); - } else { - common_element('option', array('value' => $value), $option); - } - } - common_element_end('select'); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); + common_element_start('p'); + $attrs = array('name' => $id, + 'type' => 'checkbox', + 'class' => 'checkbox', + 'id' => $id); + if ($value) { + $attrs['value'] = htmlspecialchars($value); + } + if ($checked) { + $attrs['checked'] = 'checked'; + } + if ($disabled) { + $attrs['disabled'] = 'true'; + } + common_element('input', $attrs); + common_text(' '); + common_element('label', array('class' => 'checkbox_label', 'for' => $id), $label); + common_text(' '); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); +} + +function common_dropdown($id, $label, $content, $instructions=null, $blank_select=FALSE, $selected=null) { + common_element_start('p'); + common_element('label', array('for' => $id), $label); + common_element_start('select', array('id' => $id, 'name' => $id)); + if ($blank_select) { + common_element('option', array('value' => '')); + } + foreach ($content as $value => $option) { + if ($value == $selected) { + common_element('option', array('value' => $value, 'selected' => $value), $option); + } else { + common_element('option', array('value' => $value), $option); + } + } + common_element_end('select'); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); } function common_hidden($id, $value) { - common_element('input', array('name' => $id, - 'type' => 'hidden', - 'id' => $id, - 'value' => $value)); -} - -function common_password($id, $label, $instructions=NULL) { - common_element_start('p'); - common_element('label', array('for' => $id), $label); - $attrs = array('name' => $id, - 'type' => 'password', - 'class' => 'password', - 'id' => $id); - common_element('input', $attrs); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); + common_element('input', array('name' => $id, + 'type' => 'hidden', + 'id' => $id, + 'value' => $value)); +} + +function common_password($id, $label, $instructions=null) { + common_element_start('p'); + common_element('label', array('for' => $id), $label); + $attrs = array('name' => $id, + 'type' => 'password', + 'class' => 'password', + 'id' => $id); + common_element('input', $attrs); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); } function common_submit($id, $label, $cls='submit') { - global $xw; - common_element_start('p'); - common_element('input', array('type' => 'submit', - 'id' => $id, - 'name' => $id, - 'class' => $cls, - 'value' => $label)); - common_element_end('p'); -} - -function common_textarea($id, $label, $content=NULL, $instructions=NULL) { - common_element_start('p'); - common_element('label', array('for' => $id), $label); - common_element('textarea', array('rows' => 3, - 'cols' => 40, - 'name' => $id, - 'id' => $id), - ($content) ? $content : ''); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); + global $xw; + common_element_start('p'); + common_element('input', array('type' => 'submit', + 'id' => $id, + 'name' => $id, + 'class' => $cls, + 'value' => $label)); + common_element_end('p'); +} + +function common_textarea($id, $label, $content=null, $instructions=null) { + common_element_start('p'); + common_element('label', array('for' => $id), $label); + common_element('textarea', array('rows' => 3, + 'cols' => 40, + 'name' => $id, + 'id' => $id), + ($content) ? $content : ''); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); } function common_timezone() { - if (common_logged_in()) { - $user = common_current_user(); - if ($user->timezone) { - return $user->timezone; - } - } + if (common_logged_in()) { + $user = common_current_user(); + if ($user->timezone) { + return $user->timezone; + } + } - global $config; - return $config['site']['timezone']; + global $config; + return $config['site']['timezone']; } function common_language() { - // If there is a user logged in and they've set a language preference - // then return that one... - if (common_logged_in()) { - $user = common_current_user(); - $user_language = $user->language; - if ($user_language) - return $user_language; - } + // If there is a user logged in and they've set a language preference + // then return that one... + if (common_logged_in()) { + $user = common_current_user(); + $user_language = $user->language; + if ($user_language) + return $user_language; + } - // Otherwise, find the best match for the languages requested by the - // user's browser... - $httplang = isset($_SERVER['HTTP_ACCEPT_LANGUAGE']) ? $_SERVER['HTTP_ACCEPT_LANGUAGE'] : NULL; - if (!empty($httplang)) { - $language = client_prefered_language($httplang); - if ($language) - return $language; - } + // Otherwise, find the best match for the languages requested by the + // user's browser... + $httplang = isset($_SERVER['HTTP_ACCEPT_LANGUAGE']) ? $_SERVER['HTTP_ACCEPT_LANGUAGE'] : null; + if (!empty($httplang)) { + $language = client_prefered_language($httplang); + if ($language) + return $language; + } - // Finally, if none of the above worked, use the site's default... - return common_config('site', 'language'); + // Finally, if none of the above worked, use the site's default... + return common_config('site', 'language'); } -# salted, hashed passwords are stored in the DB +// salted, hashed passwords are stored in the DB function common_munge_password($password, $id) { - return md5($password . $id); + return md5($password . $id); } -# check if a username exists and has matching password +// check if a username exists and has matching password function common_check_user($nickname, $password) { - # NEVER allow blank passwords, even if they match the DB - if (mb_strlen($password) == 0) { - return false; - } - $user = User::staticGet('nickname', $nickname); - if (is_null($user)) { - return false; - } else { - if (0 == strcmp(common_munge_password($password, $user->id), - $user->password)) { - return $user; - } else { - return false; - } - } -} - -# is the current user logged in? + // NEVER allow blank passwords, even if they match the DB + if (mb_strlen($password) == 0) { + return false; + } + $user = User::staticGet('nickname', $nickname); + if (is_null($user)) { + return false; + } else { + if (0 == strcmp(common_munge_password($password, $user->id), + $user->password)) { + return $user; + } else { + return false; + } + } +} + +// is the current user logged in? function common_logged_in() { - return (!is_null(common_current_user())); + return (!is_null(common_current_user())); } function common_have_session() { - return (0 != strcmp(session_id(), '')); + return (0 != strcmp(session_id(), '')); } function common_ensure_session() { - if (!common_have_session()) { - @session_start(); - } + if (!common_have_session()) { + @session_start(); + } } -# Three kinds of arguments: -# 1) a user object -# 2) a nickname -# 3) NULL to clear +// Three kinds of arguments: +// 1) a user object +// 2) a nickname +// 3) null to clear -# Initialize to false; set to NULL if none found +// Initialize to false; set to null if none found $_cur = false; @@ -572,92 +572,92 @@ function common_set_user($user) { global $_cur; - if (is_null($user) && common_have_session()) { - $_cur = NULL; - unset($_SESSION['userid']); - return true; - } else if (is_string($user)) { - $nickname = $user; - $user = User::staticGet('nickname', $nickname); - } else if (!($user instanceof User)) { - return false; - } - - if ($user) { - common_ensure_session(); - $_SESSION['userid'] = $user->id; + if (is_null($user) && common_have_session()) { + $_cur = null; + unset($_SESSION['userid']); + return true; + } else if (is_string($user)) { + $nickname = $user; + $user = User::staticGet('nickname', $nickname); + } else if (!($user instanceof User)) { + return false; + } + + if ($user) { + common_ensure_session(); + $_SESSION['userid'] = $user->id; $_cur = $user; - return $_cur; - } - return false; + return $_cur; + } + return false; } function common_set_cookie($key, $value, $expiration=0) { - $path = common_config('site', 'path'); - $server = common_config('site', 'server'); + $path = common_config('site', 'path'); + $server = common_config('site', 'server'); - if ($path && ($path != '/')) { - $cookiepath = '/' . $path . '/'; - } else { - $cookiepath = '/'; - } - return setcookie($key, - $value, - $expiration, - $cookiepath, - $server); + if ($path && ($path != '/')) { + $cookiepath = '/' . $path . '/'; + } else { + $cookiepath = '/'; + } + return setcookie($key, + $value, + $expiration, + $cookiepath, + $server); } define('REMEMBERME', 'rememberme'); -define('REMEMBERME_EXPIRY', 30 * 24 * 60 * 60); # 30 days +define('REMEMBERME_EXPIRY', 30 * 24 * 60 * 60); // 30 days -function common_rememberme($user=NULL) { - if (!$user) { - $user = common_current_user(); - if (!$user) { - common_debug('No current user to remember', __FILE__); - return false; - } - } +function common_rememberme($user=null) { + if (!$user) { + $user = common_current_user(); + if (!$user) { + common_debug('No current user to remember', __FILE__); + return false; + } + } - $rm = new Remember_me(); + $rm = new Remember_me(); - $rm->code = common_good_rand(16); - $rm->user_id = $user->id; + $rm->code = common_good_rand(16); + $rm->user_id = $user->id; - # Wrap the insert in some good ol' fashioned transaction code + // Wrap the insert in some good ol' fashioned transaction code $rm->query('BEGIN'); - $result = $rm->insert(); + $result = $rm->insert(); - if (!$result) { - common_log_db_error($rm, 'INSERT', __FILE__); - common_debug('Error adding rememberme record for ' . $user->nickname, __FILE__); - return false; + if (!$result) { + common_log_db_error($rm, 'INSERT', __FILE__); + common_debug('Error adding rememberme record for ' . $user->nickname, __FILE__); + return false; } $rm->query('COMMIT'); - common_debug('Inserted rememberme record (' . $rm->code . ', ' . $rm->user_id . '); result = ' . $result . '.', __FILE__); + common_debug('Inserted rememberme record (' . $rm->code . ', ' . $rm->user_id . '); result = ' . $result . '.', __FILE__); $cookieval = $rm->user_id . ':' . $rm->code; - common_log(LOG_INFO, 'adding rememberme cookie "' . $cookieval . '" for ' . $user->nickname); + common_log(LOG_INFO, 'adding rememberme cookie "' . $cookieval . '" for ' . $user->nickname); - common_set_cookie(REMEMBERME, $cookieval, time() + REMEMBERME_EXPIRY); + common_set_cookie(REMEMBERME, $cookieval, time() + REMEMBERME_EXPIRY); - return true; + return true; } function common_remembered_user() { - $user = NULL; + $user = null; - $packed = isset($_COOKIE[REMEMBERME]) ? $_COOKIE[REMEMBERME] : NULL; + $packed = isset($_COOKIE[REMEMBERME]) ? $_COOKIE[REMEMBERME] : null; - if (!$packed) { - return NULL; + if (!$packed) { + return null; } list($id, $code) = explode(':', $packed); @@ -665,7 +665,7 @@ function common_remembered_user() { if (!$id || !$code) { common_log(LOG_WARNING, 'Malformed rememberme cookie: ' . $packed); common_forgetme(); - return NULL; + return null; } $rm = Remember_me::staticGet($code); @@ -673,13 +673,13 @@ function common_remembered_user() { if (!$rm) { common_log(LOG_WARNING, 'No such remember code: ' . $code); common_forgetme(); - return NULL; + return null; } if ($rm->user_id != $id) { common_log(LOG_WARNING, 'Rememberme code for wrong user: ' . $rm->user_id . ' != ' . $id); common_forgetme(); - return NULL; + return null; } $user = User::staticGet($rm->user_id); @@ -687,17 +687,17 @@ function common_remembered_user() { if (!$user) { common_log(LOG_WARNING, 'No such user for rememberme: ' . $rm->user_id); common_forgetme(); - return NULL; + return null; } - # successful! + // successful! $result = $rm->delete(); if (!$result) { common_log_db_error($rm, 'DELETE', __FILE__); common_log(LOG_WARNING, 'Could not delete rememberme: ' . $code); common_forgetme(); - return NULL; + return null; } common_log(LOG_INFO, 'logging in ' . $user->nickname . ' using rememberme code ' . $rm->code); @@ -705,21 +705,21 @@ function common_remembered_user() { common_set_user($user); common_real_login(false); - # We issue a new cookie, so they can log in - # automatically again after this session + // We issue a new cookie, so they can log in + // automatically again after this session common_rememberme($user); - return $user; + return $user; } -# must be called with a valid user! +// must be called with a valid user! function common_forgetme() { - common_set_cookie(REMEMBERME, '', 0); + common_set_cookie(REMEMBERME, '', 0); } -# who is the current user? +// who is the current user? function common_current_user() { global $_cur; @@ -734,99 +734,99 @@ function common_current_user() { } } - # that didn't work; try to remember; will init $_cur to NULL on failure + // that didn't work; try to remember; will init $_cur to null on failure $_cur = common_remembered_user(); if ($_cur) { common_debug("Got User " . $_cur->nickname); common_debug("Faking session on remembered user"); - # XXX: Is this necessary? + // XXX: Is this necessary? $_SESSION['userid'] = $_cur->id; } } - return $_cur; + return $_cur; } -# Logins that are 'remembered' aren't 'real' -- they're subject to -# cookie-stealing. So, we don't let them do certain things. New reg, -# OpenID, and password logins _are_ real. +// Logins that are 'remembered' aren't 'real' -- they're subject to +// cookie-stealing. So, we don't let them do certain things. New reg, +// OpenID, and password logins _are_ real. function common_real_login($real=true) { - common_ensure_session(); - $_SESSION['real_login'] = $real; + common_ensure_session(); + $_SESSION['real_login'] = $real; } function common_is_real_login() { - return common_logged_in() && $_SESSION['real_login']; + return common_logged_in() && $_SESSION['real_login']; } -# get canonical version of nickname for comparison +// get canonical version of nickname for comparison function common_canonical_nickname($nickname) { - # XXX: UTF-8 canonicalization (like combining chars) - return strtolower($nickname); + // XXX: UTF-8 canonicalization (like combining chars) + return strtolower($nickname); } -# get canonical version of email for comparison +// get canonical version of email for comparison function common_canonical_email($email) { - # XXX: canonicalize UTF-8 - # XXX: lcase the domain part - return $email; + // XXX: canonicalize UTF-8 + // XXX: lcase the domain part + return $email; } define('URL_REGEX', '^|[ \t\r\n])((ftp|http|https|gopher|mailto|news|nntp|telnet|wais|file|prospero|aim|webcal):(([A-Za-z0-9$_.+!*(),;/?:@&~=-])|%[A-Fa-f0-9]{2}){2,}(#([a-zA-Z0-9][a-zA-Z0-9$_.+!*(),;/?:@&~=%-]*))?([A-Za-z0-9$_+!*();/?:~-]))'); function common_render_content($text, $notice) { - $r = common_render_text($text); - $id = $notice->profile_id; - $r = preg_replace('/(^|\s+)@([A-Za-z0-9]{1,64})/e', "'\\1@'.common_at_link($id, '\\2')", $r); - $r = preg_replace('/^T ([A-Z0-9]{1,64}) /e', "'T '.common_at_link($id, '\\1').' '", $r); - $r = preg_replace('/(^|\s+)@#([A-Za-z0-9]{1,64})/e', "'\\1@#'.common_at_hash_link($id, '\\2')", $r); - return $r; + $r = common_render_text($text); + $id = $notice->profile_id; + $r = preg_replace('/(^|\s+)@([A-Za-z0-9]{1,64})/e', "'\\1@'.common_at_link($id, '\\2')", $r); + $r = preg_replace('/^T ([A-Z0-9]{1,64}) /e', "'T '.common_at_link($id, '\\1').' '", $r); + $r = preg_replace('/(^|\s+)@#([A-Za-z0-9]{1,64})/e', "'\\1@#'.common_at_hash_link($id, '\\2')", $r); + return $r; } function common_render_text($text) { - $r = htmlspecialchars($text); + $r = htmlspecialchars($text); - $r = preg_replace('/[\x{0}-\x{8}\x{b}-\x{c}\x{e}-\x{19}]/', '', $r); - $r = preg_replace_callback('@https?://[^\]>\s]+@', 'common_render_uri_thingy', $r); - $r = preg_replace('/(^|\s+)#([A-Za-z0-9_\-\.]{1,64})/e', "'\\1#'.common_tag_link('\\2')", $r); - # XXX: machine tags - return $r; + $r = preg_replace('/[\x{0}-\x{8}\x{b}-\x{c}\x{e}-\x{19}]/', '', $r); + $r = preg_replace_callback('@https?://[^\]>\s]+@', 'common_render_uri_thingy', $r); + $r = preg_replace('/(^|\s+)#([A-Za-z0-9_\-\.]{1,64})/e', "'\\1#'.common_tag_link('\\2')", $r); + // XXX: machine tags + return $r; } function common_render_uri_thingy($matches) { - $uri = $matches[0]; - $trailer = ''; - - # Some heuristics for extracting URIs from surrounding punctuation - # Strip from trailing text... - if (preg_match('/^(.*)([,.:"\']+)$/', $uri, $matches)) { - $uri = $matches[1]; - $trailer = $matches[2]; - } - - $pairs = array( - ']' => '[', # technically disallowed in URIs, but used in Java docs - ')' => '(', # far too frequent in Wikipedia and MSDN - ); - $final = substr($uri, -1, 1); - if (isset($pairs[$final])) { - $openers = substr_count($uri, $pairs[$final]); - $closers = substr_count($uri, $final); - if ($closers > $openers) { - // Assume the paren was opened outside the URI - $uri = substr($uri, 0, -1); - $trailer = $final . $trailer; - } - } - if ($longurl = common_longurl($uri)) { - $longurl = htmlentities($longurl, ENT_QUOTES, 'UTF-8'); - $title = " title='$longurl'"; - } - else $title = ''; - - return '' . $uri . '' . $trailer; + $uri = $matches[0]; + $trailer = ''; + + // Some heuristics for extracting URIs from surrounding punctuation + // Strip from trailing text... + if (preg_match('/^(.*)([,.:"\']+)$/', $uri, $matches)) { + $uri = $matches[1]; + $trailer = $matches[2]; + } + + $pairs = array( + ']' => '[', // technically disallowed in URIs, but used in Java docs + ')' => '(', // far too frequent in Wikipedia and MSDN + ); + $final = substr($uri, -1, 1); + if (isset($pairs[$final])) { + $openers = substr_count($uri, $pairs[$final]); + $closers = substr_count($uri, $final); + if ($closers > $openers) { + // Assume the paren was opened outside the URI + $uri = substr($uri, 0, -1); + $trailer = $final . $trailer; + } + } + if ($longurl = common_longurl($uri)) { + $longurl = htmlentities($longurl, ENT_QUOTES, 'UTF-8'); + $title = " title='$longurl'"; + } + else $title = ''; + + return '' . $uri . '' . $trailer; } function common_longurl($short_url) { @@ -836,10 +836,10 @@ function common_longurl($short_url) { } function common_longurl2($uri) { - $uri_e = urlencode($uri); - $longurl = unserialize(file_get_contents("http://api.longurl.org/v1/expand?format=php&url=$uri_e")); - if (empty($longurl['long_url']) || $uri === $longurl['long_url']) return false; - return stripslashes($longurl['long_url']); + $uri_e = urlencode($uri); + $longurl = unserialize(file_get_contents("http://api.longurl.org/v1/expand?format=php&url=$uri_e")); + if (empty($longurl['long_url']) || $uri === $longurl['long_url']) return false; + return stripslashes($longurl['long_url']); } function common_shorten_links($text) { @@ -847,465 +847,465 @@ function common_shorten_links($text) { static $cache = array(); if (isset($cache[$text])) return $cache[$text]; // \s = not a horizontal whitespace character (since PHP 5.2.4) - return $cache[$text] = preg_replace('@https?://[^)\]>\s]+@e', "common_shorten_link('\\0')", $text); + return $cache[$text] = preg_replace('@https?://[^)\]>\s]+@e', "common_shorten_link('\\0')", $text); } function common_shorten_link($url, $reverse = false) { - static $url_cache = array(); + static $url_cache = array(); if ($reverse) return isset($url_cache[$url]) ? $url_cache[$url] : $url; - $user = common_current_user(); - - $curlh = curl_init(); - curl_setopt($curlh, CURLOPT_CONNECTTIMEOUT, 20); // # seconds to wait - curl_setopt($curlh, CURLOPT_USERAGENT, 'Laconica'); - curl_setopt($curlh, CURLOPT_RETURNTRANSFER, true); - - switch($user->urlshorteningservice) { - case 'ur1.ca': - $short_url_service = new LilUrl; - $short_url = $short_url_service->shorten($url); - break; - - case '2tu.us': - $short_url_service = new TightUrl; - $short_url = $short_url_service->shorten($url); - break; - - case 'ptiturl.com': - $short_url_service = new PtitUrl; - $short_url = $short_url_service->shorten($url); - break; - - case 'bit.ly': - curl_setopt($curlh, CURLOPT_URL, 'http://bit.ly/api?method=shorten&long_url='.urlencode($url)); - $short_url = current(json_decode(curl_exec($curlh))->results)->hashUrl; - break; - - case 'is.gd': - curl_setopt($curlh, CURLOPT_URL, 'http://is.gd/api.php?longurl='.urlencode($url)); - $short_url = curl_exec($curlh); - break; - case 'snipr.com': - curl_setopt($curlh, CURLOPT_URL, 'http://snipr.com/site/snip?r=simple&link='.urlencode($url)); - $short_url = curl_exec($curlh); - break; - case 'metamark.net': - curl_setopt($curlh, CURLOPT_URL, 'http://metamark.net/api/rest/simple?long_url='.urlencode($url)); - $short_url = curl_exec($curlh); - break; - case 'tinyurl.com': - curl_setopt($curlh, CURLOPT_URL, 'http://tinyurl.com/api-create.php?url='.urlencode($url)); - $short_url = curl_exec($curlh); - break; - default: - $short_url = false; - } - - curl_close($curlh); - - if ($short_url) { + $user = common_current_user(); + + $curlh = curl_init(); + curl_setopt($curlh, CURLOPT_CONNECTTIMEOUT, 20); // # seconds to wait + curl_setopt($curlh, CURLOPT_USERAGENT, 'Laconica'); + curl_setopt($curlh, CURLOPT_RETURNTRANSFER, true); + + switch($user->urlshorteningservice) { + case 'ur1.ca': + $short_url_service = new LilUrl; + $short_url = $short_url_service->shorten($url); + break; + + case '2tu.us': + $short_url_service = new TightUrl; + $short_url = $short_url_service->shorten($url); + break; + + case 'ptiturl.com': + $short_url_service = new PtitUrl; + $short_url = $short_url_service->shorten($url); + break; + + case 'bit.ly': + curl_setopt($curlh, CURLOPT_URL, 'http://bit.ly/api?method=shorten&long_url='.urlencode($url)); + $short_url = current(json_decode(curl_exec($curlh))->results)->hashUrl; + break; + + case 'is.gd': + curl_setopt($curlh, CURLOPT_URL, 'http://is.gd/api.php?longurl='.urlencode($url)); + $short_url = curl_exec($curlh); + break; + case 'snipr.com': + curl_setopt($curlh, CURLOPT_URL, 'http://snipr.com/site/snip?r=simple&link='.urlencode($url)); + $short_url = curl_exec($curlh); + break; + case 'metamark.net': + curl_setopt($curlh, CURLOPT_URL, 'http://metamark.net/api/rest/simple?long_url='.urlencode($url)); + $short_url = curl_exec($curlh); + break; + case 'tinyurl.com': + curl_setopt($curlh, CURLOPT_URL, 'http://tinyurl.com/api-create.php?url='.urlencode($url)); + $short_url = curl_exec($curlh); + break; + default: + $short_url = false; + } + + curl_close($curlh); + + if ($short_url) { $url_cache[(string)$short_url] = $url; - return (string)$short_url; - } - return $url; + return (string)$short_url; + } + return $url; } function common_xml_safe_str($str) { - $xmlStr = htmlentities(iconv('UTF-8', 'UTF-8//IGNORE', $str), ENT_NOQUOTES, 'UTF-8'); + $xmlStr = htmlentities(iconv('UTF-8', 'UTF-8//IGNORE', $str), ENT_NOQUOTES, 'UTF-8'); - // Replace control, formatting, and surrogate characters with '*', ala Twitter - return preg_replace('/[\p{Cc}\p{Cf}\p{Cs}]/u', '*', $str); + // Replace control, formatting, and surrogate characters with '*', ala Twitter + return preg_replace('/[\p{Cc}\p{Cf}\p{Cs}]/u', '*', $str); } function common_tag_link($tag) { - $canonical = common_canonical_tag($tag); - $url = common_local_url('tag', array('tag' => $canonical)); - return ''; + $canonical = common_canonical_tag($tag); + $url = common_local_url('tag', array('tag' => $canonical)); + return ''; } function common_canonical_tag($tag) { - return strtolower(str_replace(array('-', '_', '.'), '', $tag)); + return strtolower(str_replace(array('-', '_', '.'), '', $tag)); } function common_valid_profile_tag($str) { - return preg_match('/^[A-Za-z0-9_\-\.]{1,64}$/', $str); + return preg_match('/^[A-Za-z0-9_\-\.]{1,64}$/', $str); } function common_at_link($sender_id, $nickname) { - $sender = Profile::staticGet($sender_id); - $recipient = common_relative_profile($sender, common_canonical_nickname($nickname)); - if ($recipient) { - return ''.$nickname.''; - } else { - return $nickname; - } + $sender = Profile::staticGet($sender_id); + $recipient = common_relative_profile($sender, common_canonical_nickname($nickname)); + if ($recipient) { + return ''.$nickname.''; + } else { + return $nickname; + } } function common_at_hash_link($sender_id, $tag) { - $user = User::staticGet($sender_id); - if (!$user) { - return $tag; - } - $tagged = Profile_tag::getTagged($user->id, common_canonical_tag($tag)); - if ($tagged) { - $url = common_local_url('subscriptions', - array('nickname' => $user->nickname, - 'tag' => $tag)); - return ''.$tag.''; - } else { - return $tag; - } -} - -function common_relative_profile($sender, $nickname, $dt=NULL) { - # Try to find profiles this profile is subscribed to that have this nickname - $recipient = new Profile(); - # XXX: use a join instead of a subquery - $recipient->whereAdd('EXISTS (SELECT subscribed from subscription where subscriber = '.$sender->id.' and subscribed = id)', 'AND'); - $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); - if ($recipient->find(TRUE)) { - # XXX: should probably differentiate between profiles with - # the same name by date of most recent update - return $recipient; - } - # Try to find profiles that listen to this profile and that have this nickname - $recipient = new Profile(); - # XXX: use a join instead of a subquery - $recipient->whereAdd('EXISTS (SELECT subscriber from subscription where subscribed = '.$sender->id.' and subscriber = id)', 'AND'); - $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); - if ($recipient->find(TRUE)) { - # XXX: should probably differentiate between profiles with - # the same name by date of most recent update - return $recipient; - } - # If this is a local user, try to find a local user with that nickname. - $sender = User::staticGet($sender->id); - if ($sender) { - $recipient_user = User::staticGet('nickname', $nickname); - if ($recipient_user) { - return $recipient_user->getProfile(); - } - } - # Otherwise, no links. @messages from local users to remote users, - # or from remote users to other remote users, are just - # outside our ability to make intelligent guesses about - return NULL; + $user = User::staticGet($sender_id); + if (!$user) { + return $tag; + } + $tagged = Profile_tag::getTagged($user->id, common_canonical_tag($tag)); + if ($tagged) { + $url = common_local_url('subscriptions', + array('nickname' => $user->nickname, + 'tag' => $tag)); + return ''.$tag.''; + } else { + return $tag; + } +} + +function common_relative_profile($sender, $nickname, $dt=null) { + // Try to find profiles this profile is subscribed to that have this nickname + $recipient = new Profile(); + // XXX: use a join instead of a subquery + $recipient->whereAdd('EXISTS (SELECT subscribed from subscription where subscriber = '.$sender->id.' and subscribed = id)', 'AND'); + $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); + if ($recipient->find(TRUE)) { + // XXX: should probably differentiate between profiles with + // the same name by date of most recent update + return $recipient; + } + // Try to find profiles that listen to this profile and that have this nickname + $recipient = new Profile(); + // XXX: use a join instead of a subquery + $recipient->whereAdd('EXISTS (SELECT subscriber from subscription where subscribed = '.$sender->id.' and subscriber = id)', 'AND'); + $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); + if ($recipient->find(TRUE)) { + // XXX: should probably differentiate between profiles with + // the same name by date of most recent update + return $recipient; + } + // If this is a local user, try to find a local user with that nickname. + $sender = User::staticGet($sender->id); + if ($sender) { + $recipient_user = User::staticGet('nickname', $nickname); + if ($recipient_user) { + return $recipient_user->getProfile(); + } + } + // Otherwise, no links. @messages from local users to remote users, + // or from remote users to other remote users, are just + // outside our ability to make intelligent guesses about + return null; } // where should the avatar go for this user? -function common_avatar_filename($id, $extension, $size=NULL, $extra=NULL) { - global $config; +function common_avatar_filename($id, $extension, $size=null, $extra=null) { + global $config; - if ($size) { - return $id . '-' . $size . (($extra) ? ('-' . $extra) : '') . $extension; - } else { - return $id . '-original' . (($extra) ? ('-' . $extra) : '') . $extension; - } + if ($size) { + return $id . '-' . $size . (($extra) ? ('-' . $extra) : '') . $extension; + } else { + return $id . '-original' . (($extra) ? ('-' . $extra) : '') . $extension; + } } function common_avatar_path($filename) { - global $config; - return INSTALLDIR . '/avatar/' . $filename; + global $config; + return INSTALLDIR . '/avatar/' . $filename; } function common_avatar_url($filename) { - return common_path('avatar/'.$filename); + return common_path('avatar/'.$filename); } function common_avatar_display_url($avatar) { - $server = common_config('avatar', 'server'); - if ($server) { - return 'http://'.$server.'/'.$avatar->filename; - } else { - return $avatar->url; - } + $server = common_config('avatar', 'server'); + if ($server) { + return 'http://'.$server.'/'.$avatar->filename; + } else { + return $avatar->url; + } } function common_default_avatar($size) { - static $sizenames = array(AVATAR_PROFILE_SIZE => 'profile', - AVATAR_STREAM_SIZE => 'stream', - AVATAR_MINI_SIZE => 'mini'); - return theme_path('default-avatar-'.$sizenames[$size].'.png'); -} - -function common_local_url($action, $args=NULL, $fragment=NULL) { - $url = NULL; - if (common_config('site','fancy')) { - $url = common_fancy_url($action, $args); - } else { - $url = common_simple_url($action, $args); - } - if (!is_null($fragment)) { - $url .= '#'.$fragment; - } - return $url; -} - -function common_fancy_url($action, $args=NULL) { - switch (strtolower($action)) { - case 'public': - if ($args && isset($args['page'])) { - return common_path('?page=' . $args['page']); - } else { - return common_path(''); - } - case 'featured': - if ($args && isset($args['page'])) { - return common_path('featured?page=' . $args['page']); - } else { - return common_path('featured'); - } - case 'favorited': - if ($args && isset($args['page'])) { - return common_path('favorited?page=' . $args['page']); - } else { - return common_path('favorited'); - } - case 'publicrss': - return common_path('rss'); - case 'publicatom': - return common_path("api/statuses/public_timeline.atom"); - case 'publicxrds': - return common_path('xrds'); - case 'featuredrss': - return common_path('featuredrss'); - case 'favoritedrss': - return common_path('favoritedrss'); - case 'opensearch': - if ($args && $args['type']) { - return common_path('opensearch/'.$args['type']); - } else { - return common_path('opensearch/people'); - } - case 'doc': - return common_path('doc/'.$args['title']); + static $sizenames = array(AVATAR_PROFILE_SIZE => 'profile', + AVATAR_STREAM_SIZE => 'stream', + AVATAR_MINI_SIZE => 'mini'); + return theme_path('default-avatar-'.$sizenames[$size].'.png'); +} + +function common_local_url($action, $args=null, $fragment=null) { + $url = null; + if (common_config('site','fancy')) { + $url = common_fancy_url($action, $args); + } else { + $url = common_simple_url($action, $args); + } + if (!is_null($fragment)) { + $url .= '#'.$fragment; + } + return $url; +} + +function common_fancy_url($action, $args=null) { + switch (strtolower($action)) { + case 'public': + if ($args && isset($args['page'])) { + return common_path('?page=' . $args['page']); + } else { + return common_path(''); + } + case 'featured': + if ($args && isset($args['page'])) { + return common_path('featured?page=' . $args['page']); + } else { + return common_path('featured'); + } + case 'favorited': + if ($args && isset($args['page'])) { + return common_path('favorited?page=' . $args['page']); + } else { + return common_path('favorited'); + } + case 'publicrss': + return common_path('rss'); + case 'publicatom': + return common_path("api/statuses/public_timeline.atom"); + case 'publicxrds': + return common_path('xrds'); + case 'featuredrss': + return common_path('featuredrss'); + case 'favoritedrss': + return common_path('favoritedrss'); + case 'opensearch': + if ($args && $args['type']) { + return common_path('opensearch/'.$args['type']); + } else { + return common_path('opensearch/people'); + } + case 'doc': + return common_path('doc/'.$args['title']); case 'block': - case 'login': - case 'logout': - case 'subscribe': - case 'unsubscribe': - case 'invite': - return common_path('main/'.$action); - case 'tagother': - return common_path('main/tagother?id='.$args['id']); - case 'register': - if ($args && $args['code']) { - return common_path('main/register/'.$args['code']); - } else { - return common_path('main/register'); - } - case 'remotesubscribe': - if ($args && $args['nickname']) { - return common_path('main/remote?nickname=' . $args['nickname']); - } else { - return common_path('main/remote'); - } - case 'nudge': - return common_path($args['nickname'].'/nudge'); - case 'openidlogin': - return common_path('main/openid'); - case 'profilesettings': - return common_path('settings/profile'); - case 'emailsettings': - return common_path('settings/email'); - case 'openidsettings': - return common_path('settings/openid'); - case 'smssettings': - return common_path('settings/sms'); - case 'twittersettings': - return common_path('settings/twitter'); - case 'othersettings': - return common_path('settings/other'); + case 'login': + case 'logout': + case 'subscribe': + case 'unsubscribe': + case 'invite': + return common_path('main/'.$action); + case 'tagother': + return common_path('main/tagother?id='.$args['id']); + case 'register': + if ($args && $args['code']) { + return common_path('main/register/'.$args['code']); + } else { + return common_path('main/register'); + } + case 'remotesubscribe': + if ($args && $args['nickname']) { + return common_path('main/remote?nickname=' . $args['nickname']); + } else { + return common_path('main/remote'); + } + case 'nudge': + return common_path($args['nickname'].'/nudge'); + case 'openidlogin': + return common_path('main/openid'); + case 'profilesettings': + return common_path('settings/profile'); + case 'emailsettings': + return common_path('settings/email'); + case 'openidsettings': + return common_path('settings/openid'); + case 'smssettings': + return common_path('settings/sms'); + case 'twittersettings': + return common_path('settings/twitter'); + case 'othersettings': + return common_path('settings/other'); case 'deleteprofile': return common_path('settings/delete'); - case 'newnotice': - if ($args && $args['replyto']) { - return common_path('notice/new?replyto='.$args['replyto']); - } else { - return common_path('notice/new'); - } - case 'shownotice': - return common_path('notice/'.$args['notice']); - case 'deletenotice': - if ($args && $args['notice']) { - return common_path('notice/delete/'.$args['notice']); - } else { - return common_path('notice/delete'); - } - case 'microsummary': - case 'xrds': - case 'foaf': - return common_path($args['nickname'].'/'.$action); - case 'all': - case 'replies': - case 'inbox': - case 'outbox': - if ($args && isset($args['page'])) { - return common_path($args['nickname'].'/'.$action.'?page=' . $args['page']); - } else { - return common_path($args['nickname'].'/'.$action); - } - case 'subscriptions': - case 'subscribers': - $nickname = $args['nickname']; - unset($args['nickname']); - if (isset($args['tag'])) { - $tag = $args['tag']; - unset($args['tag']); - } - $params = http_build_query($args); - if ($params) { - return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '') . '?' . $params); - } else { - return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '')); - } - case 'allrss': - return common_path($args['nickname'].'/all/rss'); - case 'repliesrss': - return common_path($args['nickname'].'/replies/rss'); - case 'userrss': + case 'newnotice': + if ($args && $args['replyto']) { + return common_path('notice/new?replyto='.$args['replyto']); + } else { + return common_path('notice/new'); + } + case 'shownotice': + return common_path('notice/'.$args['notice']); + case 'deletenotice': + if ($args && $args['notice']) { + return common_path('notice/delete/'.$args['notice']); + } else { + return common_path('notice/delete'); + } + case 'microsummary': + case 'xrds': + case 'foaf': + return common_path($args['nickname'].'/'.$action); + case 'all': + case 'replies': + case 'inbox': + case 'outbox': + if ($args && isset($args['page'])) { + return common_path($args['nickname'].'/'.$action.'?page=' . $args['page']); + } else { + return common_path($args['nickname'].'/'.$action); + } + case 'subscriptions': + case 'subscribers': + $nickname = $args['nickname']; + unset($args['nickname']); + if (isset($args['tag'])) { + $tag = $args['tag']; + unset($args['tag']); + } + $params = http_build_query($args); + if ($params) { + return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '') . '?' . $params); + } else { + return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '')); + } + case 'allrss': + return common_path($args['nickname'].'/all/rss'); + case 'repliesrss': + return common_path($args['nickname'].'/replies/rss'); + case 'userrss': if (isset($args['limit'])) - return common_path($args['nickname'].'/rss?limit=' . $args['limit']); - return common_path($args['nickname'].'/rss'); - case 'showstream': - if ($args && isset($args['page'])) { - return common_path($args['nickname'].'?page=' . $args['page']); - } else { - return common_path($args['nickname']); - } - - case 'usertimeline': - return common_path("api/statuses/user_timeline/".$args['nickname'].".atom"); - case 'confirmaddress': - return common_path('main/confirmaddress/'.$args['code']); - case 'userbyid': - return common_path('user/'.$args['id']); - case 'recoverpassword': - $path = 'main/recoverpassword'; - if ($args['code']) { - $path .= '/' . $args['code']; - } - return common_path($path); - case 'imsettings': - return common_path('settings/im'); - case 'peoplesearch': - return common_path('search/people' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'noticesearch': - return common_path('search/notice' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'noticesearchrss': - return common_path('search/notice/rss' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'avatarbynickname': - return common_path($args['nickname'].'/avatar/'.$args['size']); - case 'tag': - if (isset($args['tag']) && $args['tag']) { - $path = 'tag/' . $args['tag']; - unset($args['tag']); - } else { - $path = 'tags'; - } - return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); - case 'peopletag': - $path = 'peopletag/' . $args['tag']; - unset($args['tag']); - return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); - case 'tags': - return common_path('tags' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'favor': - return common_path('main/favor'); - case 'disfavor': - return common_path('main/disfavor'); - case 'showfavorites': - if ($args && isset($args['page'])) { - return common_path($args['nickname'].'/favorites?page=' . $args['page']); - } else { - return common_path($args['nickname'].'/favorites'); - } - case 'favoritesrss': - return common_path($args['nickname'].'/favorites/rss'); - case 'showmessage': - return common_path('message/' . $args['message']); - case 'newmessage': - return common_path('message/new' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'api': - # XXX: do fancy URLs for all the API methods - switch (strtolower($args['apiaction'])) { - case 'statuses': - switch (strtolower($args['method'])) { - case 'user_timeline.rss': - return common_path('api/statuses/user_timeline/'.$args['argument'].'.rss'); - case 'user_timeline.atom': - return common_path('api/statuses/user_timeline/'.$args['argument'].'.atom'); - case 'user_timeline.json': - return common_path('api/statuses/user_timeline/'.$args['argument'].'.json'); - case 'user_timeline.xml': - return common_path('api/statuses/user_timeline/'.$args['argument'].'.xml'); - default: return common_simple_url($action, $args); - } - default: return common_simple_url($action, $args); - } - case 'sup': - if ($args && isset($args['seconds'])) { - return common_path('main/sup?seconds='.$args['seconds']); - } else { - return common_path('main/sup'); - } - default: - return common_simple_url($action, $args); - } -} - -function common_simple_url($action, $args=NULL) { - global $config; - /* XXX: pretty URLs */ - $extra = ''; - if ($args) { - foreach ($args as $key => $value) { - $extra .= "&${key}=${value}"; - } - } - return common_path("index.php?action=${action}${extra}"); + return common_path($args['nickname'].'/rss?limit=' . $args['limit']); + return common_path($args['nickname'].'/rss'); + case 'showstream': + if ($args && isset($args['page'])) { + return common_path($args['nickname'].'?page=' . $args['page']); + } else { + return common_path($args['nickname']); + } + + case 'usertimeline': + return common_path("api/statuses/user_timeline/".$args['nickname'].".atom"); + case 'confirmaddress': + return common_path('main/confirmaddress/'.$args['code']); + case 'userbyid': + return common_path('user/'.$args['id']); + case 'recoverpassword': + $path = 'main/recoverpassword'; + if ($args['code']) { + $path .= '/' . $args['code']; + } + return common_path($path); + case 'imsettings': + return common_path('settings/im'); + case 'peoplesearch': + return common_path('search/people' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'noticesearch': + return common_path('search/notice' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'noticesearchrss': + return common_path('search/notice/rss' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'avatarbynickname': + return common_path($args['nickname'].'/avatar/'.$args['size']); + case 'tag': + if (isset($args['tag']) && $args['tag']) { + $path = 'tag/' . $args['tag']; + unset($args['tag']); + } else { + $path = 'tags'; + } + return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); + case 'peopletag': + $path = 'peopletag/' . $args['tag']; + unset($args['tag']); + return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); + case 'tags': + return common_path('tags' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'favor': + return common_path('main/favor'); + case 'disfavor': + return common_path('main/disfavor'); + case 'showfavorites': + if ($args && isset($args['page'])) { + return common_path($args['nickname'].'/favorites?page=' . $args['page']); + } else { + return common_path($args['nickname'].'/favorites'); + } + case 'favoritesrss': + return common_path($args['nickname'].'/favorites/rss'); + case 'showmessage': + return common_path('message/' . $args['message']); + case 'newmessage': + return common_path('message/new' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'api': + // XXX: do fancy URLs for all the API methods + switch (strtolower($args['apiaction'])) { + case 'statuses': + switch (strtolower($args['method'])) { + case 'user_timeline.rss': + return common_path('api/statuses/user_timeline/'.$args['argument'].'.rss'); + case 'user_timeline.atom': + return common_path('api/statuses/user_timeline/'.$args['argument'].'.atom'); + case 'user_timeline.json': + return common_path('api/statuses/user_timeline/'.$args['argument'].'.json'); + case 'user_timeline.xml': + return common_path('api/statuses/user_timeline/'.$args['argument'].'.xml'); + default: return common_simple_url($action, $args); + } + default: return common_simple_url($action, $args); + } + case 'sup': + if ($args && isset($args['seconds'])) { + return common_path('main/sup?seconds='.$args['seconds']); + } else { + return common_path('main/sup'); + } + default: + return common_simple_url($action, $args); + } +} + +function common_simple_url($action, $args=null) { + global $config; + /* XXX: pretty URLs */ + $extra = ''; + if ($args) { + foreach ($args as $key => $value) { + $extra .= "&${key}=${value}"; + } + } + return common_path("index.php?action=${action}${extra}"); } function common_path($relative) { - global $config; - $pathpart = ($config['site']['path']) ? $config['site']['path']."/" : ''; - return "http://".$config['site']['server'].'/'.$pathpart.$relative; + global $config; + $pathpart = ($config['site']['path']) ? $config['site']['path']."/" : ''; + return "http://".$config['site']['server'].'/'.$pathpart.$relative; } function common_date_string($dt) { - // XXX: do some sexy date formatting - // return date(DATE_RFC822, $dt); - $t = strtotime($dt); - $now = time(); - $diff = $now - $t; - - if ($now < $t) { # that shouldn't happen! - return common_exact_date($dt); - } else if ($diff < 60) { - return _('a few seconds ago'); - } else if ($diff < 92) { - return _('about a minute ago'); - } else if ($diff < 3300) { - return sprintf(_('about %d minutes ago'), round($diff/60)); - } else if ($diff < 5400) { - return _('about an hour ago'); - } else if ($diff < 22 * 3600) { - return sprintf(_('about %d hours ago'), round($diff/3600)); - } else if ($diff < 37 * 3600) { - return _('about a day ago'); - } else if ($diff < 24 * 24 * 3600) { - return sprintf(_('about %d days ago'), round($diff/(24*3600))); - } else if ($diff < 46 * 24 * 3600) { - return _('about a month ago'); - } else if ($diff < 330 * 24 * 3600) { - return sprintf(_('about %d months ago'), round($diff/(30*24*3600))); - } else if ($diff < 480 * 24 * 3600) { - return _('about a year ago'); - } else { - return common_exact_date($dt); - } + // XXX: do some sexy date formatting + // return date(DATE_RFC822, $dt); + $t = strtotime($dt); + $now = time(); + $diff = $now - $t; + + if ($now < $t) { // that shouldn't happen! + return common_exact_date($dt); + } else if ($diff < 60) { + return _('a few seconds ago'); + } else if ($diff < 92) { + return _('about a minute ago'); + } else if ($diff < 3300) { + return sprintf(_('about %d minutes ago'), round($diff/60)); + } else if ($diff < 5400) { + return _('about an hour ago'); + } else if ($diff < 22 * 3600) { + return sprintf(_('about %d hours ago'), round($diff/3600)); + } else if ($diff < 37 * 3600) { + return _('about a day ago'); + } else if ($diff < 24 * 24 * 3600) { + return sprintf(_('about %d days ago'), round($diff/(24*3600))); + } else if ($diff < 46 * 24 * 3600) { + return _('about a month ago'); + } else if ($diff < 330 * 24 * 3600) { + return sprintf(_('about %d months ago'), round($diff/(30*24*3600))); + } else if ($diff < 480 * 24 * 3600) { + return _('about a year ago'); + } else { + return common_exact_date($dt); + } } function common_exact_date($dt) { @@ -1317,885 +1317,885 @@ function common_exact_date($dt) { $_siteTz = new DateTimeZone(common_timezone()); } - $dateStr = date('d F Y H:i:s', strtotime($dt)); - $d = new DateTime($dateStr, $_utc); - $d->setTimezone($_siteTz); - return $d->format(DATE_RFC850); + $dateStr = date('d F Y H:i:s', strtotime($dt)); + $d = new DateTime($dateStr, $_utc); + $d->setTimezone($_siteTz); + return $d->format(DATE_RFC850); } function common_date_w3dtf($dt) { - $dateStr = date('d F Y H:i:s', strtotime($dt)); - $d = new DateTime($dateStr, new DateTimeZone('UTC')); - $d->setTimezone(new DateTimeZone(common_timezone())); - return $d->format(DATE_W3C); + $dateStr = date('d F Y H:i:s', strtotime($dt)); + $d = new DateTime($dateStr, new DateTimeZone('UTC')); + $d->setTimezone(new DateTimeZone(common_timezone())); + return $d->format(DATE_W3C); } function common_date_rfc2822($dt) { - $dateStr = date('d F Y H:i:s', strtotime($dt)); - $d = new DateTime($dateStr, new DateTimeZone('UTC')); - $d->setTimezone(new DateTimeZone(common_timezone())); - return $d->format('r'); + $dateStr = date('d F Y H:i:s', strtotime($dt)); + $d = new DateTime($dateStr, new DateTimeZone('UTC')); + $d->setTimezone(new DateTimeZone(common_timezone())); + return $d->format('r'); } function common_date_iso8601($dt) { - $dateStr = date('d F Y H:i:s', strtotime($dt)); - $d = new DateTime($dateStr, new DateTimeZone('UTC')); - $d->setTimezone(new DateTimeZone(common_timezone())); - return $d->format('c'); + $dateStr = date('d F Y H:i:s', strtotime($dt)); + $d = new DateTime($dateStr, new DateTimeZone('UTC')); + $d->setTimezone(new DateTimeZone(common_timezone())); + return $d->format('c'); } function common_sql_now() { - return strftime('%Y-%m-%d %H:%M:%S', time()); + return strftime('%Y-%m-%d %H:%M:%S', time()); } function common_redirect($url, $code=307) { - static $status = array(301 => "Moved Permanently", - 302 => "Found", - 303 => "See Other", - 307 => "Temporary Redirect"); - header("Status: ${code} $status[$code]"); - header("Location: $url"); - - common_start_xml('a', - '-//W3C//DTD XHTML 1.0 Strict//EN', - 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'); - common_element('a', array('href' => $url), $url); - common_end_xml(); + static $status = array(301 => "Moved Permanently", + 302 => "Found", + 303 => "See Other", + 307 => "Temporary Redirect"); + header("Status: ${code} $status[$code]"); + header("Location: $url"); + + common_start_xml('a', + '-//W3C//DTD XHTML 1.0 Strict//EN', + 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'); + common_element('a', array('href' => $url), $url); + common_end_xml(); exit; } function common_save_replies($notice) { - # Alternative reply format - $tname = false; - if (preg_match('/^T ([A-Z0-9]{1,64}) /', $notice->content, $match)) { - $tname = $match[1]; - } - # extract all @messages - $cnt = preg_match_all('/(?:^|\s)@([a-z0-9]{1,64})/', $notice->content, $match); - - $names = array(); - - if ($cnt || $tname) { - # XXX: is there another way to make an array copy? - $names = ($tname) ? array_unique(array_merge(array(strtolower($tname)), $match[1])) : array_unique($match[1]); - } - - $sender = Profile::staticGet($notice->profile_id); - - $replied = array(); - - # store replied only for first @ (what user/notice what the reply directed, - # we assume first @ is it) - - for ($i=0; $icreated); - if (!$recipient) { - continue; - } - if ($i == 0 && ($recipient->id != $sender->id) && !$notice->reply_to) { # Don't save reply to self - $reply_for = $recipient; - $recipient_notice = $reply_for->getCurrentNotice(); - if ($recipient_notice) { - $orig = clone($notice); - $notice->reply_to = $recipient_notice->id; - $notice->update($orig); - } - } - # Don't save replies from blocked profile to local user + // Alternative reply format + $tname = false; + if (preg_match('/^T ([A-Z0-9]{1,64}) /', $notice->content, $match)) { + $tname = $match[1]; + } + // extract all @messages + $cnt = preg_match_all('/(?:^|\s)@([a-z0-9]{1,64})/', $notice->content, $match); + + $names = array(); + + if ($cnt || $tname) { + // XXX: is there another way to make an array copy? + $names = ($tname) ? array_unique(array_merge(array(strtolower($tname)), $match[1])) : array_unique($match[1]); + } + + $sender = Profile::staticGet($notice->profile_id); + + $replied = array(); + + // store replied only for first @ (what user/notice what the reply directed, + // we assume first @ is it) + + for ($i=0; $icreated); + if (!$recipient) { + continue; + } + if ($i == 0 && ($recipient->id != $sender->id) && !$notice->reply_to) { // Don't save reply to self + $reply_for = $recipient; + $recipient_notice = $reply_for->getCurrentNotice(); + if ($recipient_notice) { + $orig = clone($notice); + $notice->reply_to = $recipient_notice->id; + $notice->update($orig); + } + } + // Don't save replies from blocked profile to local user $recipient_user = User::staticGet('id', $recipient->id); if ($recipient_user && $recipient_user->hasBlocked($sender)) { continue; } - $reply = new Reply(); - $reply->notice_id = $notice->id; - $reply->profile_id = $recipient->id; - $id = $reply->insert(); - if (!$id) { - $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); - common_log(LOG_ERR, 'DB error inserting reply: ' . $last_error->message); - common_server_error(sprintf(_('DB error inserting reply: %s'), $last_error->message)); - return; - } else { - $replied[$recipient->id] = 1; - } - } - - # Hash format replies, too - $cnt = preg_match_all('/(?:^|\s)@#([a-z0-9]{1,64})/', $notice->content, $match); - if ($cnt) { - foreach ($match[1] as $tag) { - $tagged = Profile_tag::getTagged($sender->id, $tag); - foreach ($tagged as $t) { - if (!$replied[$t->id]) { - # Don't save replies from blocked profile to local user + $reply = new Reply(); + $reply->notice_id = $notice->id; + $reply->profile_id = $recipient->id; + $id = $reply->insert(); + if (!$id) { + $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); + common_log(LOG_ERR, 'DB error inserting reply: ' . $last_error->message); + common_server_error(sprintf(_('DB error inserting reply: %s'), $last_error->message)); + return; + } else { + $replied[$recipient->id] = 1; + } + } + + // Hash format replies, too + $cnt = preg_match_all('/(?:^|\s)@#([a-z0-9]{1,64})/', $notice->content, $match); + if ($cnt) { + foreach ($match[1] as $tag) { + $tagged = Profile_tag::getTagged($sender->id, $tag); + foreach ($tagged as $t) { + if (!$replied[$t->id]) { + // Don't save replies from blocked profile to local user $t_user = User::staticGet('id', $t->id); if ($t_user && $t_user->hasBlocked($sender)) { continue; } - $reply = new Reply(); - $reply->notice_id = $notice->id; - $reply->profile_id = $t->id; - $id = $reply->insert(); - if (!$id) { - common_log_db_error($reply, 'INSERT', __FILE__); - return; - } - } - } - } - } + $reply = new Reply(); + $reply->notice_id = $notice->id; + $reply->profile_id = $t->id; + $id = $reply->insert(); + if (!$id) { + common_log_db_error($reply, 'INSERT', __FILE__); + return; + } + } + } + } + } } function common_broadcast_notice($notice, $remote=false) { - // Check to see if notice should go to Twitter - $flink = Foreign_link::getByUserID($notice->profile_id, 1); // 1 == Twitter - if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) { + // Check to see if notice should go to Twitter + $flink = Foreign_link::getByUserID($notice->profile_id, 1); // 1 == Twitter + if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) { - // If it's not a Twitter-style reply, or if the user WANTS to send replies... + // If it's not a Twitter-style reply, or if the user WANTS to send replies... - if (!preg_match('/^@[a-zA-Z0-9_]{1,15}\b/u', $notice->content) || - (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) { + if (!preg_match('/^@[a-zA-Z0-9_]{1,15}\b/u', $notice->content) || + (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) { - $result = common_twitter_broadcast($notice, $flink); + $result = common_twitter_broadcast($notice, $flink); - if (!$result) { - common_debug('Unable to send notice: ' . $notice->id . ' to Twitter.', __FILE__); - } - } - } + if (!$result) { + common_debug('Unable to send notice: ' . $notice->id . ' to Twitter.', __FILE__); + } + } + } - if (common_config('queue', 'enabled')) { - # Do it later! - return common_enqueue_notice($notice); - } else { - return common_real_broadcast($notice, $remote); - } + if (common_config('queue', 'enabled')) { + // Do it later! + return common_enqueue_notice($notice); + } else { + return common_real_broadcast($notice, $remote); + } } function common_twitter_broadcast($notice, $flink) { - global $config; - $success = true; - $fuser = $flink->getForeignUser(); - $twitter_user = $fuser->nickname; - $twitter_password = $flink->credentials; - $uri = 'http://www.twitter.com/statuses/update.json'; - - // XXX: Hack to get around PHP cURL's use of @ being a a meta character - $statustxt = preg_replace('/^@/', ' @', $notice->content); - - $options = array( - CURLOPT_USERPWD => "$twitter_user:$twitter_password", - CURLOPT_POST => true, - CURLOPT_POSTFIELDS => array( - 'status' => $statustxt, - 'source' => $config['integration']['source'] - ), - CURLOPT_RETURNTRANSFER => true, - CURLOPT_FAILONERROR => true, - CURLOPT_HEADER => false, - CURLOPT_FOLLOWLOCATION => true, - CURLOPT_USERAGENT => "Laconica", - CURLOPT_CONNECTTIMEOUT => 120, // XXX: Scary!!!! How long should this be? - CURLOPT_TIMEOUT => 120 - ); - - $ch = curl_init($uri); + global $config; + $success = true; + $fuser = $flink->getForeignUser(); + $twitter_user = $fuser->nickname; + $twitter_password = $flink->credentials; + $uri = 'http://www.twitter.com/statuses/update.json'; + + // XXX: Hack to get around PHP cURL's use of @ being a a meta character + $statustxt = preg_replace('/^@/', ' @', $notice->content); + + $options = array( + CURLOPT_USERPWD => "$twitter_user:$twitter_password", + CURLOPT_POST => true, + CURLOPT_POSTFIELDS => array( + 'status' => $statustxt, + 'source' => $config['integration']['source'] + ), + CURLOPT_RETURNTRANSFER => true, + CURLOPT_FAILONERROR => true, + CURLOPT_HEADER => false, + CURLOPT_FOLLOWLOCATION => true, + CURLOPT_USERAGENT => "Laconica", + CURLOPT_CONNECTTIMEOUT => 120, // XXX: Scary!!!! How long should this be? + CURLOPT_TIMEOUT => 120 + ); + + $ch = curl_init($uri); curl_setopt_array($ch, $options); $data = curl_exec($ch); $errmsg = curl_error($ch); - if ($errmsg) { - common_debug("cURL error: $errmsg - trying to send notice for $twitter_user.", - __FILE__); - $success = false; - } + if ($errmsg) { + common_debug("cURL error: $errmsg - trying to send notice for $twitter_user.", + __FILE__); + $success = false; + } - curl_close($ch); + curl_close($ch); - if (!$data) { - common_debug("No data returned by Twitter's API trying to send update for $twitter_user", - __FILE__); - $success = false; - } + if (!$data) { + common_debug("No data returned by Twitter's API trying to send update for $twitter_user", + __FILE__); + $success = false; + } - // Twitter should return a status - $status = json_decode($data); + // Twitter should return a status + $status = json_decode($data); - if (!$status->id) { - common_debug("Unexpected data returned by Twitter API trying to send update for $twitter_user", - __FILE__); - $success = false; - } + if (!$status->id) { + common_debug("Unexpected data returned by Twitter API trying to send update for $twitter_user", + __FILE__); + $success = false; + } - return $success; + return $success; } -# Stick the notice on the queue +// Stick the notice on the queue function common_enqueue_notice($notice) { - foreach (array('jabber', 'omb', 'sms', 'public') as $transport) { - $qi = new Queue_item(); - $qi->notice_id = $notice->id; - $qi->transport = $transport; - $qi->created = $notice->created; + foreach (array('jabber', 'omb', 'sms', 'public') as $transport) { + $qi = new Queue_item(); + $qi->notice_id = $notice->id; + $qi->transport = $transport; + $qi->created = $notice->created; $result = $qi->insert(); - if (!$result) { - $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); - common_log(LOG_ERR, 'DB error inserting queue item: ' . $last_error->message); - return false; - } - common_log(LOG_DEBUG, 'complete queueing notice ID = ' . $notice->id . ' for ' . $transport); - } - return $result; + if (!$result) { + $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); + common_log(LOG_ERR, 'DB error inserting queue item: ' . $last_error->message); + return false; + } + common_log(LOG_DEBUG, 'complete queueing notice ID = ' . $notice->id . ' for ' . $transport); + } + return $result; } function common_dequeue_notice($notice) { - $qi = Queue_item::staticGet($notice->id); - if ($qi) { - $result = $qi->delete(); - if (!$result) { - $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); - common_log(LOG_ERR, 'DB error deleting queue item: ' . $last_error->message); - return false; - } - common_log(LOG_DEBUG, 'complete dequeueing notice ID = ' . $notice->id); - return $result; - } else { + $qi = Queue_item::staticGet($notice->id); + if ($qi) { + $result = $qi->delete(); + if (!$result) { + $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); + common_log(LOG_ERR, 'DB error deleting queue item: ' . $last_error->message); return false; } + common_log(LOG_DEBUG, 'complete dequeueing notice ID = ' . $notice->id); + return $result; + } else { + return false; + } } function common_real_broadcast($notice, $remote=false) { - $success = true; - if (!$remote) { - # Make sure we have the OMB stuff - require_once(INSTALLDIR.'/lib/omb.php'); - $success = omb_broadcast_remote_subscribers($notice); - if (!$success) { - common_log(LOG_ERR, 'Error in OMB broadcast for notice ' . $notice->id); - } - } - if ($success) { - require_once(INSTALLDIR.'/lib/jabber.php'); - $success = jabber_broadcast_notice($notice); - if (!$success) { - common_log(LOG_ERR, 'Error in jabber broadcast for notice ' . $notice->id); - } - } - if ($success) { - require_once(INSTALLDIR.'/lib/mail.php'); - $success = mail_broadcast_notice_sms($notice); - if (!$success) { - common_log(LOG_ERR, 'Error in sms broadcast for notice ' . $notice->id); - } - } - if ($success) { - $success = jabber_public_notice($notice); - if (!$success) { - common_log(LOG_ERR, 'Error in public broadcast for notice ' . $notice->id); - } - } - // XXX: broadcast notices to other IM - return $success; + $success = true; + if (!$remote) { + // Make sure we have the OMB stuff + require_once(INSTALLDIR.'/lib/omb.php'); + $success = omb_broadcast_remote_subscribers($notice); + if (!$success) { + common_log(LOG_ERR, 'Error in OMB broadcast for notice ' . $notice->id); + } + } + if ($success) { + require_once(INSTALLDIR.'/lib/jabber.php'); + $success = jabber_broadcast_notice($notice); + if (!$success) { + common_log(LOG_ERR, 'Error in jabber broadcast for notice ' . $notice->id); + } + } + if ($success) { + require_once(INSTALLDIR.'/lib/mail.php'); + $success = mail_broadcast_notice_sms($notice); + if (!$success) { + common_log(LOG_ERR, 'Error in sms broadcast for notice ' . $notice->id); + } + } + if ($success) { + $success = jabber_public_notice($notice); + if (!$success) { + common_log(LOG_ERR, 'Error in public broadcast for notice ' . $notice->id); + } + } + // XXX: broadcast notices to other IM + return $success; } function common_broadcast_profile($profile) { - // XXX: optionally use a queue system like http://code.google.com/p/microapps/wiki/NQDQ - require_once(INSTALLDIR.'/lib/omb.php'); - omb_broadcast_profile($profile); - // XXX: Other broadcasts...? - return true; + // XXX: optionally use a queue system like http://code.google.com/p/microapps/wiki/NQDQ + require_once(INSTALLDIR.'/lib/omb.php'); + omb_broadcast_profile($profile); + // XXX: Other broadcasts...? + return true; } function common_profile_url($nickname) { - return common_local_url('showstream', array('nickname' => $nickname)); + return common_local_url('showstream', array('nickname' => $nickname)); } -# Don't call if nobody's logged in +// Don't call if nobody's logged in -function common_notice_form($action=NULL, $content=NULL) { - $user = common_current_user(); - assert(!is_null($user)); - common_element_start('form', array('id' => 'status_form', - 'method' => 'post', - 'action' => common_local_url('newnotice'))); - common_element_start('p'); - common_element('label', array('for' => 'status_textarea', - 'id' => 'status_label'), - sprintf(_('What\'s up, %s?'), $user->nickname)); +function common_notice_form($action=null, $content=null) { + $user = common_current_user(); + assert(!is_null($user)); + common_element_start('form', array('id' => 'status_form', + 'method' => 'post', + 'action' => common_local_url('newnotice'))); + common_element_start('p'); + common_element('label', array('for' => 'status_textarea', + 'id' => 'status_label'), + sprintf(_('What\'s up, %s?'), $user->nickname)); common_element('span', array('id' => 'counter', 'class' => 'counter'), '140'); - common_element('textarea', array('id' => 'status_textarea', - 'cols' => 60, - 'rows' => 3, - 'name' => 'status_textarea'), - ($content) ? $content : ''); - common_hidden('token', common_session_token()); - if ($action) { - common_hidden('returnto', $action); - } - # set by JavaScript - common_hidden('inreplyto', 'false'); - common_element('input', array('id' => 'status_submit', - 'name' => 'status_submit', - 'type' => 'submit', - 'value' => _('Send'))); - common_element_end('p'); - common_element_end('form'); -} - -# Should make up a reasonable root URL + common_element('textarea', array('id' => 'status_textarea', + 'cols' => 60, + 'rows' => 3, + 'name' => 'status_textarea'), + ($content) ? $content : ''); + common_hidden('token', common_session_token()); + if ($action) { + common_hidden('returnto', $action); + } + // set by JavaScript + common_hidden('inreplyto', 'false'); + common_element('input', array('id' => 'status_submit', + 'name' => 'status_submit', + 'type' => 'submit', + 'value' => _('Send'))); + common_element_end('p'); + common_element_end('form'); +} + +// Should make up a reasonable root URL function common_root_url() { - return common_path(''); + return common_path(''); } -# returns $bytes bytes of random data as a hexadecimal string -# "good" here is a goal and not a guarantee +// returns $bytes bytes of random data as a hexadecimal string +// "good" here is a goal and not a guarantee function common_good_rand($bytes) { - # XXX: use random.org...? - if (file_exists('/dev/urandom')) { - return common_urandom($bytes); - } else { # FIXME: this is probably not good enough - return common_mtrand($bytes); - } + // XXX: use random.org...? + if (file_exists('/dev/urandom')) { + return common_urandom($bytes); + } else { // FIXME: this is probably not good enough + return common_mtrand($bytes); + } } function common_urandom($bytes) { - $h = fopen('/dev/urandom', 'rb'); - # should not block - $src = fread($h, $bytes); - fclose($h); - $enc = ''; - for ($i = 0; $i < $bytes; $i++) { - $enc .= sprintf("%02x", (ord($src[$i]))); - } - return $enc; + $h = fopen('/dev/urandom', 'rb'); + // should not block + $src = fread($h, $bytes); + fclose($h); + $enc = ''; + for ($i = 0; $i < $bytes; $i++) { + $enc .= sprintf("%02x", (ord($src[$i]))); + } + return $enc; } function common_mtrand($bytes) { - $enc = ''; - for ($i = 0; $i < $bytes; $i++) { - $enc .= sprintf("%02x", mt_rand(0, 255)); - } - return $enc; + $enc = ''; + for ($i = 0; $i < $bytes; $i++) { + $enc .= sprintf("%02x", mt_rand(0, 255)); + } + return $enc; } function common_set_returnto($url) { - common_ensure_session(); - $_SESSION['returnto'] = $url; + common_ensure_session(); + $_SESSION['returnto'] = $url; } function common_get_returnto() { - common_ensure_session(); - return $_SESSION['returnto']; + common_ensure_session(); + return $_SESSION['returnto']; } function common_timestamp() { - return date('YmdHis'); + return date('YmdHis'); } function common_ensure_syslog() { - static $initialized = false; - if (!$initialized) { - global $config; - openlog($config['syslog']['appname'], 0, LOG_USER); - $initialized = true; - } -} - -function common_log($priority, $msg, $filename=NULL) { - $logfile = common_config('site', 'logfile'); - if ($logfile) { - $log = fopen($logfile, "a"); - if ($log) { - static $syslog_priorities = array('LOG_EMERG', 'LOG_ALERT', 'LOG_CRIT', 'LOG_ERR', - 'LOG_WARNING', 'LOG_NOTICE', 'LOG_INFO', 'LOG_DEBUG'); - $output = date('Y-m-d H:i:s') . ' ' . $syslog_priorities[$priority] . ': ' . $msg . "\n"; - fwrite($log, $output); - fclose($log); - } - } else { - common_ensure_syslog(); - syslog($priority, $msg); - } -} - -function common_debug($msg, $filename=NULL) { - if ($filename) { - common_log(LOG_DEBUG, basename($filename).' - '.$msg); - } else { - common_log(LOG_DEBUG, $msg); - } -} - -function common_log_db_error(&$object, $verb, $filename=NULL) { - $objstr = common_log_objstring($object); - $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); - common_log(LOG_ERR, $last_error->message . '(' . $verb . ' on ' . $objstr . ')', $filename); + static $initialized = false; + if (!$initialized) { + global $config; + openlog($config['syslog']['appname'], 0, LOG_USER); + $initialized = true; + } +} + +function common_log($priority, $msg, $filename=null) { + $logfile = common_config('site', 'logfile'); + if ($logfile) { + $log = fopen($logfile, "a"); + if ($log) { + static $syslog_priorities = array('LOG_EMERG', 'LOG_ALERT', 'LOG_CRIT', 'LOG_ERR', + 'LOG_WARNING', 'LOG_NOTICE', 'LOG_INFO', 'LOG_DEBUG'); + $output = date('Y-m-d H:i:s') . ' ' . $syslog_priorities[$priority] . ': ' . $msg . "\n"; + fwrite($log, $output); + fclose($log); + } + } else { + common_ensure_syslog(); + syslog($priority, $msg); + } +} + +function common_debug($msg, $filename=null) { + if ($filename) { + common_log(LOG_DEBUG, basename($filename).' - '.$msg); + } else { + common_log(LOG_DEBUG, $msg); + } +} + +function common_log_db_error(&$object, $verb, $filename=null) { + $objstr = common_log_objstring($object); + $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); + common_log(LOG_ERR, $last_error->message . '(' . $verb . ' on ' . $objstr . ')', $filename); } function common_log_objstring(&$object) { - if (is_null($object)) { - return "NULL"; - } - $arr = $object->toArray(); - $fields = array(); - foreach ($arr as $k => $v) { - $fields[] = "$k='$v'"; - } - $objstring = $object->tableName() . '[' . implode(',', $fields) . ']'; - return $objstring; + if (is_null($object)) { + return "null"; + } + $arr = $object->toArray(); + $fields = array(); + foreach ($arr as $k => $v) { + $fields[] = "$k='$v'"; + } + $objstring = $object->tableName() . '[' . implode(',', $fields) . ']'; + return $objstring; } function common_valid_http_url($url) { - return Validate::uri($url, array('allowed_schemes' => array('http', 'https'))); + return Validate::uri($url, array('allowed_schemes' => array('http', 'https'))); } function common_valid_tag($tag) { - if (preg_match('/^tag:(.*?),(\d{4}(-\d{2}(-\d{2})?)?):(.*)$/', $tag, $matches)) { - return (Validate::email($matches[1]) || - preg_match('/^([\w-\.]+)$/', $matches[1])); - } - return false; + if (preg_match('/^tag:(.*?),(\d{4}(-\d{2}(-\d{2})?)?):(.*)$/', $tag, $matches)) { + return (Validate::email($matches[1]) || + preg_match('/^([\w-\.]+)$/', $matches[1])); + } + return false; } -# Does a little before-after block for next/prev page +// Does a little before-after block for next/prev page -function common_pagination($have_before, $have_after, $page, $action, $args=NULL) { +function common_pagination($have_before, $have_after, $page, $action, $args=null) { - if ($have_before || $have_after) { - common_element_start('div', array('id' => 'pagination')); - common_element_start('ul', array('id' => 'nav_pagination')); - } + if ($have_before || $have_after) { + common_element_start('div', array('id' => 'pagination')); + common_element_start('ul', array('id' => 'nav_pagination')); + } - if ($have_before) { - $pargs = array('page' => $page-1); - $newargs = ($args) ? array_merge($args,$pargs) : $pargs; + if ($have_before) { + $pargs = array('page' => $page-1); + $newargs = ($args) ? array_merge($args,$pargs) : $pargs; - common_element_start('li', 'before'); - common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'prev'), - _('« After')); - common_element_end('li'); - } + common_element_start('li', 'before'); + common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'prev'), + _('« After')); + common_element_end('li'); + } - if ($have_after) { - $pargs = array('page' => $page+1); - $newargs = ($args) ? array_merge($args,$pargs) : $pargs; - common_element_start('li', 'after'); - common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'next'), - _('Before »')); - common_element_end('li'); - } + if ($have_after) { + $pargs = array('page' => $page+1); + $newargs = ($args) ? array_merge($args,$pargs) : $pargs; + common_element_start('li', 'after'); + common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'next'), + _('Before »')); + common_element_end('li'); + } - if ($have_before || $have_after) { - common_element_end('ul'); - common_element_end('div'); - } + if ($have_before || $have_after) { + common_element_end('ul'); + common_element_end('div'); + } } /* Following functions are copied from MediaWiki GlobalFunctions.php * and written by Evan Prodromou. */ function common_accept_to_prefs($accept, $def = '*/*') { - # No arg means accept anything (per HTTP spec) - if(!$accept) { - return array($def => 1); - } + // No arg means accept anything (per HTTP spec) + if(!$accept) { + return array($def => 1); + } - $prefs = array(); + $prefs = array(); - $parts = explode(',', $accept); + $parts = explode(',', $accept); - foreach($parts as $part) { - # FIXME: doesn't deal with params like 'text/html; level=1' - @list($value, $qpart) = explode(';', $part); - $match = array(); - if(!isset($qpart)) { - $prefs[$value] = 1; - } elseif(preg_match('/q\s*=\s*(\d*\.\d+)/', $qpart, $match)) { - $prefs[$value] = $match[1]; - } - } + foreach($parts as $part) { + // FIXME: doesn't deal with params like 'text/html; level=1' + @list($value, $qpart) = explode(';', $part); + $match = array(); + if(!isset($qpart)) { + $prefs[$value] = 1; + } elseif(preg_match('/q\s*=\s*(\d*\.\d+)/', $qpart, $match)) { + $prefs[$value] = $match[1]; + } + } - return $prefs; + return $prefs; } function common_mime_type_match($type, $avail) { - if(array_key_exists($type, $avail)) { - return $type; - } else { - $parts = explode('/', $type); - if(array_key_exists($parts[0] . '/*', $avail)) { - return $parts[0] . '/*'; - } elseif(array_key_exists('*/*', $avail)) { - return '*/*'; - } else { - return NULL; - } - } + if(array_key_exists($type, $avail)) { + return $type; + } else { + $parts = explode('/', $type); + if(array_key_exists($parts[0] . '/*', $avail)) { + return $parts[0] . '/*'; + } elseif(array_key_exists('*/*', $avail)) { + return '*/*'; + } else { + return null; + } + } } function common_negotiate_type($cprefs, $sprefs) { - $combine = array(); - - foreach(array_keys($sprefs) as $type) { - $parts = explode('/', $type); - if($parts[1] != '*') { - $ckey = common_mime_type_match($type, $cprefs); - if($ckey) { - $combine[$type] = $sprefs[$type] * $cprefs[$ckey]; - } - } - } - - foreach(array_keys($cprefs) as $type) { - $parts = explode('/', $type); - if($parts[1] != '*' && !array_key_exists($type, $sprefs)) { - $skey = common_mime_type_match($type, $sprefs); - if($skey) { - $combine[$type] = $sprefs[$skey] * $cprefs[$type]; - } - } - } - - $bestq = 0; - $besttype = "text/html"; - - foreach(array_keys($combine) as $type) { - if($combine[$type] > $bestq) { - $besttype = $type; - $bestq = $combine[$type]; - } - } - - return $besttype; + $combine = array(); + + foreach(array_keys($sprefs) as $type) { + $parts = explode('/', $type); + if($parts[1] != '*') { + $ckey = common_mime_type_match($type, $cprefs); + if($ckey) { + $combine[$type] = $sprefs[$type] * $cprefs[$ckey]; + } + } + } + + foreach(array_keys($cprefs) as $type) { + $parts = explode('/', $type); + if($parts[1] != '*' && !array_key_exists($type, $sprefs)) { + $skey = common_mime_type_match($type, $sprefs); + if($skey) { + $combine[$type] = $sprefs[$skey] * $cprefs[$type]; + } + } + } + + $bestq = 0; + $besttype = "text/html"; + + foreach(array_keys($combine) as $type) { + if($combine[$type] > $bestq) { + $besttype = $type; + $bestq = $combine[$type]; + } + } + + return $besttype; } function common_config($main, $sub) { - global $config; - return isset($config[$main][$sub]) ? $config[$main][$sub] : false; + global $config; + return isset($config[$main][$sub]) ? $config[$main][$sub] : false; } function common_copy_args($from) { - $to = array(); - $strip = get_magic_quotes_gpc(); - foreach ($from as $k => $v) { - $to[$k] = ($strip) ? stripslashes($v) : $v; - } - return $to; + $to = array(); + $strip = get_magic_quotes_gpc(); + foreach ($from as $k => $v) { + $to[$k] = ($strip) ? stripslashes($v) : $v; + } + return $to; } // Neutralise the evil effects of magic_quotes_gpc in the current request. // This is used before handing a request off to OAuthRequest::from_request. function common_remove_magic_from_request() { - if(get_magic_quotes_gpc()) { - $_POST=array_map('stripslashes',$_POST); - $_GET=array_map('stripslashes',$_GET); - } + if(get_magic_quotes_gpc()) { + $_POST=array_map('stripslashes',$_POST); + $_GET=array_map('stripslashes',$_GET); + } } function common_user_uri(&$user) { - return common_local_url('userbyid', array('id' => $user->id)); + return common_local_url('userbyid', array('id' => $user->id)); } function common_notice_uri(&$notice) { - return common_local_url('shownotice', - array('notice' => $notice->id)); + return common_local_url('shownotice', + array('notice' => $notice->id)); } -# 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits +// 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits function common_confirmation_code($bits) { - # 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits - static $codechars = '23456789ABCDEFGHJKLMNPQRSTUVWXYZ'; - $chars = ceil($bits/5); - $code = ''; - for ($i = 0; $i < $chars; $i++) { - # XXX: convert to string and back - $num = hexdec(common_good_rand(1)); - # XXX: randomness is too precious to throw away almost - # 40% of the bits we get! - $code .= $codechars[$num%32]; - } - return $code; -} - -# convert markup to HTML + // 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits + static $codechars = '23456789ABCDEFGHJKLMNPQRSTUVWXYZ'; + $chars = ceil($bits/5); + $code = ''; + for ($i = 0; $i < $chars; $i++) { + // XXX: convert to string and back + $num = hexdec(common_good_rand(1)); + // XXX: randomness is too precious to throw away almost + // 40% of the bits we get! + $code .= $codechars[$num%32]; + } + return $code; +} + +// convert markup to HTML function common_markup_to_html($c) { - $c = preg_replace('/%%action.(\w+)%%/e', "common_local_url('\\1')", $c); - $c = preg_replace('/%%doc.(\w+)%%/e', "common_local_url('doc', array('title'=>'\\1'))", $c); - $c = preg_replace('/%%(\w+).(\w+)%%/e', 'common_config(\'\\1\', \'\\2\')', $c); - return Markdown($c); + $c = preg_replace('/%%action.(\w+)%%/e', "common_local_url('\\1')", $c); + $c = preg_replace('/%%doc.(\w+)%%/e', "common_local_url('doc', array('title'=>'\\1'))", $c); + $c = preg_replace('/%%(\w+).(\w+)%%/e', 'common_config(\'\\1\', \'\\2\')', $c); + return Markdown($c); } function common_profile_avatar_url($profile, $size=AVATAR_PROFILE_SIZE) { - $avatar = $profile->getAvatar($size); - if ($avatar) { - return common_avatar_display_url($avatar); - } else { - return common_default_avatar($size); - } + $avatar = $profile->getAvatar($size); + if ($avatar) { + return common_avatar_display_url($avatar); + } else { + return common_default_avatar($size); + } } function common_profile_uri($profile) { - if (!$profile) { - return NULL; - } - $user = User::staticGet($profile->id); - if ($user) { - return $user->uri; - } - - $remote = Remote_profile::staticGet($profile->id); - if ($remote) { - return $remote->uri; - } - # XXX: this is a very bad profile! - return NULL; + if (!$profile) { + return null; + } + $user = User::staticGet($profile->id); + if ($user) { + return $user->uri; + } + + $remote = Remote_profile::staticGet($profile->id); + if ($remote) { + return $remote->uri; + } + // XXX: this is a very bad profile! + return null; } function common_canonical_sms($sms) { - # strip non-digits - preg_replace('/\D/', '', $sms); - return $sms; + // strip non-digits + preg_replace('/\D/', '', $sms); + return $sms; } function common_error_handler($errno, $errstr, $errfile, $errline, $errcontext) { switch ($errno) { case E_USER_ERROR: - common_log(LOG_ERR, "[$errno] $errstr ($errfile:$errline)"); - exit(1); - break; + common_log(LOG_ERR, "[$errno] $errstr ($errfile:$errline)"); + exit(1); + break; - case E_USER_WARNING: - common_log(LOG_WARNING, "[$errno] $errstr ($errfile:$errline)"); - break; + case E_USER_WARNING: + common_log(LOG_WARNING, "[$errno] $errstr ($errfile:$errline)"); + break; case E_USER_NOTICE: - common_log(LOG_NOTICE, "[$errno] $errstr ($errfile:$errline)"); - break; + common_log(LOG_NOTICE, "[$errno] $errstr ($errfile:$errline)"); + break; } - # FIXME: show error page if we're on the Web + // FIXME: show error page if we're on the Web /* Don't execute PHP internal error handler */ return true; } function common_session_token() { - common_ensure_session(); - if (!array_key_exists('token', $_SESSION)) { - $_SESSION['token'] = common_good_rand(64); - } - return $_SESSION['token']; + common_ensure_session(); + if (!array_key_exists('token', $_SESSION)) { + $_SESSION['token'] = common_good_rand(64); + } + return $_SESSION['token']; } function common_disfavor_form($notice) { - common_element_start('form', array('id' => 'disfavor-' . $notice->id, - 'method' => 'post', - 'class' => 'disfavor', - 'action' => common_local_url('disfavor'))); - - common_element('input', array('type' => 'hidden', - 'name' => 'token-'. $notice->id, - 'id' => 'token-'. $notice->id, - 'class' => 'token', - 'value' => common_session_token())); - - common_element('input', array('type' => 'hidden', - 'name' => 'notice', - 'id' => 'notice-n'. $notice->id, - 'class' => 'notice', - 'value' => $notice->id)); - - common_element('input', array('type' => 'submit', - 'id' => 'disfavor-submit-' . $notice->id, - 'name' => 'disfavor-submit-' . $notice->id, - 'class' => 'disfavor', - 'value' => 'Disfavor favorite', - 'title' => 'Remove this message from favorites')); - common_element_end('form'); + common_element_start('form', array('id' => 'disfavor-' . $notice->id, + 'method' => 'post', + 'class' => 'disfavor', + 'action' => common_local_url('disfavor'))); + + common_element('input', array('type' => 'hidden', + 'name' => 'token-'. $notice->id, + 'id' => 'token-'. $notice->id, + 'class' => 'token', + 'value' => common_session_token())); + + common_element('input', array('type' => 'hidden', + 'name' => 'notice', + 'id' => 'notice-n'. $notice->id, + 'class' => 'notice', + 'value' => $notice->id)); + + common_element('input', array('type' => 'submit', + 'id' => 'disfavor-submit-' . $notice->id, + 'name' => 'disfavor-submit-' . $notice->id, + 'class' => 'disfavor', + 'value' => 'Disfavor favorite', + 'title' => 'Remove this message from favorites')); + common_element_end('form'); } function common_favor_form($notice) { - common_element_start('form', array('id' => 'favor-' . $notice->id, - 'method' => 'post', - 'class' => 'favor', - 'action' => common_local_url('favor'))); - - common_element('input', array('type' => 'hidden', - 'name' => 'token-'. $notice->id, - 'id' => 'token-'. $notice->id, - 'class' => 'token', - 'value' => common_session_token())); - - common_element('input', array('type' => 'hidden', - 'name' => 'notice', - 'id' => 'notice-n'. $notice->id, - 'class' => 'notice', - 'value' => $notice->id)); - - common_element('input', array('type' => 'submit', - 'id' => 'favor-submit-' . $notice->id, - 'name' => 'favor-submit-' . $notice->id, - 'class' => 'favor', - 'value' => 'Add to favorites', - 'title' => 'Add this message to favorites')); - common_element_end('form'); + common_element_start('form', array('id' => 'favor-' . $notice->id, + 'method' => 'post', + 'class' => 'favor', + 'action' => common_local_url('favor'))); + + common_element('input', array('type' => 'hidden', + 'name' => 'token-'. $notice->id, + 'id' => 'token-'. $notice->id, + 'class' => 'token', + 'value' => common_session_token())); + + common_element('input', array('type' => 'hidden', + 'name' => 'notice', + 'id' => 'notice-n'. $notice->id, + 'class' => 'notice', + 'value' => $notice->id)); + + common_element('input', array('type' => 'submit', + 'id' => 'favor-submit-' . $notice->id, + 'name' => 'favor-submit-' . $notice->id, + 'class' => 'favor', + 'value' => 'Add to favorites', + 'title' => 'Add this message to favorites')); + common_element_end('form'); } function common_nudge_form($profile) { - common_element_start('form', array('id' => 'nudge', 'method' => 'post', - 'action' => common_local_url('nudge', array('nickname' => $profile->nickname)))); - common_hidden('token', common_session_token()); - common_element('input', array('type' => 'submit', - 'class' => 'submit', - 'value' => _('Send a nudge'))); - common_element_end('form'); + common_element_start('form', array('id' => 'nudge', 'method' => 'post', + 'action' => common_local_url('nudge', array('nickname' => $profile->nickname)))); + common_hidden('token', common_session_token()); + common_element('input', array('type' => 'submit', + 'class' => 'submit', + 'value' => _('Send a nudge'))); + common_element_end('form'); } function common_nudge_response() { - common_element('p', array('id' => 'nudge_response'), _('Nudge sent!')); + common_element('p', array('id' => 'nudge_response'), _('Nudge sent!')); } function common_subscribe_form($profile) { - common_element_start('form', array('id' => 'subscribe-' . $profile->id, - 'method' => 'post', - 'class' => 'subscribe', - 'action' => common_local_url('subscribe'))); - common_hidden('token', common_session_token()); - common_element('input', array('id' => 'subscribeto-' . $profile->id, - 'name' => 'subscribeto', - 'type' => 'hidden', - 'value' => $profile->id)); - common_element('input', array('type' => 'submit', - 'class' => 'submit', - 'value' => _('Subscribe'))); - common_element_end('form'); + common_element_start('form', array('id' => 'subscribe-' . $profile->id, + 'method' => 'post', + 'class' => 'subscribe', + 'action' => common_local_url('subscribe'))); + common_hidden('token', common_session_token()); + common_element('input', array('id' => 'subscribeto-' . $profile->id, + 'name' => 'subscribeto', + 'type' => 'hidden', + 'value' => $profile->id)); + common_element('input', array('type' => 'submit', + 'class' => 'submit', + 'value' => _('Subscribe'))); + common_element_end('form'); } function common_unsubscribe_form($profile) { - common_element_start('form', array('id' => 'unsubscribe-' . $profile->id, - 'method' => 'post', - 'class' => 'unsubscribe', - 'action' => common_local_url('unsubscribe'))); - common_hidden('token', common_session_token()); - common_element('input', array('id' => 'unsubscribeto-' . $profile->id, - 'name' => 'unsubscribeto', - 'type' => 'hidden', - 'value' => $profile->id)); - common_element('input', array('type' => 'submit', - 'class' => 'submit', - 'value' => _('Unsubscribe'))); - common_element_end('form'); + common_element_start('form', array('id' => 'unsubscribe-' . $profile->id, + 'method' => 'post', + 'class' => 'unsubscribe', + 'action' => common_local_url('unsubscribe'))); + common_hidden('token', common_session_token()); + common_element('input', array('id' => 'unsubscribeto-' . $profile->id, + 'name' => 'unsubscribeto', + 'type' => 'hidden', + 'value' => $profile->id)); + common_element('input', array('type' => 'submit', + 'class' => 'submit', + 'value' => _('Unsubscribe'))); + common_element_end('form'); } // XXX: Refactor this code function common_profile_new_message_nudge ($cur, $profile) { - $user = User::staticGet('id', $profile->id); + $user = User::staticGet('id', $profile->id); - if ($cur && $cur->id != $user->id && $cur->mutuallySubscribed($user)) { + if ($cur && $cur->id != $user->id && $cur->mutuallySubscribed($user)) { common_element_start('li', array('id' => 'profile_send_a_new_message')); - common_element('a', array('href' => common_local_url('newmessage', array('to' => $user->id))), - _('Send a message')); + common_element('a', array('href' => common_local_url('newmessage', array('to' => $user->id))), + _('Send a message')); common_element_end('li'); - if ($user->email && $user->emailnotifynudge) { + if ($user->email && $user->emailnotifynudge) { common_element_start('li', array('id' => 'profile_nudge')); common_nudge_form($user); common_element_end('li'); } - } + } } function common_cache_key($extra) { - return 'laconica:' . common_keyize(common_config('site', 'name')) . ':' . $extra; + return 'laconica:' . common_keyize(common_config('site', 'name')) . ':' . $extra; } function common_keyize($str) { - $str = strtolower($str); - $str = preg_replace('/\s/', '_', $str); - return $str; + $str = strtolower($str); + $str = preg_replace('/\s/', '_', $str); + return $str; } function common_message_form($content, $user, $to) { - common_element_start('form', array('id' => 'message_form', - 'method' => 'post', - 'action' => common_local_url('newmessage'))); + common_element_start('form', array('id' => 'message_form', + 'method' => 'post', + 'action' => common_local_url('newmessage'))); - $mutual_users = $user->mutuallySubscribedUsers(); + $mutual_users = $user->mutuallySubscribedUsers(); - $mutual = array(); + $mutual = array(); - while ($mutual_users->fetch()) { - if ($mutual_users->id != $user->id) { - $mutual[$mutual_users->id] = $mutual_users->nickname; - } - } + while ($mutual_users->fetch()) { + if ($mutual_users->id != $user->id) { + $mutual[$mutual_users->id] = $mutual_users->nickname; + } + } - $mutual_users->free(); - unset($mutual_users); + $mutual_users->free(); + unset($mutual_users); - common_dropdown('to', _('To'), $mutual, NULL, FALSE, $to->id); + common_dropdown('to', _('To'), $mutual, null, FALSE, $to->id); - common_element_start('p'); + common_element_start('p'); - common_element('textarea', array('id' => 'message_content', - 'cols' => 60, - 'rows' => 3, - 'name' => 'content'), - ($content) ? $content : ''); + common_element('textarea', array('id' => 'message_content', + 'cols' => 60, + 'rows' => 3, + 'name' => 'content'), + ($content) ? $content : ''); - common_element('input', array('id' => 'message_send', - 'name' => 'message_send', - 'type' => 'submit', - 'value' => _('Send'))); + common_element('input', array('id' => 'message_send', + 'name' => 'message_send', + 'type' => 'submit', + 'value' => _('Send'))); - common_hidden('token', common_session_token()); + common_hidden('token', common_session_token()); - common_element_end('p'); - common_element_end('form'); + common_element_end('p'); + common_element_end('form'); } function common_memcache() { - static $cache = NULL; - if (!common_config('memcached', 'enabled')) { - return NULL; - } else { - if (!$cache) { - $cache = new Memcache(); - $servers = common_config('memcached', 'server'); - if (is_array($servers)) { - foreach($servers as $server) { - $cache->addServer($server); - } - } else { - $cache->addServer($servers); - } - } - return $cache; - } + static $cache = null; + if (!common_config('memcached', 'enabled')) { + return null; + } else { + if (!$cache) { + $cache = new Memcache(); + $servers = common_config('memcached', 'server'); + if (is_array($servers)) { + foreach($servers as $server) { + $cache->addServer($server); + } + } else { + $cache->addServer($servers); + } + } + return $cache; + } } function common_compatible_license($from, $to) { - # XXX: better compatibility check needed here! - return ($from == $to); + // XXX: better compatibility check needed here! + return ($from == $to); } /* These are almost identical, so we use a helper function */ -function common_block_form($profile, $args=NULL) { +function common_block_form($profile, $args=null) { common_blocking_form('block', _('Block'), $profile, $args); } -function common_unblock_form($profile, $args=NULL) { +function common_unblock_form($profile, $args=null) { common_blocking_form('unblock', _('Unblock'), $profile, $args); } -function common_blocking_form($type, $label, $profile, $args=NULL) { +function common_blocking_form($type, $label, $profile, $args=null) { common_element_start('form', array('id' => $type . '-' . $profile->id, 'method' => 'post', 'class' => $type, @@ -2217,4 +2217,3 @@ function common_blocking_form($type, $label, $profile, $args=NULL) { common_element_end('form'); return; } - diff --git a/_darcs/tentative_pristine b/_darcs/tentative_pristine index fa3a0e58e5..487d2bcdc5 100644 --- a/_darcs/tentative_pristine +++ b/_darcs/tentative_pristine @@ -1,52 +1,3368 @@ -hunk ./index.php 2 --/* -+/** -hunk ./index.php 23 --require_once(INSTALLDIR . "/lib/common.php"); -+require_once INSTALLDIR . '/lib/common.php'; -hunk ./index.php 25 --# get and cache current user -+// get and cache current user -hunk ./index.php 29 --# initialize language env -+// initialize language env -hunk ./index.php 44 -- 'recoverpassword', 'api', 'doc', 'register'))) --{ -+ 'recoverpassword', 'api', 'doc', 'register'))) { -hunk ./index.php 51 -- require_once($actionfile); -- $action_class = ucfirst($action)."Action"; -+ -+ include_once $actionfile; -+ -+ $action_class = ucfirst($action).'Action'; -+ -hunk ./index.php 57 -- if ($config['db']['mirror'] && $action_obj->is_readonly()) { -- if (is_array($config['db']['mirror'])) { -- # "load balancing", ha ha -- $k = array_rand($config['db']['mirror']); -- $mirror = $config['db']['mirror'][$k]; -- } else { -- $mirror = $config['db']['mirror']; -- } -- $config['db']['database'] = $mirror; -- } -+ -+ if ($config['db']['mirror'] && $action_obj->is_readonly()) { -+ if (is_array($config['db']['mirror'])) { -+ // "load balancing", ha ha -+ $k = array_rand($config['db']['mirror']); -+ -+ $mirror = $config['db']['mirror'][$k]; -+ } else { -+ $mirror = $config['db']['mirror']; -+ } -+ $config['db']['database'] = $mirror; -+ } -hunk ./index.php 70 -- call_user_func(array($action_obj, 'handle'), $_REQUEST); -- } -+ call_user_func(array($action_obj, 'handle'), $_REQUEST); +hunk ./lib/util.php 22 +-# Show a server error ++// Show a server error +hunk ./lib/util.php 25 +- static $status = array(500 => 'Internal Server Error', +- 501 => 'Not Implemented', +- 502 => 'Bad Gateway', +- 503 => 'Service Unavailable', +- 504 => 'Gateway Timeout', +- 505 => 'HTTP Version Not Supported'); ++ static $status = array(500 => 'Internal Server Error', ++ 501 => 'Not Implemented', ++ 502 => 'Bad Gateway', ++ 503 => 'Service Unavailable', ++ 504 => 'Gateway Timeout', ++ 505 => 'HTTP Version Not Supported'); +hunk ./lib/util.php 32 +- if (!array_key_exists($code, $status)) { +- $code = 500; +- } ++ if (!array_key_exists($code, $status)) { ++ $code = 500; ++ } +hunk ./lib/util.php 36 +- $status_string = $status[$code]; ++ $status_string = $status[$code]; +hunk ./lib/util.php 38 +- header('HTTP/1.1 '.$code.' '.$status_string); +- header('Content-type: text/plain'); ++ header('HTTP/1.1 '.$code.' '.$status_string); ++ header('Content-type: text/plain'); +hunk ./lib/util.php 41 +- print $msg; +- print "\n"; +- exit(); ++ print $msg; ++ print "\n"; ++ exit(); +hunk ./lib/util.php 46 +-# Show a user error ++// Show a user error +hunk ./lib/util.php 48 +- static $status = array(400 => 'Bad Request', +- 401 => 'Unauthorized', +- 402 => 'Payment Required', +- 403 => 'Forbidden', +- 404 => 'Not Found', +- 405 => 'Method Not Allowed', +- 406 => 'Not Acceptable', +- 407 => 'Proxy Authentication Required', +- 408 => 'Request Timeout', +- 409 => 'Conflict', +- 410 => 'Gone', +- 411 => 'Length Required', +- 412 => 'Precondition Failed', +- 413 => 'Request Entity Too Large', +- 414 => 'Request-URI Too Long', +- 415 => 'Unsupported Media Type', +- 416 => 'Requested Range Not Satisfiable', +- 417 => 'Expectation Failed'); ++ static $status = array(400 => 'Bad Request', ++ 401 => 'Unauthorized', ++ 402 => 'Payment Required', ++ 403 => 'Forbidden', ++ 404 => 'Not Found', ++ 405 => 'Method Not Allowed', ++ 406 => 'Not Acceptable', ++ 407 => 'Proxy Authentication Required', ++ 408 => 'Request Timeout', ++ 409 => 'Conflict', ++ 410 => 'Gone', ++ 411 => 'Length Required', ++ 412 => 'Precondition Failed', ++ 413 => 'Request Entity Too Large', ++ 414 => 'Request-URI Too Long', ++ 415 => 'Unsupported Media Type', ++ 416 => 'Requested Range Not Satisfiable', ++ 417 => 'Expectation Failed'); +hunk ./lib/util.php 67 +- if (!array_key_exists($code, $status)) { +- $code = 400; +- } ++ if (!array_key_exists($code, $status)) { ++ $code = 400; ++ } +hunk ./lib/util.php 71 +- $status_string = $status[$code]; ++ $status_string = $status[$code]; +hunk ./lib/util.php 73 +- header('HTTP/1.1 '.$code.' '.$status_string); ++ header('HTTP/1.1 '.$code.' '.$status_string); +hunk ./lib/util.php 75 +- common_show_header('Error'); +- common_element('div', array('class' => 'error'), $msg); +- common_show_footer(); ++ common_show_header('Error'); ++ common_element('div', array('class' => 'error'), $msg); ++ common_show_footer(); +hunk ./lib/util.php 82 +-# Start an HTML element +-function common_element_start($tag, $attrs=NULL) { +- global $xw; +- $xw->startElement($tag); +- if (is_array($attrs)) { +- foreach ($attrs as $name => $value) { +- $xw->writeAttribute($name, $value); +- } +- } else if (is_string($attrs)) { +- $xw->writeAttribute('class', $attrs); +- } ++// Start an HTML element ++function common_element_start($tag, $attrs=null) { ++ global $xw; ++ $xw->startElement($tag); ++ if (is_array($attrs)) { ++ foreach ($attrs as $name => $value) { ++ $xw->writeAttribute($name, $value); ++ } ++ } else if (is_string($attrs)) { ++ $xw->writeAttribute('class', $attrs); ++ } +hunk ./lib/util.php 96 +- static $empty_tag = array('base', 'meta', 'link', 'hr', +- 'br', 'param', 'img', 'area', +- 'input', 'col'); +- global $xw; +- # XXX: check namespace +- if (in_array($tag, $empty_tag)) { +- $xw->endElement(); +- } else { +- $xw->fullEndElement(); +- } ++ static $empty_tag = array('base', 'meta', 'link', 'hr', ++ 'br', 'param', 'img', 'area', ++ 'input', 'col'); ++ global $xw; ++ // XXX: check namespace ++ if (in_array($tag, $empty_tag)) { ++ $xw->endElement(); ++ } else { ++ $xw->fullEndElement(); ++ } +hunk ./lib/util.php 108 +-function common_element($tag, $attrs=NULL, $content=NULL) { +- common_element_start($tag, $attrs); +- global $xw; +- if (!is_null($content)) { +- $xw->text($content); +- } +- common_element_end($tag); ++function common_element($tag, $attrs=null, $content=null) { ++ common_element_start($tag, $attrs); ++ global $xw; ++ if (!is_null($content)) { ++ $xw->text($content); ++ } ++ common_element_end($tag); +hunk ./lib/util.php 117 +-function common_start_xml($doc=NULL, $public=NULL, $system=NULL, $indent=true) { +- global $xw; +- $xw = new XMLWriter(); +- $xw->openURI('php://output'); +- $xw->setIndent($indent); +- $xw->startDocument('1.0', 'UTF-8'); +- if ($doc) { +- $xw->writeDTD($doc, $public, $system); +- } ++function common_start_xml($doc=null, $public=null, $system=null, $indent=true) { ++ global $xw; ++ $xw = new XMLWriter(); ++ $xw->openURI('php://output'); ++ $xw->setIndent($indent); ++ $xw->startDocument('1.0', 'UTF-8'); ++ if ($doc) { ++ $xw->writeDTD($doc, $public, $system); ++ } +hunk ./lib/util.php 129 +- global $xw; +- $xw->endDocument(); +- $xw->flush(); ++ global $xw; ++ $xw->endDocument(); ++ $xw->flush(); +hunk ./lib/util.php 141 +- $language . ".UTF8", +- $language . ".utf-8", +- $language . ".UTF-8", +- $language); ++ $language . ".UTF8", ++ $language . ".utf-8", ++ $language . ".UTF-8", ++ $language); +hunk ./lib/util.php 148 +- mb_internal_encoding('UTF-8'); +- $language = common_language(); +- # So we don't have to make people install the gettext locales +- $locale_set = common_init_locale($language); +- bindtextdomain("laconica", common_config('site','locale_path')); +- bind_textdomain_codeset("laconica", "UTF-8"); +- textdomain("laconica"); +- setlocale(LC_CTYPE, 'C'); +- if(!$locale_set) { +- common_log(LOG_INFO,'Language requested:'.$language.' - locale could not be set:',__FILE__); +- } ++ mb_internal_encoding('UTF-8'); ++ $language = common_language(); ++ // So we don't have to make people install the gettext locales ++ $locale_set = common_init_locale($language); ++ bindtextdomain("laconica", common_config('site','locale_path')); ++ bind_textdomain_codeset("laconica", "UTF-8"); ++ textdomain("laconica"); ++ setlocale(LC_CTYPE, 'C'); ++ if(!$locale_set) { ++ common_log(LOG_INFO,'Language requested:'.$language.' - locale could not be set:',__FILE__); ++ } +hunk ./lib/util.php 163 +-function common_show_header($pagetitle, $callable=NULL, $data=NULL, $headercall=NULL) { ++function common_show_header($pagetitle, $callable=null, $data=null, $headercall=null) { +hunk ./lib/util.php 165 +- global $config, $xw; ++ global $config, $xw; +hunk ./lib/util.php 168 +- common_start_html(); ++ common_start_html(); +hunk ./lib/util.php 170 +- common_element_start('head'); +- common_element('title', NULL, +- $pagetitle . " - " . $config['site']['name']); +- common_element('link', array('rel' => 'stylesheet', +- 'type' => 'text/css', +- 'href' => theme_path('display.css') . '?version=' . LACONICA_VERSION, +- 'media' => 'screen, projection, tv')); +- foreach (array(6,7) as $ver) { +- if (file_exists(theme_file('ie'.$ver.'.css'))) { +- # Yes, IE people should be put in jail. +- $xw->writeComment('[if lte IE '.$ver.']> 'stylesheet', ++ 'type' => 'text/css', ++ 'href' => theme_path('display.css') . '?version=' . LACONICA_VERSION, ++ 'media' => 'screen, projection, tv')); ++ foreach (array(6,7) as $ver) { ++ if (file_exists(theme_file('ie'.$ver.'.css'))) { ++ // Yes, IE people should be put in jail. ++ $xw->writeComment('[if lte IE '.$ver.']> 'text/javascript', +- 'src' => common_path('js/jquery.min.js')), +- ' '); +- common_element('script', array('type' => 'text/javascript', +- 'src' => common_path('js/jquery.form.js')), +- ' '); +- common_element('script', array('type' => 'text/javascript', +- 'src' => common_path('js/xbImportNode.js')), +- ' '); +- common_element('script', array('type' => 'text/javascript', +- 'src' => common_path('js/util.js?version='.LACONICA_VERSION)), +- ' '); +- common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', +- 'href' => common_local_url('opensearch', array('type' => 'people')), +- 'title' => common_config('site', 'name').' People Search')); ++ common_element('script', array('type' => 'text/javascript', ++ 'src' => common_path('js/jquery.min.js')), ++ ' '); ++ common_element('script', array('type' => 'text/javascript', ++ 'src' => common_path('js/jquery.form.js')), ++ ' '); ++ common_element('script', array('type' => 'text/javascript', ++ 'src' => common_path('js/xbImportNode.js')), ++ ' '); ++ common_element('script', array('type' => 'text/javascript', ++ 'src' => common_path('js/util.js?version='.LACONICA_VERSION)), ++ ' '); ++ common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', ++ 'href' => common_local_url('opensearch', array('type' => 'people')), ++ 'title' => common_config('site', 'name').' People Search')); +hunk ./lib/util.php 201 +- common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', +- 'href' => common_local_url('opensearch', array('type' => 'notice')), +- 'title' => common_config('site', 'name').' Notice Search')); ++ common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', ++ 'href' => common_local_url('opensearch', array('type' => 'notice')), ++ 'title' => common_config('site', 'name').' Notice Search')); +hunk ./lib/util.php 205 +- if ($callable) { +- if ($data) { +- call_user_func($callable, $data); +- } else { +- call_user_func($callable); +- } +- } +- common_element_end('head'); +- common_element_start('body', $action); +- common_element_start('div', array('id' => 'wrap')); +- common_element_start('div', array('id' => 'header')); +- common_nav_menu(); +- if ((isset($config['site']['logo']) && is_string($config['site']['logo']) && (strlen($config['site']['logo']) > 0)) +- || file_exists(theme_file('logo.png'))) +- { +- common_element_start('a', array('href' => common_local_url('public'))); +- common_element('img', array('src' => isset($config['site']['logo']) ? +- ($config['site']['logo']) : theme_path('logo.png'), +- 'alt' => $config['site']['name'], +- 'id' => 'logo')); +- common_element_end('a'); +- } else { +- common_element_start('p', array('id' => 'branding')); +- common_element('a', array('href' => common_local_url('public')), +- $config['site']['name']); +- common_element_end('p'); +- } ++ if ($callable) { ++ if ($data) { ++ call_user_func($callable, $data); ++ } else { ++ call_user_func($callable); ++ } ++ } ++ common_element_end('head'); ++ common_element_start('body', $action); ++ common_element_start('div', array('id' => 'wrap')); ++ common_element_start('div', array('id' => 'header')); ++ common_nav_menu(); ++ if ((isset($config['site']['logo']) && is_string($config['site']['logo']) && (strlen($config['site']['logo']) > 0)) ++ || file_exists(theme_file('logo.png'))) ++ { ++ common_element_start('a', array('href' => common_local_url('public'))); ++ common_element('img', array('src' => isset($config['site']['logo']) ? ++ ($config['site']['logo']) : theme_path('logo.png'), ++ 'alt' => $config['site']['name'], ++ 'id' => 'logo')); ++ common_element_end('a'); ++ } else { ++ common_element_start('p', array('id' => 'branding')); ++ common_element('a', array('href' => common_local_url('public')), ++ $config['site']['name']); ++ common_element_end('p'); ++ } +hunk ./lib/util.php 233 +- common_element('h1', 'pagetitle', $pagetitle); ++ common_element('h1', 'pagetitle', $pagetitle); +hunk ./lib/util.php 235 +- if ($headercall) { +- if ($data) { +- call_user_func($headercall, $data); +- } else { +- call_user_func($headercall); +- } +- } +- common_element_end('div'); +- common_element_start('div', array('id' => 'content')); ++ if ($headercall) { ++ if ($data) { ++ call_user_func($headercall, $data); ++ } else { ++ call_user_func($headercall); ++ } ++ } ++ common_element_end('div'); ++ common_element_start('div', array('id' => 'content')); +hunk ./lib/util.php 246 +-function common_start_html($type=NULL, $indent=true) { ++function common_start_html($type=null, $indent=true) { +hunk ./lib/util.php 248 +- if (!$type) { +- $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ? $_SERVER['HTTP_ACCEPT'] : NULL; ++ if (!$type) { ++ $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ? $_SERVER['HTTP_ACCEPT'] : null; +hunk ./lib/util.php 251 +- # XXX: allow content negotiation for RDF, RSS, or XRDS ++ // XXX: allow content negotiation for RDF, RSS, or XRDS +hunk ./lib/util.php 253 +- $type = common_negotiate_type(common_accept_to_prefs($httpaccept), +- common_accept_to_prefs(PAGE_TYPE_PREFS)); ++ $type = common_negotiate_type(common_accept_to_prefs($httpaccept), ++ common_accept_to_prefs(PAGE_TYPE_PREFS)); +hunk ./lib/util.php 256 +- if (!$type) { +- common_user_error(_('This page is not available in a media type you accept'), 406); +- exit(0); +- } +- } ++ if (!$type) { ++ common_user_error(_('This page is not available in a media type you accept'), 406); ++ exit(0); ++ } ++ } +hunk ./lib/util.php 262 +- header('Content-Type: '.$type); ++ header('Content-Type: '.$type); +hunk ./lib/util.php 264 +- common_start_xml('html', +- '-//W3C//DTD XHTML 1.0 Strict//EN', +- 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd', $indent); ++ common_start_xml('html', ++ '-//W3C//DTD XHTML 1.0 Strict//EN', ++ 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd', $indent); +hunk ./lib/util.php 268 +- # FIXME: correct language for interface ++ // FIXME: correct language for interface +hunk ./lib/util.php 270 +- $language = common_language(); ++ $language = common_language(); +hunk ./lib/util.php 272 +- common_element_start('html', array('xmlns' => 'http://www.w3.org/1999/xhtml', +- 'xml:lang' => $language, +- 'lang' => $language)); ++ common_element_start('html', array('xmlns' => 'http://www.w3.org/1999/xhtml', ++ 'xml:lang' => $language, ++ 'lang' => $language)); +hunk ./lib/util.php 278 +- global $xw, $config; +- common_element_end('div'); # content div +- common_foot_menu(); +- common_element_start('div', array('id' => 'footer')); +- common_element_start('div', 'laconica'); +- if (common_config('site', 'broughtby')) { +- $instr = _('**%%site.name%%** is a microblogging service brought to you by [%%site.broughtby%%](%%site.broughtbyurl%%). '); +- } else { +- $instr = _('**%%site.name%%** is a microblogging service. '); +- } +- $instr .= sprintf(_('It runs the [Laconica](http://laconi.ca/) microblogging software, version %s, available under the [GNU Affero General Public License](http://www.fsf.org/licensing/licenses/agpl-3.0.html).'), LACONICA_VERSION); ++ global $xw, $config; ++ common_element_end('div'); // content div ++ common_foot_menu(); ++ common_element_start('div', array('id' => 'footer')); ++ common_element_start('div', 'laconica'); ++ if (common_config('site', 'broughtby')) { ++ $instr = _('**%%site.name%%** is a microblogging service brought to you by [%%site.broughtby%%](%%site.broughtbyurl%%). '); ++ } else { ++ $instr = _('**%%site.name%%** is a microblogging service. '); ++ } ++ $instr .= sprintf(_('It runs the [Laconica](http://laconi.ca/) microblogging software, version %s, available under the [GNU Affero General Public License](http://www.fsf.org/licensing/licenses/agpl-3.0.html).'), LACONICA_VERSION); +hunk ./lib/util.php 291 +- common_element_end('div'); +- common_element('img', array('id' => 'cc', +- 'src' => $config['license']['image'], +- 'alt' => $config['license']['title'])); +- common_element_start('p'); +- common_text(_('Unless otherwise specified, contents of this site are copyright by the contributors and available under the ')); +- common_element('a', array('class' => 'license', +- 'rel' => 'license', +- 'href' => $config['license']['url']), +- $config['license']['title']); +- common_text(_('. Contributors should be attributed by full name or nickname.')); +- common_element_end('p'); +- common_element_end('div'); +- common_element_end('div'); +- common_element_end('body'); +- common_element_end('html'); +- common_end_xml(); ++ common_element_end('div'); ++ common_element('img', array('id' => 'cc', ++ 'src' => $config['license']['image'], ++ 'alt' => $config['license']['title'])); ++ common_element_start('p'); ++ common_text(_('Unless otherwise specified, contents of this site are copyright by the contributors and available under the ')); ++ common_element('a', array('class' => 'license', ++ 'rel' => 'license', ++ 'href' => $config['license']['url']), ++ $config['license']['title']); ++ common_text(_('. Contributors should be attributed by full name or nickname.')); ++ common_element_end('p'); ++ common_element_end('div'); ++ common_element_end('div'); ++ common_element_end('body'); ++ common_element_end('html'); ++ common_end_xml(); +hunk ./lib/util.php 311 +- global $xw; +- $xw->text($txt); ++ global $xw; ++ $xw->text($txt); +hunk ./lib/util.php 316 +- global $xw; +- $xw->writeRaw($xml); ++ global $xw; ++ $xw->writeRaw($xml); +hunk ./lib/util.php 321 +- $user = common_current_user(); +- common_element_start('ul', array('id' => 'nav')); +- if ($user) { +- common_menu_item(common_local_url('all', array('nickname' => $user->nickname)), +- _('Home')); +- } +- common_menu_item(common_local_url('peoplesearch'), _('Search')); +- if ($user) { +- common_menu_item(common_local_url('profilesettings'), +- _('Settings')); +- common_menu_item(common_local_url('invite'), +- _('Invite')); +- common_menu_item(common_local_url('logout'), +- _('Logout')); +- } else { +- common_menu_item(common_local_url('login'), _('Login')); +- if (!common_config('site', 'closed')) { +- common_menu_item(common_local_url('register'), _('Register')); +- } +- common_menu_item(common_local_url('openidlogin'), _('OpenID')); +- } +- common_menu_item(common_local_url('doc', array('title' => 'help')), +- _('Help')); +- common_element_end('ul'); ++ $user = common_current_user(); ++ common_element_start('ul', array('id' => 'nav')); ++ if ($user) { ++ common_menu_item(common_local_url('all', array('nickname' => $user->nickname)), ++ _('Home')); ++ } ++ common_menu_item(common_local_url('peoplesearch'), _('Search')); ++ if ($user) { ++ common_menu_item(common_local_url('profilesettings'), ++ _('Settings')); ++ common_menu_item(common_local_url('invite'), ++ _('Invite')); ++ common_menu_item(common_local_url('logout'), ++ _('Logout')); ++ } else { ++ common_menu_item(common_local_url('login'), _('Login')); ++ if (!common_config('site', 'closed')) { ++ common_menu_item(common_local_url('register'), _('Register')); ++ } ++ common_menu_item(common_local_url('openidlogin'), _('OpenID')); ++ } ++ common_menu_item(common_local_url('doc', array('title' => 'help')), ++ _('Help')); ++ common_element_end('ul'); +hunk ./lib/util.php 348 +- common_element_start('ul', array('id' => 'nav_sub')); +- common_menu_item(common_local_url('doc', array('title' => 'help')), +- _('Help')); +- common_menu_item(common_local_url('doc', array('title' => 'about')), +- _('About')); +- common_menu_item(common_local_url('doc', array('title' => 'faq')), +- _('FAQ')); +- common_menu_item(common_local_url('doc', array('title' => 'privacy')), +- _('Privacy')); +- common_menu_item(common_local_url('doc', array('title' => 'source')), +- _('Source')); +- common_menu_item(common_local_url('doc', array('title' => 'contact')), +- _('Contact')); +- common_element_end('ul'); ++ common_element_start('ul', array('id' => 'nav_sub')); ++ common_menu_item(common_local_url('doc', array('title' => 'help')), ++ _('Help')); ++ common_menu_item(common_local_url('doc', array('title' => 'about')), ++ _('About')); ++ common_menu_item(common_local_url('doc', array('title' => 'faq')), ++ _('FAQ')); ++ common_menu_item(common_local_url('doc', array('title' => 'privacy')), ++ _('Privacy')); ++ common_menu_item(common_local_url('doc', array('title' => 'source')), ++ _('Source')); ++ common_menu_item(common_local_url('doc', array('title' => 'contact')), ++ _('Contact')); ++ common_element_end('ul'); +hunk ./lib/util.php 364 +-function common_menu_item($url, $text, $title=NULL, $is_selected=false) { +- $lattrs = array(); +- if ($is_selected) { +- $lattrs['class'] = 'current'; +- } +- common_element_start('li', $lattrs); +- $attrs['href'] = $url; +- if ($title) { +- $attrs['title'] = $title; +- } +- common_element('a', $attrs, $text); +- common_element_end('li'); ++function common_menu_item($url, $text, $title=null, $is_selected=false) { ++ $lattrs = array(); ++ if ($is_selected) { ++ $lattrs['class'] = 'current'; ++ } ++ common_element_start('li', $lattrs); ++ $attrs['href'] = $url; ++ if ($title) { ++ $attrs['title'] = $title; ++ } ++ common_element('a', $attrs, $text); ++ common_element_end('li'); +hunk ./lib/util.php 378 +-function common_input($id, $label, $value=NULL,$instructions=NULL) { +- common_element_start('p'); +- common_element('label', array('for' => $id), $label); +- $attrs = array('name' => $id, +- 'type' => 'text', +- 'class' => 'input_text', +- 'id' => $id); +- if ($value) { +- $attrs['value'] = htmlspecialchars($value); +- } +- common_element('input', $attrs); +- if ($instructions) { +- common_element('span', 'input_instructions', $instructions); +- } +- common_element_end('p'); ++function common_input($id, $label, $value=null,$instructions=null) { ++ common_element_start('p'); ++ common_element('label', array('for' => $id), $label); ++ $attrs = array('name' => $id, ++ 'type' => 'text', ++ 'class' => 'input_text', ++ 'id' => $id); ++ if ($value) { ++ $attrs['value'] = htmlspecialchars($value); ++ } ++ common_element('input', $attrs); ++ if ($instructions) { ++ common_element('span', 'input_instructions', $instructions); ++ } ++ common_element_end('p'); +hunk ./lib/util.php 395 +-function common_checkbox($id, $label, $checked=false, $instructions=NULL, $value='true', $disabled=false) ++function common_checkbox($id, $label, $checked=false, $instructions=null, $value='true', $disabled=false) +hunk ./lib/util.php 397 +- common_element_start('p'); +- $attrs = array('name' => $id, +- 'type' => 'checkbox', +- 'class' => 'checkbox', +- 'id' => $id); +- if ($value) { +- $attrs['value'] = htmlspecialchars($value); +- } +- if ($checked) { +- $attrs['checked'] = 'checked'; +- } +- if ($disabled) { +- $attrs['disabled'] = 'true'; +- } +- common_element('input', $attrs); +- common_text(' '); +- common_element('label', array('class' => 'checkbox_label', 'for' => $id), $label); +- common_text(' '); +- if ($instructions) { +- common_element('span', 'input_instructions', $instructions); +- } +- common_element_end('p'); ++ common_element_start('p'); ++ $attrs = array('name' => $id, ++ 'type' => 'checkbox', ++ 'class' => 'checkbox', ++ 'id' => $id); ++ if ($value) { ++ $attrs['value'] = htmlspecialchars($value); ++ } ++ if ($checked) { ++ $attrs['checked'] = 'checked'; ++ } ++ if ($disabled) { ++ $attrs['disabled'] = 'true'; ++ } ++ common_element('input', $attrs); ++ common_text(' '); ++ common_element('label', array('class' => 'checkbox_label', 'for' => $id), $label); ++ common_text(' '); ++ if ($instructions) { ++ common_element('span', 'input_instructions', $instructions); ++ } ++ common_element_end('p'); +hunk ./lib/util.php 421 +-function common_dropdown($id, $label, $content, $instructions=NULL, $blank_select=FALSE, $selected=NULL) { +- common_element_start('p'); +- common_element('label', array('for' => $id), $label); +- common_element_start('select', array('id' => $id, 'name' => $id)); +- if ($blank_select) { +- common_element('option', array('value' => '')); +- } +- foreach ($content as $value => $option) { +- if ($value == $selected) { +- common_element('option', array('value' => $value, 'selected' => $value), $option); +- } else { +- common_element('option', array('value' => $value), $option); +- } +- } +- common_element_end('select'); +- if ($instructions) { +- common_element('span', 'input_instructions', $instructions); +- } +- common_element_end('p'); ++function common_dropdown($id, $label, $content, $instructions=null, $blank_select=FALSE, $selected=null) { ++ common_element_start('p'); ++ common_element('label', array('for' => $id), $label); ++ common_element_start('select', array('id' => $id, 'name' => $id)); ++ if ($blank_select) { ++ common_element('option', array('value' => '')); ++ } ++ foreach ($content as $value => $option) { ++ if ($value == $selected) { ++ common_element('option', array('value' => $value, 'selected' => $value), $option); ++ } else { ++ common_element('option', array('value' => $value), $option); ++ } ++ } ++ common_element_end('select'); ++ if ($instructions) { ++ common_element('span', 'input_instructions', $instructions); ++ } ++ common_element_end('p'); +hunk ./lib/util.php 442 +- common_element('input', array('name' => $id, +- 'type' => 'hidden', +- 'id' => $id, +- 'value' => $value)); ++ common_element('input', array('name' => $id, ++ 'type' => 'hidden', ++ 'id' => $id, ++ 'value' => $value)); +hunk ./lib/util.php 448 +-function common_password($id, $label, $instructions=NULL) { +- common_element_start('p'); +- common_element('label', array('for' => $id), $label); +- $attrs = array('name' => $id, +- 'type' => 'password', +- 'class' => 'password', +- 'id' => $id); +- common_element('input', $attrs); +- if ($instructions) { +- common_element('span', 'input_instructions', $instructions); +- } +- common_element_end('p'); ++function common_password($id, $label, $instructions=null) { ++ common_element_start('p'); ++ common_element('label', array('for' => $id), $label); ++ $attrs = array('name' => $id, ++ 'type' => 'password', ++ 'class' => 'password', ++ 'id' => $id); ++ common_element('input', $attrs); ++ if ($instructions) { ++ common_element('span', 'input_instructions', $instructions); ++ } ++ common_element_end('p'); +hunk ./lib/util.php 463 +- global $xw; +- common_element_start('p'); +- common_element('input', array('type' => 'submit', +- 'id' => $id, +- 'name' => $id, +- 'class' => $cls, +- 'value' => $label)); +- common_element_end('p'); ++ global $xw; ++ common_element_start('p'); ++ common_element('input', array('type' => 'submit', ++ 'id' => $id, ++ 'name' => $id, ++ 'class' => $cls, ++ 'value' => $label)); ++ common_element_end('p'); +hunk ./lib/util.php 473 +-function common_textarea($id, $label, $content=NULL, $instructions=NULL) { +- common_element_start('p'); +- common_element('label', array('for' => $id), $label); +- common_element('textarea', array('rows' => 3, +- 'cols' => 40, +- 'name' => $id, +- 'id' => $id), +- ($content) ? $content : ''); +- if ($instructions) { +- common_element('span', 'input_instructions', $instructions); +- } +- common_element_end('p'); ++function common_textarea($id, $label, $content=null, $instructions=null) { ++ common_element_start('p'); ++ common_element('label', array('for' => $id), $label); ++ common_element('textarea', array('rows' => 3, ++ 'cols' => 40, ++ 'name' => $id, ++ 'id' => $id), ++ ($content) ? $content : ''); ++ if ($instructions) { ++ common_element('span', 'input_instructions', $instructions); ++ } ++ common_element_end('p'); +hunk ./lib/util.php 488 +- if (common_logged_in()) { +- $user = common_current_user(); +- if ($user->timezone) { +- return $user->timezone; +- } +- } ++ if (common_logged_in()) { ++ $user = common_current_user(); ++ if ($user->timezone) { ++ return $user->timezone; ++ } ++ } +hunk ./lib/util.php 495 +- global $config; +- return $config['site']['timezone']; ++ global $config; ++ return $config['site']['timezone']; +hunk ./lib/util.php 501 +- // If there is a user logged in and they've set a language preference +- // then return that one... +- if (common_logged_in()) { +- $user = common_current_user(); +- $user_language = $user->language; +- if ($user_language) +- return $user_language; +- } ++ // If there is a user logged in and they've set a language preference ++ // then return that one... ++ if (common_logged_in()) { ++ $user = common_current_user(); ++ $user_language = $user->language; ++ if ($user_language) ++ return $user_language; ++ } +hunk ./lib/util.php 510 +- // Otherwise, find the best match for the languages requested by the +- // user's browser... +- $httplang = isset($_SERVER['HTTP_ACCEPT_LANGUAGE']) ? $_SERVER['HTTP_ACCEPT_LANGUAGE'] : NULL; +- if (!empty($httplang)) { +- $language = client_prefered_language($httplang); +- if ($language) +- return $language; +- } ++ // Otherwise, find the best match for the languages requested by the ++ // user's browser... ++ $httplang = isset($_SERVER['HTTP_ACCEPT_LANGUAGE']) ? $_SERVER['HTTP_ACCEPT_LANGUAGE'] : null; ++ if (!empty($httplang)) { ++ $language = client_prefered_language($httplang); ++ if ($language) ++ return $language; ++ } +hunk ./lib/util.php 519 +- // Finally, if none of the above worked, use the site's default... +- return common_config('site', 'language'); ++ // Finally, if none of the above worked, use the site's default... ++ return common_config('site', 'language'); +hunk ./lib/util.php 522 +-# salted, hashed passwords are stored in the DB ++// salted, hashed passwords are stored in the DB +hunk ./lib/util.php 525 +- return md5($password . $id); ++ return md5($password . $id); +hunk ./lib/util.php 528 +-# check if a username exists and has matching password ++// check if a username exists and has matching password +hunk ./lib/util.php 530 +- # NEVER allow blank passwords, even if they match the DB +- if (mb_strlen($password) == 0) { +- return false; +- } +- $user = User::staticGet('nickname', $nickname); +- if (is_null($user)) { +- return false; +- } else { +- if (0 == strcmp(common_munge_password($password, $user->id), +- $user->password)) { +- return $user; +- } else { +- return false; +- } +- } ++ // NEVER allow blank passwords, even if they match the DB ++ if (mb_strlen($password) == 0) { ++ return false; ++ } ++ $user = User::staticGet('nickname', $nickname); ++ if (is_null($user)) { ++ return false; ++ } else { ++ if (0 == strcmp(common_munge_password($password, $user->id), ++ $user->password)) { ++ return $user; ++ } else { ++ return false; ++ } ++ } +hunk ./lib/util.php 547 +-# is the current user logged in? ++// is the current user logged in? +hunk ./lib/util.php 549 +- return (!is_null(common_current_user())); ++ return (!is_null(common_current_user())); +hunk ./lib/util.php 553 +- return (0 != strcmp(session_id(), '')); ++ return (0 != strcmp(session_id(), '')); +hunk ./lib/util.php 557 +- if (!common_have_session()) { +- @session_start(); +- } ++ if (!common_have_session()) { ++ @session_start(); ++ } +hunk ./lib/util.php 562 +-# Three kinds of arguments: +-# 1) a user object +-# 2) a nickname +-# 3) NULL to clear ++// Three kinds of arguments: ++// 1) a user object ++// 2) a nickname ++// 3) null to clear +hunk ./lib/util.php 567 +-# Initialize to false; set to NULL if none found ++// Initialize to false; set to null if none found +hunk ./lib/util.php 575 +- if (is_null($user) && common_have_session()) { +- $_cur = NULL; +- unset($_SESSION['userid']); +- return true; +- } else if (is_string($user)) { +- $nickname = $user; +- $user = User::staticGet('nickname', $nickname); +- } else if (!($user instanceof User)) { +- return false; +- } ++ if (is_null($user) && common_have_session()) { ++ $_cur = null; ++ unset($_SESSION['userid']); ++ return true; ++ } else if (is_string($user)) { ++ $nickname = $user; ++ $user = User::staticGet('nickname', $nickname); ++ } else if (!($user instanceof User)) { ++ return false; ++ } +hunk ./lib/util.php 586 +- if ($user) { +- common_ensure_session(); +- $_SESSION['userid'] = $user->id; ++ if ($user) { ++ common_ensure_session(); ++ $_SESSION['userid'] = $user->id; +hunk ./lib/util.php 590 +- return $_cur; +- } +- return false; ++ return $_cur; ++ } ++ return false; +hunk ./lib/util.php 596 +- $path = common_config('site', 'path'); +- $server = common_config('site', 'server'); ++ $path = common_config('site', 'path'); ++ $server = common_config('site', 'server'); +hunk ./lib/util.php 599 +- if ($path && ($path != '/')) { +- $cookiepath = '/' . $path . '/'; +- } else { +- $cookiepath = '/'; +- } +- return setcookie($key, +- $value, +- $expiration, +- $cookiepath, +- $server); ++ if ($path && ($path != '/')) { ++ $cookiepath = '/' . $path . '/'; ++ } else { ++ $cookiepath = '/'; ++ } ++ return setcookie($key, ++ $value, ++ $expiration, ++ $cookiepath, ++ $server); +hunk ./lib/util.php 612 +-define('REMEMBERME_EXPIRY', 30 * 24 * 60 * 60); # 30 days ++define('REMEMBERME_EXPIRY', 30 * 24 * 60 * 60); // 30 days +hunk ./lib/util.php 614 +-function common_rememberme($user=NULL) { +- if (!$user) { +- $user = common_current_user(); +- if (!$user) { +- common_debug('No current user to remember', __FILE__); +- return false; +- } +- } ++function common_rememberme($user=null) { ++ if (!$user) { ++ $user = common_current_user(); ++ if (!$user) { ++ common_debug('No current user to remember', __FILE__); ++ return false; ++ } ++ } +hunk ./lib/util.php 623 +- $rm = new Remember_me(); ++ $rm = new Remember_me(); +hunk ./lib/util.php 625 +- $rm->code = common_good_rand(16); +- $rm->user_id = $user->id; ++ $rm->code = common_good_rand(16); ++ $rm->user_id = $user->id; +hunk ./lib/util.php 628 +- # Wrap the insert in some good ol' fashioned transaction code ++ // Wrap the insert in some good ol' fashioned transaction code +hunk ./lib/util.php 632 +- $result = $rm->insert(); ++ $result = $rm->insert(); +hunk ./lib/util.php 634 +- if (!$result) { +- common_log_db_error($rm, 'INSERT', __FILE__); +- common_debug('Error adding rememberme record for ' . $user->nickname, __FILE__); +- return false; ++ if (!$result) { ++ common_log_db_error($rm, 'INSERT', __FILE__); ++ common_debug('Error adding rememberme record for ' . $user->nickname, __FILE__); ++ return false; +hunk ./lib/util.php 642 +- common_debug('Inserted rememberme record (' . $rm->code . ', ' . $rm->user_id . '); result = ' . $result . '.', __FILE__); ++ common_debug('Inserted rememberme record (' . $rm->code . ', ' . $rm->user_id . '); result = ' . $result . '.', __FILE__); +hunk ./lib/util.php 646 +- common_log(LOG_INFO, 'adding rememberme cookie "' . $cookieval . '" for ' . $user->nickname); ++ common_log(LOG_INFO, 'adding rememberme cookie "' . $cookieval . '" for ' . $user->nickname); +hunk ./lib/util.php 648 +- common_set_cookie(REMEMBERME, $cookieval, time() + REMEMBERME_EXPIRY); ++ common_set_cookie(REMEMBERME, $cookieval, time() + REMEMBERME_EXPIRY); +hunk ./lib/util.php 650 +- return true; ++ return true; +hunk ./lib/util.php 655 +- $user = NULL; ++ $user = null; +hunk ./lib/util.php 657 +- $packed = isset($_COOKIE[REMEMBERME]) ? $_COOKIE[REMEMBERME] : NULL; ++ $packed = isset($_COOKIE[REMEMBERME]) ? $_COOKIE[REMEMBERME] : null; +hunk ./lib/util.php 659 +- if (!$packed) { +- return NULL; ++ if (!$packed) { ++ return null; +hunk ./lib/util.php 668 +- return NULL; ++ return null; +hunk ./lib/util.php 676 +- return NULL; ++ return null; +hunk ./lib/util.php 682 +- return NULL; ++ return null; +hunk ./lib/util.php 690 +- return NULL; ++ return null; +hunk ./lib/util.php 693 +- # successful! ++ // successful! +hunk ./lib/util.php 700 +- return NULL; ++ return null; +hunk ./lib/util.php 708 +- # We issue a new cookie, so they can log in +- # automatically again after this session ++ // We issue a new cookie, so they can log in ++ // automatically again after this session +hunk ./lib/util.php 713 +- return $user; ++ return $user; +hunk ./lib/util.php 716 +-# must be called with a valid user! ++// must be called with a valid user! +hunk ./lib/util.php 719 +- common_set_cookie(REMEMBERME, '', 0); ++ common_set_cookie(REMEMBERME, '', 0); +hunk ./lib/util.php 722 +-# who is the current user? ++// who is the current user? +hunk ./lib/util.php 737 +- # that didn't work; try to remember; will init $_cur to NULL on failure ++ // that didn't work; try to remember; will init $_cur to null on failure +hunk ./lib/util.php 743 +- # XXX: Is this necessary? ++ // XXX: Is this necessary? +hunk ./lib/util.php 748 +- return $_cur; ++ return $_cur; +hunk ./lib/util.php 751 +-# Logins that are 'remembered' aren't 'real' -- they're subject to +-# cookie-stealing. So, we don't let them do certain things. New reg, +-# OpenID, and password logins _are_ real. ++// Logins that are 'remembered' aren't 'real' -- they're subject to ++// cookie-stealing. So, we don't let them do certain things. New reg, ++// OpenID, and password logins _are_ real. +hunk ./lib/util.php 756 +- common_ensure_session(); +- $_SESSION['real_login'] = $real; ++ common_ensure_session(); ++ $_SESSION['real_login'] = $real; +hunk ./lib/util.php 761 +- return common_logged_in() && $_SESSION['real_login']; ++ return common_logged_in() && $_SESSION['real_login']; +hunk ./lib/util.php 764 +-# get canonical version of nickname for comparison ++// get canonical version of nickname for comparison +hunk ./lib/util.php 766 +- # XXX: UTF-8 canonicalization (like combining chars) +- return strtolower($nickname); ++ // XXX: UTF-8 canonicalization (like combining chars) ++ return strtolower($nickname); +hunk ./lib/util.php 770 +-# get canonical version of email for comparison ++// get canonical version of email for comparison +hunk ./lib/util.php 772 +- # XXX: canonicalize UTF-8 +- # XXX: lcase the domain part +- return $email; ++ // XXX: canonicalize UTF-8 ++ // XXX: lcase the domain part ++ return $email; +hunk ./lib/util.php 780 +- $r = common_render_text($text); +- $id = $notice->profile_id; +- $r = preg_replace('/(^|\s+)@([A-Za-z0-9]{1,64})/e', "'\\1@'.common_at_link($id, '\\2')", $r); +- $r = preg_replace('/^T ([A-Z0-9]{1,64}) /e', "'T '.common_at_link($id, '\\1').' '", $r); +- $r = preg_replace('/(^|\s+)@#([A-Za-z0-9]{1,64})/e', "'\\1@#'.common_at_hash_link($id, '\\2')", $r); +- return $r; ++ $r = common_render_text($text); ++ $id = $notice->profile_id; ++ $r = preg_replace('/(^|\s+)@([A-Za-z0-9]{1,64})/e', "'\\1@'.common_at_link($id, '\\2')", $r); ++ $r = preg_replace('/^T ([A-Z0-9]{1,64}) /e', "'T '.common_at_link($id, '\\1').' '", $r); ++ $r = preg_replace('/(^|\s+)@#([A-Za-z0-9]{1,64})/e', "'\\1@#'.common_at_hash_link($id, '\\2')", $r); ++ return $r; +hunk ./lib/util.php 789 +- $r = htmlspecialchars($text); ++ $r = htmlspecialchars($text); +hunk ./lib/util.php 791 +- $r = preg_replace('/[\x{0}-\x{8}\x{b}-\x{c}\x{e}-\x{19}]/', '', $r); +- $r = preg_replace_callback('@https?://[^\]>\s]+@', 'common_render_uri_thingy', $r); +- $r = preg_replace('/(^|\s+)#([A-Za-z0-9_\-\.]{1,64})/e', "'\\1#'.common_tag_link('\\2')", $r); +- # XXX: machine tags +- return $r; ++ $r = preg_replace('/[\x{0}-\x{8}\x{b}-\x{c}\x{e}-\x{19}]/', '', $r); ++ $r = preg_replace_callback('@https?://[^\]>\s]+@', 'common_render_uri_thingy', $r); ++ $r = preg_replace('/(^|\s+)#([A-Za-z0-9_\-\.]{1,64})/e', "'\\1#'.common_tag_link('\\2')", $r); ++ // XXX: machine tags ++ return $r; +hunk ./lib/util.php 799 +- $uri = $matches[0]; +- $trailer = ''; ++ $uri = $matches[0]; ++ $trailer = ''; +hunk ./lib/util.php 802 +- # Some heuristics for extracting URIs from surrounding punctuation +- # Strip from trailing text... +- if (preg_match('/^(.*)([,.:"\']+)$/', $uri, $matches)) { +- $uri = $matches[1]; +- $trailer = $matches[2]; +- } ++ // Some heuristics for extracting URIs from surrounding punctuation ++ // Strip from trailing text... ++ if (preg_match('/^(.*)([,.:"\']+)$/', $uri, $matches)) { ++ $uri = $matches[1]; ++ $trailer = $matches[2]; ++ } +hunk ./lib/util.php 809 +- $pairs = array( +- ']' => '[', # technically disallowed in URIs, but used in Java docs +- ')' => '(', # far too frequent in Wikipedia and MSDN +- ); +- $final = substr($uri, -1, 1); +- if (isset($pairs[$final])) { +- $openers = substr_count($uri, $pairs[$final]); +- $closers = substr_count($uri, $final); +- if ($closers > $openers) { +- // Assume the paren was opened outside the URI +- $uri = substr($uri, 0, -1); +- $trailer = $final . $trailer; +- } +- } +- if ($longurl = common_longurl($uri)) { +- $longurl = htmlentities($longurl, ENT_QUOTES, 'UTF-8'); +- $title = " title='$longurl'"; +- } +- else $title = ''; ++ $pairs = array( ++ ']' => '[', // technically disallowed in URIs, but used in Java docs ++ ')' => '(', // far too frequent in Wikipedia and MSDN ++ ); ++ $final = substr($uri, -1, 1); ++ if (isset($pairs[$final])) { ++ $openers = substr_count($uri, $pairs[$final]); ++ $closers = substr_count($uri, $final); ++ if ($closers > $openers) { ++ // Assume the paren was opened outside the URI ++ $uri = substr($uri, 0, -1); ++ $trailer = $final . $trailer; ++ } ++ } ++ if ($longurl = common_longurl($uri)) { ++ $longurl = htmlentities($longurl, ENT_QUOTES, 'UTF-8'); ++ $title = " title='$longurl'"; ++ } ++ else $title = ''; +hunk ./lib/util.php 829 +- return '' . $uri . '' . $trailer; ++ return '' . $uri . '' . $trailer; +hunk ./lib/util.php 839 +- $uri_e = urlencode($uri); +- $longurl = unserialize(file_get_contents("http://api.longurl.org/v1/expand?format=php&url=$uri_e")); +- if (empty($longurl['long_url']) || $uri === $longurl['long_url']) return false; +- return stripslashes($longurl['long_url']); ++ $uri_e = urlencode($uri); ++ $longurl = unserialize(file_get_contents("http://api.longurl.org/v1/expand?format=php&url=$uri_e")); ++ if (empty($longurl['long_url']) || $uri === $longurl['long_url']) return false; ++ return stripslashes($longurl['long_url']); +hunk ./lib/util.php 850 +- return $cache[$text] = preg_replace('@https?://[^)\]>\s]+@e', "common_shorten_link('\\0')", $text); ++ return $cache[$text] = preg_replace('@https?://[^)\]>\s]+@e', "common_shorten_link('\\0')", $text); +hunk ./lib/util.php 854 +- static $url_cache = array(); ++ static $url_cache = array(); +hunk ./lib/util.php 857 +- $user = common_current_user(); ++ $user = common_current_user(); +hunk ./lib/util.php 859 +- $curlh = curl_init(); +- curl_setopt($curlh, CURLOPT_CONNECTTIMEOUT, 20); // # seconds to wait +- curl_setopt($curlh, CURLOPT_USERAGENT, 'Laconica'); +- curl_setopt($curlh, CURLOPT_RETURNTRANSFER, true); ++ $curlh = curl_init(); ++ curl_setopt($curlh, CURLOPT_CONNECTTIMEOUT, 20); // # seconds to wait ++ curl_setopt($curlh, CURLOPT_USERAGENT, 'Laconica'); ++ curl_setopt($curlh, CURLOPT_RETURNTRANSFER, true); +hunk ./lib/util.php 864 +- switch($user->urlshorteningservice) { +- case 'ur1.ca': +- $short_url_service = new LilUrl; +- $short_url = $short_url_service->shorten($url); +- break; ++ switch($user->urlshorteningservice) { ++ case 'ur1.ca': ++ $short_url_service = new LilUrl; ++ $short_url = $short_url_service->shorten($url); ++ break; +hunk ./lib/util.php 870 +- case '2tu.us': +- $short_url_service = new TightUrl; +- $short_url = $short_url_service->shorten($url); +- break; ++ case '2tu.us': ++ $short_url_service = new TightUrl; ++ $short_url = $short_url_service->shorten($url); ++ break; +hunk ./lib/util.php 875 +- case 'ptiturl.com': +- $short_url_service = new PtitUrl; +- $short_url = $short_url_service->shorten($url); +- break; ++ case 'ptiturl.com': ++ $short_url_service = new PtitUrl; ++ $short_url = $short_url_service->shorten($url); ++ break; +hunk ./lib/util.php 880 +- case 'bit.ly': +- curl_setopt($curlh, CURLOPT_URL, 'http://bit.ly/api?method=shorten&long_url='.urlencode($url)); +- $short_url = current(json_decode(curl_exec($curlh))->results)->hashUrl; +- break; ++ case 'bit.ly': ++ curl_setopt($curlh, CURLOPT_URL, 'http://bit.ly/api?method=shorten&long_url='.urlencode($url)); ++ $short_url = current(json_decode(curl_exec($curlh))->results)->hashUrl; ++ break; +hunk ./lib/util.php 885 +- case 'is.gd': +- curl_setopt($curlh, CURLOPT_URL, 'http://is.gd/api.php?longurl='.urlencode($url)); +- $short_url = curl_exec($curlh); +- break; +- case 'snipr.com': +- curl_setopt($curlh, CURLOPT_URL, 'http://snipr.com/site/snip?r=simple&link='.urlencode($url)); +- $short_url = curl_exec($curlh); +- break; +- case 'metamark.net': +- curl_setopt($curlh, CURLOPT_URL, 'http://metamark.net/api/rest/simple?long_url='.urlencode($url)); +- $short_url = curl_exec($curlh); +- break; +- case 'tinyurl.com': +- curl_setopt($curlh, CURLOPT_URL, 'http://tinyurl.com/api-create.php?url='.urlencode($url)); +- $short_url = curl_exec($curlh); +- break; +- default: +- $short_url = false; +- } ++ case 'is.gd': ++ curl_setopt($curlh, CURLOPT_URL, 'http://is.gd/api.php?longurl='.urlencode($url)); ++ $short_url = curl_exec($curlh); ++ break; ++ case 'snipr.com': ++ curl_setopt($curlh, CURLOPT_URL, 'http://snipr.com/site/snip?r=simple&link='.urlencode($url)); ++ $short_url = curl_exec($curlh); ++ break; ++ case 'metamark.net': ++ curl_setopt($curlh, CURLOPT_URL, 'http://metamark.net/api/rest/simple?long_url='.urlencode($url)); ++ $short_url = curl_exec($curlh); ++ break; ++ case 'tinyurl.com': ++ curl_setopt($curlh, CURLOPT_URL, 'http://tinyurl.com/api-create.php?url='.urlencode($url)); ++ $short_url = curl_exec($curlh); ++ break; ++ default: ++ $short_url = false; ++ } +hunk ./lib/util.php 905 +- curl_close($curlh); ++ curl_close($curlh); +hunk ./lib/util.php 907 +- if ($short_url) { ++ if ($short_url) { +hunk ./lib/util.php 909 +- return (string)$short_url; +- } +- return $url; ++ return (string)$short_url; ++ } ++ return $url; +hunk ./lib/util.php 915 +- $xmlStr = htmlentities(iconv('UTF-8', 'UTF-8//IGNORE', $str), ENT_NOQUOTES, 'UTF-8'); ++ $xmlStr = htmlentities(iconv('UTF-8', 'UTF-8//IGNORE', $str), ENT_NOQUOTES, 'UTF-8'); +hunk ./lib/util.php 917 +- // Replace control, formatting, and surrogate characters with '*', ala Twitter +- return preg_replace('/[\p{Cc}\p{Cf}\p{Cs}]/u', '*', $str); ++ // Replace control, formatting, and surrogate characters with '*', ala Twitter ++ return preg_replace('/[\p{Cc}\p{Cf}\p{Cs}]/u', '*', $str); +hunk ./lib/util.php 922 +- $canonical = common_canonical_tag($tag); +- $url = common_local_url('tag', array('tag' => $canonical)); +- return ''; ++ $canonical = common_canonical_tag($tag); ++ $url = common_local_url('tag', array('tag' => $canonical)); ++ return ''; +hunk ./lib/util.php 928 +- return strtolower(str_replace(array('-', '_', '.'), '', $tag)); ++ return strtolower(str_replace(array('-', '_', '.'), '', $tag)); +hunk ./lib/util.php 932 +- return preg_match('/^[A-Za-z0-9_\-\.]{1,64}$/', $str); ++ return preg_match('/^[A-Za-z0-9_\-\.]{1,64}$/', $str); +hunk ./lib/util.php 936 +- $sender = Profile::staticGet($sender_id); +- $recipient = common_relative_profile($sender, common_canonical_nickname($nickname)); +- if ($recipient) { +- return ''.$nickname.''; +- } else { +- return $nickname; +- } ++ $sender = Profile::staticGet($sender_id); ++ $recipient = common_relative_profile($sender, common_canonical_nickname($nickname)); ++ if ($recipient) { ++ return ''.$nickname.''; ++ } else { ++ return $nickname; ++ } +hunk ./lib/util.php 946 +- $user = User::staticGet($sender_id); +- if (!$user) { +- return $tag; +- } +- $tagged = Profile_tag::getTagged($user->id, common_canonical_tag($tag)); +- if ($tagged) { +- $url = common_local_url('subscriptions', +- array('nickname' => $user->nickname, +- 'tag' => $tag)); +- return ''.$tag.''; +- } else { +- return $tag; +- } ++ $user = User::staticGet($sender_id); ++ if (!$user) { ++ return $tag; ++ } ++ $tagged = Profile_tag::getTagged($user->id, common_canonical_tag($tag)); ++ if ($tagged) { ++ $url = common_local_url('subscriptions', ++ array('nickname' => $user->nickname, ++ 'tag' => $tag)); ++ return ''.$tag.''; ++ } else { ++ return $tag; ++ } +hunk ./lib/util.php 961 +-function common_relative_profile($sender, $nickname, $dt=NULL) { +- # Try to find profiles this profile is subscribed to that have this nickname +- $recipient = new Profile(); +- # XXX: use a join instead of a subquery +- $recipient->whereAdd('EXISTS (SELECT subscribed from subscription where subscriber = '.$sender->id.' and subscribed = id)', 'AND'); +- $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); +- if ($recipient->find(TRUE)) { +- # XXX: should probably differentiate between profiles with +- # the same name by date of most recent update +- return $recipient; +- } +- # Try to find profiles that listen to this profile and that have this nickname +- $recipient = new Profile(); +- # XXX: use a join instead of a subquery +- $recipient->whereAdd('EXISTS (SELECT subscriber from subscription where subscribed = '.$sender->id.' and subscriber = id)', 'AND'); +- $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); +- if ($recipient->find(TRUE)) { +- # XXX: should probably differentiate between profiles with +- # the same name by date of most recent update +- return $recipient; +- } +- # If this is a local user, try to find a local user with that nickname. +- $sender = User::staticGet($sender->id); +- if ($sender) { +- $recipient_user = User::staticGet('nickname', $nickname); +- if ($recipient_user) { +- return $recipient_user->getProfile(); +- } +- } +- # Otherwise, no links. @messages from local users to remote users, +- # or from remote users to other remote users, are just +- # outside our ability to make intelligent guesses about +- return NULL; ++function common_relative_profile($sender, $nickname, $dt=null) { ++ // Try to find profiles this profile is subscribed to that have this nickname ++ $recipient = new Profile(); ++ // XXX: use a join instead of a subquery ++ $recipient->whereAdd('EXISTS (SELECT subscribed from subscription where subscriber = '.$sender->id.' and subscribed = id)', 'AND'); ++ $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); ++ if ($recipient->find(TRUE)) { ++ // XXX: should probably differentiate between profiles with ++ // the same name by date of most recent update ++ return $recipient; ++ } ++ // Try to find profiles that listen to this profile and that have this nickname ++ $recipient = new Profile(); ++ // XXX: use a join instead of a subquery ++ $recipient->whereAdd('EXISTS (SELECT subscriber from subscription where subscribed = '.$sender->id.' and subscriber = id)', 'AND'); ++ $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); ++ if ($recipient->find(TRUE)) { ++ // XXX: should probably differentiate between profiles with ++ // the same name by date of most recent update ++ return $recipient; ++ } ++ // If this is a local user, try to find a local user with that nickname. ++ $sender = User::staticGet($sender->id); ++ if ($sender) { ++ $recipient_user = User::staticGet('nickname', $nickname); ++ if ($recipient_user) { ++ return $recipient_user->getProfile(); ++ } ++ } ++ // Otherwise, no links. @messages from local users to remote users, ++ // or from remote users to other remote users, are just ++ // outside our ability to make intelligent guesses about ++ return null; +hunk ./lib/util.php 998 +-function common_avatar_filename($id, $extension, $size=NULL, $extra=NULL) { +- global $config; ++function common_avatar_filename($id, $extension, $size=null, $extra=null) { ++ global $config; +hunk ./lib/util.php 1001 +- if ($size) { +- return $id . '-' . $size . (($extra) ? ('-' . $extra) : '') . $extension; +- } else { +- return $id . '-original' . (($extra) ? ('-' . $extra) : '') . $extension; +- } ++ if ($size) { ++ return $id . '-' . $size . (($extra) ? ('-' . $extra) : '') . $extension; ++ } else { ++ return $id . '-original' . (($extra) ? ('-' . $extra) : '') . $extension; ++ } +hunk ./lib/util.php 1009 +- global $config; +- return INSTALLDIR . '/avatar/' . $filename; ++ global $config; ++ return INSTALLDIR . '/avatar/' . $filename; +hunk ./lib/util.php 1014 +- return common_path('avatar/'.$filename); ++ return common_path('avatar/'.$filename); +hunk ./lib/util.php 1018 +- $server = common_config('avatar', 'server'); +- if ($server) { +- return 'http://'.$server.'/'.$avatar->filename; +- } else { +- return $avatar->url; +- } ++ $server = common_config('avatar', 'server'); ++ if ($server) { ++ return 'http://'.$server.'/'.$avatar->filename; ++ } else { ++ return $avatar->url; ++ } +hunk ./lib/util.php 1027 +- static $sizenames = array(AVATAR_PROFILE_SIZE => 'profile', +- AVATAR_STREAM_SIZE => 'stream', +- AVATAR_MINI_SIZE => 'mini'); +- return theme_path('default-avatar-'.$sizenames[$size].'.png'); ++ static $sizenames = array(AVATAR_PROFILE_SIZE => 'profile', ++ AVATAR_STREAM_SIZE => 'stream', ++ AVATAR_MINI_SIZE => 'mini'); ++ return theme_path('default-avatar-'.$sizenames[$size].'.png'); +hunk ./lib/util.php 1033 +-function common_local_url($action, $args=NULL, $fragment=NULL) { +- $url = NULL; +- if (common_config('site','fancy')) { +- $url = common_fancy_url($action, $args); +- } else { +- $url = common_simple_url($action, $args); +- } +- if (!is_null($fragment)) { +- $url .= '#'.$fragment; +- } +- return $url; ++function common_local_url($action, $args=null, $fragment=null) { ++ $url = null; ++ if (common_config('site','fancy')) { ++ $url = common_fancy_url($action, $args); ++ } else { ++ $url = common_simple_url($action, $args); ++ } ++ if (!is_null($fragment)) { ++ $url .= '#'.$fragment; ++ } ++ return $url; +hunk ./lib/util.php 1046 +-function common_fancy_url($action, $args=NULL) { +- switch (strtolower($action)) { +- case 'public': +- if ($args && isset($args['page'])) { +- return common_path('?page=' . $args['page']); +- } else { +- return common_path(''); +- } +- case 'featured': +- if ($args && isset($args['page'])) { +- return common_path('featured?page=' . $args['page']); +- } else { +- return common_path('featured'); +- } +- case 'favorited': +- if ($args && isset($args['page'])) { +- return common_path('favorited?page=' . $args['page']); +- } else { +- return common_path('favorited'); +- } +- case 'publicrss': +- return common_path('rss'); +- case 'publicatom': +- return common_path("api/statuses/public_timeline.atom"); +- case 'publicxrds': +- return common_path('xrds'); +- case 'featuredrss': +- return common_path('featuredrss'); +- case 'favoritedrss': +- return common_path('favoritedrss'); +- case 'opensearch': +- if ($args && $args['type']) { +- return common_path('opensearch/'.$args['type']); +- } else { +- return common_path('opensearch/people'); +- } +- case 'doc': +- return common_path('doc/'.$args['title']); ++function common_fancy_url($action, $args=null) { ++ switch (strtolower($action)) { ++ case 'public': ++ if ($args && isset($args['page'])) { ++ return common_path('?page=' . $args['page']); ++ } else { ++ return common_path(''); ++ } ++ case 'featured': ++ if ($args && isset($args['page'])) { ++ return common_path('featured?page=' . $args['page']); ++ } else { ++ return common_path('featured'); ++ } ++ case 'favorited': ++ if ($args && isset($args['page'])) { ++ return common_path('favorited?page=' . $args['page']); ++ } else { ++ return common_path('favorited'); ++ } ++ case 'publicrss': ++ return common_path('rss'); ++ case 'publicatom': ++ return common_path("api/statuses/public_timeline.atom"); ++ case 'publicxrds': ++ return common_path('xrds'); ++ case 'featuredrss': ++ return common_path('featuredrss'); ++ case 'favoritedrss': ++ return common_path('favoritedrss'); ++ case 'opensearch': ++ if ($args && $args['type']) { ++ return common_path('opensearch/'.$args['type']); ++ } else { ++ return common_path('opensearch/people'); ++ } ++ case 'doc': ++ return common_path('doc/'.$args['title']); +hunk ./lib/util.php 1085 +- case 'login': +- case 'logout': +- case 'subscribe': +- case 'unsubscribe': +- case 'invite': +- return common_path('main/'.$action); +- case 'tagother': +- return common_path('main/tagother?id='.$args['id']); +- case 'register': +- if ($args && $args['code']) { +- return common_path('main/register/'.$args['code']); +- } else { +- return common_path('main/register'); +- } +- case 'remotesubscribe': +- if ($args && $args['nickname']) { +- return common_path('main/remote?nickname=' . $args['nickname']); +- } else { +- return common_path('main/remote'); +- } +- case 'nudge': +- return common_path($args['nickname'].'/nudge'); +- case 'openidlogin': +- return common_path('main/openid'); +- case 'profilesettings': +- return common_path('settings/profile'); +- case 'emailsettings': +- return common_path('settings/email'); +- case 'openidsettings': +- return common_path('settings/openid'); +- case 'smssettings': +- return common_path('settings/sms'); +- case 'twittersettings': +- return common_path('settings/twitter'); +- case 'othersettings': +- return common_path('settings/other'); ++ case 'login': ++ case 'logout': ++ case 'subscribe': ++ case 'unsubscribe': ++ case 'invite': ++ return common_path('main/'.$action); ++ case 'tagother': ++ return common_path('main/tagother?id='.$args['id']); ++ case 'register': ++ if ($args && $args['code']) { ++ return common_path('main/register/'.$args['code']); ++ } else { ++ return common_path('main/register'); ++ } ++ case 'remotesubscribe': ++ if ($args && $args['nickname']) { ++ return common_path('main/remote?nickname=' . $args['nickname']); ++ } else { ++ return common_path('main/remote'); ++ } ++ case 'nudge': ++ return common_path($args['nickname'].'/nudge'); ++ case 'openidlogin': ++ return common_path('main/openid'); ++ case 'profilesettings': ++ return common_path('settings/profile'); ++ case 'emailsettings': ++ return common_path('settings/email'); ++ case 'openidsettings': ++ return common_path('settings/openid'); ++ case 'smssettings': ++ return common_path('settings/sms'); ++ case 'twittersettings': ++ return common_path('settings/twitter'); ++ case 'othersettings': ++ return common_path('settings/other'); +hunk ./lib/util.php 1123 +- case 'newnotice': +- if ($args && $args['replyto']) { +- return common_path('notice/new?replyto='.$args['replyto']); +- } else { +- return common_path('notice/new'); +- } +- case 'shownotice': +- return common_path('notice/'.$args['notice']); +- case 'deletenotice': +- if ($args && $args['notice']) { +- return common_path('notice/delete/'.$args['notice']); +- } else { +- return common_path('notice/delete'); +- } +- case 'microsummary': +- case 'xrds': +- case 'foaf': +- return common_path($args['nickname'].'/'.$action); +- case 'all': +- case 'replies': +- case 'inbox': +- case 'outbox': +- if ($args && isset($args['page'])) { +- return common_path($args['nickname'].'/'.$action.'?page=' . $args['page']); +- } else { +- return common_path($args['nickname'].'/'.$action); +- } +- case 'subscriptions': +- case 'subscribers': +- $nickname = $args['nickname']; +- unset($args['nickname']); +- if (isset($args['tag'])) { +- $tag = $args['tag']; +- unset($args['tag']); +- } +- $params = http_build_query($args); +- if ($params) { +- return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '') . '?' . $params); +- } else { +- return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '')); +- } +- case 'allrss': +- return common_path($args['nickname'].'/all/rss'); +- case 'repliesrss': +- return common_path($args['nickname'].'/replies/rss'); +- case 'userrss': ++ case 'newnotice': ++ if ($args && $args['replyto']) { ++ return common_path('notice/new?replyto='.$args['replyto']); ++ } else { ++ return common_path('notice/new'); ++ } ++ case 'shownotice': ++ return common_path('notice/'.$args['notice']); ++ case 'deletenotice': ++ if ($args && $args['notice']) { ++ return common_path('notice/delete/'.$args['notice']); ++ } else { ++ return common_path('notice/delete'); ++ } ++ case 'microsummary': ++ case 'xrds': ++ case 'foaf': ++ return common_path($args['nickname'].'/'.$action); ++ case 'all': ++ case 'replies': ++ case 'inbox': ++ case 'outbox': ++ if ($args && isset($args['page'])) { ++ return common_path($args['nickname'].'/'.$action.'?page=' . $args['page']); ++ } else { ++ return common_path($args['nickname'].'/'.$action); ++ } ++ case 'subscriptions': ++ case 'subscribers': ++ $nickname = $args['nickname']; ++ unset($args['nickname']); ++ if (isset($args['tag'])) { ++ $tag = $args['tag']; ++ unset($args['tag']); ++ } ++ $params = http_build_query($args); ++ if ($params) { ++ return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '') . '?' . $params); ++ } else { ++ return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '')); ++ } ++ case 'allrss': ++ return common_path($args['nickname'].'/all/rss'); ++ case 'repliesrss': ++ return common_path($args['nickname'].'/replies/rss'); ++ case 'userrss': +hunk ./lib/util.php 1170 +- return common_path($args['nickname'].'/rss?limit=' . $args['limit']); +- return common_path($args['nickname'].'/rss'); +- case 'showstream': +- if ($args && isset($args['page'])) { +- return common_path($args['nickname'].'?page=' . $args['page']); +- } else { +- return common_path($args['nickname']); +- } ++ return common_path($args['nickname'].'/rss?limit=' . $args['limit']); ++ return common_path($args['nickname'].'/rss'); ++ case 'showstream': ++ if ($args && isset($args['page'])) { ++ return common_path($args['nickname'].'?page=' . $args['page']); ++ } else { ++ return common_path($args['nickname']); ++ } +hunk ./lib/util.php 1179 +- case 'usertimeline': +- return common_path("api/statuses/user_timeline/".$args['nickname'].".atom"); +- case 'confirmaddress': +- return common_path('main/confirmaddress/'.$args['code']); +- case 'userbyid': +- return common_path('user/'.$args['id']); +- case 'recoverpassword': +- $path = 'main/recoverpassword'; +- if ($args['code']) { +- $path .= '/' . $args['code']; +- } +- return common_path($path); +- case 'imsettings': +- return common_path('settings/im'); +- case 'peoplesearch': +- return common_path('search/people' . (($args) ? ('?' . http_build_query($args)) : '')); +- case 'noticesearch': +- return common_path('search/notice' . (($args) ? ('?' . http_build_query($args)) : '')); +- case 'noticesearchrss': +- return common_path('search/notice/rss' . (($args) ? ('?' . http_build_query($args)) : '')); +- case 'avatarbynickname': +- return common_path($args['nickname'].'/avatar/'.$args['size']); +- case 'tag': +- if (isset($args['tag']) && $args['tag']) { +- $path = 'tag/' . $args['tag']; +- unset($args['tag']); +- } else { +- $path = 'tags'; +- } +- return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); +- case 'peopletag': +- $path = 'peopletag/' . $args['tag']; +- unset($args['tag']); +- return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); +- case 'tags': +- return common_path('tags' . (($args) ? ('?' . http_build_query($args)) : '')); +- case 'favor': +- return common_path('main/favor'); +- case 'disfavor': +- return common_path('main/disfavor'); +- case 'showfavorites': +- if ($args && isset($args['page'])) { +- return common_path($args['nickname'].'/favorites?page=' . $args['page']); +- } else { +- return common_path($args['nickname'].'/favorites'); +- } +- case 'favoritesrss': +- return common_path($args['nickname'].'/favorites/rss'); +- case 'showmessage': +- return common_path('message/' . $args['message']); +- case 'newmessage': +- return common_path('message/new' . (($args) ? ('?' . http_build_query($args)) : '')); +- case 'api': +- # XXX: do fancy URLs for all the API methods +- switch (strtolower($args['apiaction'])) { +- case 'statuses': +- switch (strtolower($args['method'])) { +- case 'user_timeline.rss': +- return common_path('api/statuses/user_timeline/'.$args['argument'].'.rss'); +- case 'user_timeline.atom': +- return common_path('api/statuses/user_timeline/'.$args['argument'].'.atom'); +- case 'user_timeline.json': +- return common_path('api/statuses/user_timeline/'.$args['argument'].'.json'); +- case 'user_timeline.xml': +- return common_path('api/statuses/user_timeline/'.$args['argument'].'.xml'); +- default: return common_simple_url($action, $args); +- } +- default: return common_simple_url($action, $args); +- } +- case 'sup': +- if ($args && isset($args['seconds'])) { +- return common_path('main/sup?seconds='.$args['seconds']); +- } else { +- return common_path('main/sup'); +- } +- default: +- return common_simple_url($action, $args); +- } ++ case 'usertimeline': ++ return common_path("api/statuses/user_timeline/".$args['nickname'].".atom"); ++ case 'confirmaddress': ++ return common_path('main/confirmaddress/'.$args['code']); ++ case 'userbyid': ++ return common_path('user/'.$args['id']); ++ case 'recoverpassword': ++ $path = 'main/recoverpassword'; ++ if ($args['code']) { ++ $path .= '/' . $args['code']; ++ } ++ return common_path($path); ++ case 'imsettings': ++ return common_path('settings/im'); ++ case 'peoplesearch': ++ return common_path('search/people' . (($args) ? ('?' . http_build_query($args)) : '')); ++ case 'noticesearch': ++ return common_path('search/notice' . (($args) ? ('?' . http_build_query($args)) : '')); ++ case 'noticesearchrss': ++ return common_path('search/notice/rss' . (($args) ? ('?' . http_build_query($args)) : '')); ++ case 'avatarbynickname': ++ return common_path($args['nickname'].'/avatar/'.$args['size']); ++ case 'tag': ++ if (isset($args['tag']) && $args['tag']) { ++ $path = 'tag/' . $args['tag']; ++ unset($args['tag']); ++ } else { ++ $path = 'tags'; ++ } ++ return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); ++ case 'peopletag': ++ $path = 'peopletag/' . $args['tag']; ++ unset($args['tag']); ++ return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); ++ case 'tags': ++ return common_path('tags' . (($args) ? ('?' . http_build_query($args)) : '')); ++ case 'favor': ++ return common_path('main/favor'); ++ case 'disfavor': ++ return common_path('main/disfavor'); ++ case 'showfavorites': ++ if ($args && isset($args['page'])) { ++ return common_path($args['nickname'].'/favorites?page=' . $args['page']); ++ } else { ++ return common_path($args['nickname'].'/favorites'); ++ } ++ case 'favoritesrss': ++ return common_path($args['nickname'].'/favorites/rss'); ++ case 'showmessage': ++ return common_path('message/' . $args['message']); ++ case 'newmessage': ++ return common_path('message/new' . (($args) ? ('?' . http_build_query($args)) : '')); ++ case 'api': ++ // XXX: do fancy URLs for all the API methods ++ switch (strtolower($args['apiaction'])) { ++ case 'statuses': ++ switch (strtolower($args['method'])) { ++ case 'user_timeline.rss': ++ return common_path('api/statuses/user_timeline/'.$args['argument'].'.rss'); ++ case 'user_timeline.atom': ++ return common_path('api/statuses/user_timeline/'.$args['argument'].'.atom'); ++ case 'user_timeline.json': ++ return common_path('api/statuses/user_timeline/'.$args['argument'].'.json'); ++ case 'user_timeline.xml': ++ return common_path('api/statuses/user_timeline/'.$args['argument'].'.xml'); ++ default: return common_simple_url($action, $args); ++ } ++ default: return common_simple_url($action, $args); ++ } ++ case 'sup': ++ if ($args && isset($args['seconds'])) { ++ return common_path('main/sup?seconds='.$args['seconds']); ++ } else { ++ return common_path('main/sup'); ++ } ++ default: ++ return common_simple_url($action, $args); ++ } +hunk ./lib/util.php 1259 +-function common_simple_url($action, $args=NULL) { +- global $config; +- /* XXX: pretty URLs */ +- $extra = ''; +- if ($args) { +- foreach ($args as $key => $value) { +- $extra .= "&${key}=${value}"; +- } +- } +- return common_path("index.php?action=${action}${extra}"); ++function common_simple_url($action, $args=null) { ++ global $config; ++ /* XXX: pretty URLs */ ++ $extra = ''; ++ if ($args) { ++ foreach ($args as $key => $value) { ++ $extra .= "&${key}=${value}"; ++ } ++ } ++ return common_path("index.php?action=${action}${extra}"); +hunk ./lib/util.php 1272 +- global $config; +- $pathpart = ($config['site']['path']) ? $config['site']['path']."/" : ''; +- return "http://".$config['site']['server'].'/'.$pathpart.$relative; ++ global $config; ++ $pathpart = ($config['site']['path']) ? $config['site']['path']."/" : ''; ++ return "http://".$config['site']['server'].'/'.$pathpart.$relative; +hunk ./lib/util.php 1278 +- // XXX: do some sexy date formatting +- // return date(DATE_RFC822, $dt); +- $t = strtotime($dt); +- $now = time(); +- $diff = $now - $t; ++ // XXX: do some sexy date formatting ++ // return date(DATE_RFC822, $dt); ++ $t = strtotime($dt); ++ $now = time(); ++ $diff = $now - $t; +hunk ./lib/util.php 1284 +- if ($now < $t) { # that shouldn't happen! +- return common_exact_date($dt); +- } else if ($diff < 60) { +- return _('a few seconds ago'); +- } else if ($diff < 92) { +- return _('about a minute ago'); +- } else if ($diff < 3300) { +- return sprintf(_('about %d minutes ago'), round($diff/60)); +- } else if ($diff < 5400) { +- return _('about an hour ago'); +- } else if ($diff < 22 * 3600) { +- return sprintf(_('about %d hours ago'), round($diff/3600)); +- } else if ($diff < 37 * 3600) { +- return _('about a day ago'); +- } else if ($diff < 24 * 24 * 3600) { +- return sprintf(_('about %d days ago'), round($diff/(24*3600))); +- } else if ($diff < 46 * 24 * 3600) { +- return _('about a month ago'); +- } else if ($diff < 330 * 24 * 3600) { +- return sprintf(_('about %d months ago'), round($diff/(30*24*3600))); +- } else if ($diff < 480 * 24 * 3600) { +- return _('about a year ago'); +- } else { +- return common_exact_date($dt); +- } ++ if ($now < $t) { // that shouldn't happen! ++ return common_exact_date($dt); ++ } else if ($diff < 60) { ++ return _('a few seconds ago'); ++ } else if ($diff < 92) { ++ return _('about a minute ago'); ++ } else if ($diff < 3300) { ++ return sprintf(_('about %d minutes ago'), round($diff/60)); ++ } else if ($diff < 5400) { ++ return _('about an hour ago'); ++ } else if ($diff < 22 * 3600) { ++ return sprintf(_('about %d hours ago'), round($diff/3600)); ++ } else if ($diff < 37 * 3600) { ++ return _('about a day ago'); ++ } else if ($diff < 24 * 24 * 3600) { ++ return sprintf(_('about %d days ago'), round($diff/(24*3600))); ++ } else if ($diff < 46 * 24 * 3600) { ++ return _('about a month ago'); ++ } else if ($diff < 330 * 24 * 3600) { ++ return sprintf(_('about %d months ago'), round($diff/(30*24*3600))); ++ } else if ($diff < 480 * 24 * 3600) { ++ return _('about a year ago'); ++ } else { ++ return common_exact_date($dt); ++ } +hunk ./lib/util.php 1320 +- $dateStr = date('d F Y H:i:s', strtotime($dt)); +- $d = new DateTime($dateStr, $_utc); +- $d->setTimezone($_siteTz); +- return $d->format(DATE_RFC850); ++ $dateStr = date('d F Y H:i:s', strtotime($dt)); ++ $d = new DateTime($dateStr, $_utc); ++ $d->setTimezone($_siteTz); ++ return $d->format(DATE_RFC850); +hunk ./lib/util.php 1327 +- $dateStr = date('d F Y H:i:s', strtotime($dt)); +- $d = new DateTime($dateStr, new DateTimeZone('UTC')); +- $d->setTimezone(new DateTimeZone(common_timezone())); +- return $d->format(DATE_W3C); ++ $dateStr = date('d F Y H:i:s', strtotime($dt)); ++ $d = new DateTime($dateStr, new DateTimeZone('UTC')); ++ $d->setTimezone(new DateTimeZone(common_timezone())); ++ return $d->format(DATE_W3C); +hunk ./lib/util.php 1334 +- $dateStr = date('d F Y H:i:s', strtotime($dt)); +- $d = new DateTime($dateStr, new DateTimeZone('UTC')); +- $d->setTimezone(new DateTimeZone(common_timezone())); +- return $d->format('r'); ++ $dateStr = date('d F Y H:i:s', strtotime($dt)); ++ $d = new DateTime($dateStr, new DateTimeZone('UTC')); ++ $d->setTimezone(new DateTimeZone(common_timezone())); ++ return $d->format('r'); +hunk ./lib/util.php 1341 +- $dateStr = date('d F Y H:i:s', strtotime($dt)); +- $d = new DateTime($dateStr, new DateTimeZone('UTC')); +- $d->setTimezone(new DateTimeZone(common_timezone())); +- return $d->format('c'); ++ $dateStr = date('d F Y H:i:s', strtotime($dt)); ++ $d = new DateTime($dateStr, new DateTimeZone('UTC')); ++ $d->setTimezone(new DateTimeZone(common_timezone())); ++ return $d->format('c'); +hunk ./lib/util.php 1348 +- return strftime('%Y-%m-%d %H:%M:%S', time()); ++ return strftime('%Y-%m-%d %H:%M:%S', time()); +hunk ./lib/util.php 1352 +- static $status = array(301 => "Moved Permanently", +- 302 => "Found", +- 303 => "See Other", +- 307 => "Temporary Redirect"); +- header("Status: ${code} $status[$code]"); +- header("Location: $url"); ++ static $status = array(301 => "Moved Permanently", ++ 302 => "Found", ++ 303 => "See Other", ++ 307 => "Temporary Redirect"); ++ header("Status: ${code} $status[$code]"); ++ header("Location: $url"); +hunk ./lib/util.php 1359 +- common_start_xml('a', +- '-//W3C//DTD XHTML 1.0 Strict//EN', +- 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'); +- common_element('a', array('href' => $url), $url); +- common_end_xml(); ++ common_start_xml('a', ++ '-//W3C//DTD XHTML 1.0 Strict//EN', ++ 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'); ++ common_element('a', array('href' => $url), $url); ++ common_end_xml(); +hunk ./lib/util.php 1368 +- # Alternative reply format +- $tname = false; +- if (preg_match('/^T ([A-Z0-9]{1,64}) /', $notice->content, $match)) { +- $tname = $match[1]; +- } +- # extract all @messages +- $cnt = preg_match_all('/(?:^|\s)@([a-z0-9]{1,64})/', $notice->content, $match); ++ // Alternative reply format ++ $tname = false; ++ if (preg_match('/^T ([A-Z0-9]{1,64}) /', $notice->content, $match)) { ++ $tname = $match[1]; ++ } ++ // extract all @messages ++ $cnt = preg_match_all('/(?:^|\s)@([a-z0-9]{1,64})/', $notice->content, $match); +hunk ./lib/util.php 1376 +- $names = array(); ++ $names = array(); +hunk ./lib/util.php 1378 +- if ($cnt || $tname) { +- # XXX: is there another way to make an array copy? +- $names = ($tname) ? array_unique(array_merge(array(strtolower($tname)), $match[1])) : array_unique($match[1]); +- } ++ if ($cnt || $tname) { ++ // XXX: is there another way to make an array copy? ++ $names = ($tname) ? array_unique(array_merge(array(strtolower($tname)), $match[1])) : array_unique($match[1]); ++ } +hunk ./lib/util.php 1383 +- $sender = Profile::staticGet($notice->profile_id); ++ $sender = Profile::staticGet($notice->profile_id); +hunk ./lib/util.php 1385 +- $replied = array(); ++ $replied = array(); +hunk ./lib/util.php 1387 +- # store replied only for first @ (what user/notice what the reply directed, +- # we assume first @ is it) ++ // store replied only for first @ (what user/notice what the reply directed, ++ // we assume first @ is it) +hunk ./lib/util.php 1390 +- for ($i=0; $icreated); +- if (!$recipient) { +- continue; +- } +- if ($i == 0 && ($recipient->id != $sender->id) && !$notice->reply_to) { # Don't save reply to self +- $reply_for = $recipient; +- $recipient_notice = $reply_for->getCurrentNotice(); +- if ($recipient_notice) { +- $orig = clone($notice); +- $notice->reply_to = $recipient_notice->id; +- $notice->update($orig); +- } +- } +- # Don't save replies from blocked profile to local user ++ for ($i=0; $icreated); ++ if (!$recipient) { ++ continue; ++ } ++ if ($i == 0 && ($recipient->id != $sender->id) && !$notice->reply_to) { // Don't save reply to self ++ $reply_for = $recipient; ++ $recipient_notice = $reply_for->getCurrentNotice(); ++ if ($recipient_notice) { ++ $orig = clone($notice); ++ $notice->reply_to = $recipient_notice->id; ++ $notice->update($orig); ++ } ++ } ++ // Don't save replies from blocked profile to local user +hunk ./lib/util.php 1410 +- $reply = new Reply(); +- $reply->notice_id = $notice->id; +- $reply->profile_id = $recipient->id; +- $id = $reply->insert(); +- if (!$id) { +- $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); +- common_log(LOG_ERR, 'DB error inserting reply: ' . $last_error->message); +- common_server_error(sprintf(_('DB error inserting reply: %s'), $last_error->message)); +- return; +- } else { +- $replied[$recipient->id] = 1; +- } +- } ++ $reply = new Reply(); ++ $reply->notice_id = $notice->id; ++ $reply->profile_id = $recipient->id; ++ $id = $reply->insert(); ++ if (!$id) { ++ $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); ++ common_log(LOG_ERR, 'DB error inserting reply: ' . $last_error->message); ++ common_server_error(sprintf(_('DB error inserting reply: %s'), $last_error->message)); ++ return; ++ } else { ++ $replied[$recipient->id] = 1; ++ } ++ } +hunk ./lib/util.php 1424 +- # Hash format replies, too +- $cnt = preg_match_all('/(?:^|\s)@#([a-z0-9]{1,64})/', $notice->content, $match); +- if ($cnt) { +- foreach ($match[1] as $tag) { +- $tagged = Profile_tag::getTagged($sender->id, $tag); +- foreach ($tagged as $t) { +- if (!$replied[$t->id]) { +- # Don't save replies from blocked profile to local user ++ // Hash format replies, too ++ $cnt = preg_match_all('/(?:^|\s)@#([a-z0-9]{1,64})/', $notice->content, $match); ++ if ($cnt) { ++ foreach ($match[1] as $tag) { ++ $tagged = Profile_tag::getTagged($sender->id, $tag); ++ foreach ($tagged as $t) { ++ if (!$replied[$t->id]) { ++ // Don't save replies from blocked profile to local user +hunk ./lib/util.php 1436 +- $reply = new Reply(); +- $reply->notice_id = $notice->id; +- $reply->profile_id = $t->id; +- $id = $reply->insert(); +- if (!$id) { +- common_log_db_error($reply, 'INSERT', __FILE__); +- return; +- } +- } +- } +- } +- } ++ $reply = new Reply(); ++ $reply->notice_id = $notice->id; ++ $reply->profile_id = $t->id; ++ $id = $reply->insert(); ++ if (!$id) { ++ common_log_db_error($reply, 'INSERT', __FILE__); ++ return; ++ } ++ } ++ } ++ } ++ } +hunk ./lib/util.php 1452 +- // Check to see if notice should go to Twitter +- $flink = Foreign_link::getByUserID($notice->profile_id, 1); // 1 == Twitter +- if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) { ++ // Check to see if notice should go to Twitter ++ $flink = Foreign_link::getByUserID($notice->profile_id, 1); // 1 == Twitter ++ if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) { +hunk ./lib/util.php 1456 +- // If it's not a Twitter-style reply, or if the user WANTS to send replies... ++ // If it's not a Twitter-style reply, or if the user WANTS to send replies... +hunk ./lib/util.php 1458 +- if (!preg_match('/^@[a-zA-Z0-9_]{1,15}\b/u', $notice->content) || +- (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) { ++ if (!preg_match('/^@[a-zA-Z0-9_]{1,15}\b/u', $notice->content) || ++ (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) { +hunk ./lib/util.php 1461 +- $result = common_twitter_broadcast($notice, $flink); ++ $result = common_twitter_broadcast($notice, $flink); +hunk ./lib/util.php 1463 +- if (!$result) { +- common_debug('Unable to send notice: ' . $notice->id . ' to Twitter.', __FILE__); +- } +- } +- } ++ if (!$result) { ++ common_debug('Unable to send notice: ' . $notice->id . ' to Twitter.', __FILE__); ++ } ++ } ++ } +hunk ./lib/util.php 1469 +- if (common_config('queue', 'enabled')) { +- # Do it later! +- return common_enqueue_notice($notice); +- } else { +- return common_real_broadcast($notice, $remote); +- } ++ if (common_config('queue', 'enabled')) { ++ // Do it later! ++ return common_enqueue_notice($notice); ++ } else { ++ return common_real_broadcast($notice, $remote); ++ } +hunk ./lib/util.php 1478 +- global $config; +- $success = true; +- $fuser = $flink->getForeignUser(); +- $twitter_user = $fuser->nickname; +- $twitter_password = $flink->credentials; +- $uri = 'http://www.twitter.com/statuses/update.json'; ++ global $config; ++ $success = true; ++ $fuser = $flink->getForeignUser(); ++ $twitter_user = $fuser->nickname; ++ $twitter_password = $flink->credentials; ++ $uri = 'http://www.twitter.com/statuses/update.json'; +hunk ./lib/util.php 1485 +- // XXX: Hack to get around PHP cURL's use of @ being a a meta character +- $statustxt = preg_replace('/^@/', ' @', $notice->content); ++ // XXX: Hack to get around PHP cURL's use of @ being a a meta character ++ $statustxt = preg_replace('/^@/', ' @', $notice->content); +hunk ./lib/util.php 1488 +- $options = array( +- CURLOPT_USERPWD => "$twitter_user:$twitter_password", +- CURLOPT_POST => true, +- CURLOPT_POSTFIELDS => array( +- 'status' => $statustxt, +- 'source' => $config['integration']['source'] +- ), +- CURLOPT_RETURNTRANSFER => true, +- CURLOPT_FAILONERROR => true, +- CURLOPT_HEADER => false, +- CURLOPT_FOLLOWLOCATION => true, +- CURLOPT_USERAGENT => "Laconica", +- CURLOPT_CONNECTTIMEOUT => 120, // XXX: Scary!!!! How long should this be? +- CURLOPT_TIMEOUT => 120 +- ); ++ $options = array( ++ CURLOPT_USERPWD => "$twitter_user:$twitter_password", ++ CURLOPT_POST => true, ++ CURLOPT_POSTFIELDS => array( ++ 'status' => $statustxt, ++ 'source' => $config['integration']['source'] ++ ), ++ CURLOPT_RETURNTRANSFER => true, ++ CURLOPT_FAILONERROR => true, ++ CURLOPT_HEADER => false, ++ CURLOPT_FOLLOWLOCATION => true, ++ CURLOPT_USERAGENT => "Laconica", ++ CURLOPT_CONNECTTIMEOUT => 120, // XXX: Scary!!!! How long should this be? ++ CURLOPT_TIMEOUT => 120 ++ ); +hunk ./lib/util.php 1504 +- $ch = curl_init($uri); ++ $ch = curl_init($uri); +hunk ./lib/util.php 1509 +- if ($errmsg) { +- common_debug("cURL error: $errmsg - trying to send notice for $twitter_user.", +- __FILE__); +- $success = false; +- } ++ if ($errmsg) { ++ common_debug("cURL error: $errmsg - trying to send notice for $twitter_user.", ++ __FILE__); ++ $success = false; ++ } +hunk ./lib/util.php 1515 +- curl_close($ch); ++ curl_close($ch); +hunk ./lib/util.php 1517 +- if (!$data) { +- common_debug("No data returned by Twitter's API trying to send update for $twitter_user", +- __FILE__); +- $success = false; +- } ++ if (!$data) { ++ common_debug("No data returned by Twitter's API trying to send update for $twitter_user", ++ __FILE__); ++ $success = false; ++ } +hunk ./lib/util.php 1523 +- // Twitter should return a status +- $status = json_decode($data); ++ // Twitter should return a status ++ $status = json_decode($data); +hunk ./lib/util.php 1526 +- if (!$status->id) { +- common_debug("Unexpected data returned by Twitter API trying to send update for $twitter_user", +- __FILE__); +- $success = false; +- } ++ if (!$status->id) { ++ common_debug("Unexpected data returned by Twitter API trying to send update for $twitter_user", ++ __FILE__); ++ $success = false; ++ } +hunk ./lib/util.php 1532 +- return $success; ++ return $success; +hunk ./lib/util.php 1535 +-# Stick the notice on the queue ++// Stick the notice on the queue +hunk ./lib/util.php 1538 +- foreach (array('jabber', 'omb', 'sms', 'public') as $transport) { +- $qi = new Queue_item(); +- $qi->notice_id = $notice->id; +- $qi->transport = $transport; +- $qi->created = $notice->created; ++ foreach (array('jabber', 'omb', 'sms', 'public') as $transport) { ++ $qi = new Queue_item(); ++ $qi->notice_id = $notice->id; ++ $qi->transport = $transport; ++ $qi->created = $notice->created; +hunk ./lib/util.php 1544 +- if (!$result) { +- $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); +- common_log(LOG_ERR, 'DB error inserting queue item: ' . $last_error->message); +- return false; +- } +- common_log(LOG_DEBUG, 'complete queueing notice ID = ' . $notice->id . ' for ' . $transport); +- } +- return $result; ++ if (!$result) { ++ $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); ++ common_log(LOG_ERR, 'DB error inserting queue item: ' . $last_error->message); ++ return false; ++ } ++ common_log(LOG_DEBUG, 'complete queueing notice ID = ' . $notice->id . ' for ' . $transport); ++ } ++ return $result; +hunk ./lib/util.php 1555 +- $qi = Queue_item::staticGet($notice->id); +- if ($qi) { +- $result = $qi->delete(); +- if (!$result) { +- $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); +- common_log(LOG_ERR, 'DB error deleting queue item: ' . $last_error->message); +- return false; +- } +- common_log(LOG_DEBUG, 'complete dequeueing notice ID = ' . $notice->id); +- return $result; +- } else { ++ $qi = Queue_item::staticGet($notice->id); ++ if ($qi) { ++ $result = $qi->delete(); ++ if (!$result) { ++ $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); ++ common_log(LOG_ERR, 'DB error deleting queue item: ' . $last_error->message); +hunk ./lib/util.php 1563 ++ common_log(LOG_DEBUG, 'complete dequeueing notice ID = ' . $notice->id); ++ return $result; ++ } else { ++ return false; ++ } +hunk ./lib/util.php 1571 +- $success = true; +- if (!$remote) { +- # Make sure we have the OMB stuff +- require_once(INSTALLDIR.'/lib/omb.php'); +- $success = omb_broadcast_remote_subscribers($notice); +- if (!$success) { +- common_log(LOG_ERR, 'Error in OMB broadcast for notice ' . $notice->id); +- } +- } +- if ($success) { +- require_once(INSTALLDIR.'/lib/jabber.php'); +- $success = jabber_broadcast_notice($notice); +- if (!$success) { +- common_log(LOG_ERR, 'Error in jabber broadcast for notice ' . $notice->id); +- } +- } +- if ($success) { +- require_once(INSTALLDIR.'/lib/mail.php'); +- $success = mail_broadcast_notice_sms($notice); +- if (!$success) { +- common_log(LOG_ERR, 'Error in sms broadcast for notice ' . $notice->id); +- } +- } +- if ($success) { +- $success = jabber_public_notice($notice); +- if (!$success) { +- common_log(LOG_ERR, 'Error in public broadcast for notice ' . $notice->id); +- } +- } +- // XXX: broadcast notices to other IM +- return $success; ++ $success = true; ++ if (!$remote) { ++ // Make sure we have the OMB stuff ++ require_once(INSTALLDIR.'/lib/omb.php'); ++ $success = omb_broadcast_remote_subscribers($notice); ++ if (!$success) { ++ common_log(LOG_ERR, 'Error in OMB broadcast for notice ' . $notice->id); ++ } ++ } ++ if ($success) { ++ require_once(INSTALLDIR.'/lib/jabber.php'); ++ $success = jabber_broadcast_notice($notice); ++ if (!$success) { ++ common_log(LOG_ERR, 'Error in jabber broadcast for notice ' . $notice->id); ++ } ++ } ++ if ($success) { ++ require_once(INSTALLDIR.'/lib/mail.php'); ++ $success = mail_broadcast_notice_sms($notice); ++ if (!$success) { ++ common_log(LOG_ERR, 'Error in sms broadcast for notice ' . $notice->id); ++ } ++ } ++ if ($success) { ++ $success = jabber_public_notice($notice); ++ if (!$success) { ++ common_log(LOG_ERR, 'Error in public broadcast for notice ' . $notice->id); ++ } ++ } ++ // XXX: broadcast notices to other IM ++ return $success; +hunk ./lib/util.php 1605 +- // XXX: optionally use a queue system like http://code.google.com/p/microapps/wiki/NQDQ +- require_once(INSTALLDIR.'/lib/omb.php'); +- omb_broadcast_profile($profile); +- // XXX: Other broadcasts...? +- return true; ++ // XXX: optionally use a queue system like http://code.google.com/p/microapps/wiki/NQDQ ++ require_once(INSTALLDIR.'/lib/omb.php'); ++ omb_broadcast_profile($profile); ++ // XXX: Other broadcasts...? ++ return true; +hunk ./lib/util.php 1613 +- return common_local_url('showstream', array('nickname' => $nickname)); ++ return common_local_url('showstream', array('nickname' => $nickname)); +hunk ./lib/util.php 1616 +-# Don't call if nobody's logged in ++// Don't call if nobody's logged in +hunk ./lib/util.php 1618 +-function common_notice_form($action=NULL, $content=NULL) { +- $user = common_current_user(); +- assert(!is_null($user)); +- common_element_start('form', array('id' => 'status_form', +- 'method' => 'post', +- 'action' => common_local_url('newnotice'))); +- common_element_start('p'); +- common_element('label', array('for' => 'status_textarea', +- 'id' => 'status_label'), +- sprintf(_('What\'s up, %s?'), $user->nickname)); ++function common_notice_form($action=null, $content=null) { ++ $user = common_current_user(); ++ assert(!is_null($user)); ++ common_element_start('form', array('id' => 'status_form', ++ 'method' => 'post', ++ 'action' => common_local_url('newnotice'))); ++ common_element_start('p'); ++ common_element('label', array('for' => 'status_textarea', ++ 'id' => 'status_label'), ++ sprintf(_('What\'s up, %s?'), $user->nickname)); +hunk ./lib/util.php 1629 +- common_element('textarea', array('id' => 'status_textarea', +- 'cols' => 60, +- 'rows' => 3, +- 'name' => 'status_textarea'), +- ($content) ? $content : ''); +- common_hidden('token', common_session_token()); +- if ($action) { +- common_hidden('returnto', $action); +- } +- # set by JavaScript +- common_hidden('inreplyto', 'false'); +- common_element('input', array('id' => 'status_submit', +- 'name' => 'status_submit', +- 'type' => 'submit', +- 'value' => _('Send'))); +- common_element_end('p'); +- common_element_end('form'); ++ common_element('textarea', array('id' => 'status_textarea', ++ 'cols' => 60, ++ 'rows' => 3, ++ 'name' => 'status_textarea'), ++ ($content) ? $content : ''); ++ common_hidden('token', common_session_token()); ++ if ($action) { ++ common_hidden('returnto', $action); ++ } ++ // set by JavaScript ++ common_hidden('inreplyto', 'false'); ++ common_element('input', array('id' => 'status_submit', ++ 'name' => 'status_submit', ++ 'type' => 'submit', ++ 'value' => _('Send'))); ++ common_element_end('p'); ++ common_element_end('form'); +hunk ./lib/util.php 1648 +-# Should make up a reasonable root URL ++// Should make up a reasonable root URL +hunk ./lib/util.php 1651 +- return common_path(''); ++ return common_path(''); +hunk ./lib/util.php 1654 +-# returns $bytes bytes of random data as a hexadecimal string +-# "good" here is a goal and not a guarantee ++// returns $bytes bytes of random data as a hexadecimal string ++// "good" here is a goal and not a guarantee +hunk ./lib/util.php 1658 +- # XXX: use random.org...? +- if (file_exists('/dev/urandom')) { +- return common_urandom($bytes); +- } else { # FIXME: this is probably not good enough +- return common_mtrand($bytes); +- } ++ // XXX: use random.org...? ++ if (file_exists('/dev/urandom')) { ++ return common_urandom($bytes); ++ } else { // FIXME: this is probably not good enough ++ return common_mtrand($bytes); ++ } +hunk ./lib/util.php 1667 +- $h = fopen('/dev/urandom', 'rb'); +- # should not block +- $src = fread($h, $bytes); +- fclose($h); +- $enc = ''; +- for ($i = 0; $i < $bytes; $i++) { +- $enc .= sprintf("%02x", (ord($src[$i]))); +- } +- return $enc; ++ $h = fopen('/dev/urandom', 'rb'); ++ // should not block ++ $src = fread($h, $bytes); ++ fclose($h); ++ $enc = ''; ++ for ($i = 0; $i < $bytes; $i++) { ++ $enc .= sprintf("%02x", (ord($src[$i]))); ++ } ++ return $enc; +hunk ./lib/util.php 1679 +- $enc = ''; +- for ($i = 0; $i < $bytes; $i++) { +- $enc .= sprintf("%02x", mt_rand(0, 255)); +- } +- return $enc; ++ $enc = ''; ++ for ($i = 0; $i < $bytes; $i++) { ++ $enc .= sprintf("%02x", mt_rand(0, 255)); ++ } ++ return $enc; +hunk ./lib/util.php 1687 +- common_ensure_session(); +- $_SESSION['returnto'] = $url; ++ common_ensure_session(); ++ $_SESSION['returnto'] = $url; +hunk ./lib/util.php 1692 +- common_ensure_session(); +- return $_SESSION['returnto']; ++ common_ensure_session(); ++ return $_SESSION['returnto']; +hunk ./lib/util.php 1697 +- return date('YmdHis'); ++ return date('YmdHis'); +hunk ./lib/util.php 1701 +- static $initialized = false; +- if (!$initialized) { +- global $config; +- openlog($config['syslog']['appname'], 0, LOG_USER); +- $initialized = true; +- } ++ static $initialized = false; ++ if (!$initialized) { ++ global $config; ++ openlog($config['syslog']['appname'], 0, LOG_USER); ++ $initialized = true; ++ } +hunk ./lib/util.php 1709 +-function common_log($priority, $msg, $filename=NULL) { +- $logfile = common_config('site', 'logfile'); +- if ($logfile) { +- $log = fopen($logfile, "a"); +- if ($log) { +- static $syslog_priorities = array('LOG_EMERG', 'LOG_ALERT', 'LOG_CRIT', 'LOG_ERR', +- 'LOG_WARNING', 'LOG_NOTICE', 'LOG_INFO', 'LOG_DEBUG'); +- $output = date('Y-m-d H:i:s') . ' ' . $syslog_priorities[$priority] . ': ' . $msg . "\n"; +- fwrite($log, $output); +- fclose($log); +- } +- } else { +- common_ensure_syslog(); +- syslog($priority, $msg); +- } ++function common_log($priority, $msg, $filename=null) { ++ $logfile = common_config('site', 'logfile'); ++ if ($logfile) { ++ $log = fopen($logfile, "a"); ++ if ($log) { ++ static $syslog_priorities = array('LOG_EMERG', 'LOG_ALERT', 'LOG_CRIT', 'LOG_ERR', ++ 'LOG_WARNING', 'LOG_NOTICE', 'LOG_INFO', 'LOG_DEBUG'); ++ $output = date('Y-m-d H:i:s') . ' ' . $syslog_priorities[$priority] . ': ' . $msg . "\n"; ++ fwrite($log, $output); ++ fclose($log); ++ } ++ } else { ++ common_ensure_syslog(); ++ syslog($priority, $msg); ++ } +hunk ./lib/util.php 1726 +-function common_debug($msg, $filename=NULL) { +- if ($filename) { +- common_log(LOG_DEBUG, basename($filename).' - '.$msg); +- } else { +- common_log(LOG_DEBUG, $msg); +- } ++function common_debug($msg, $filename=null) { ++ if ($filename) { ++ common_log(LOG_DEBUG, basename($filename).' - '.$msg); ++ } else { ++ common_log(LOG_DEBUG, $msg); ++ } +hunk ./lib/util.php 1734 +-function common_log_db_error(&$object, $verb, $filename=NULL) { +- $objstr = common_log_objstring($object); +- $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); +- common_log(LOG_ERR, $last_error->message . '(' . $verb . ' on ' . $objstr . ')', $filename); ++function common_log_db_error(&$object, $verb, $filename=null) { ++ $objstr = common_log_objstring($object); ++ $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); ++ common_log(LOG_ERR, $last_error->message . '(' . $verb . ' on ' . $objstr . ')', $filename); +hunk ./lib/util.php 1741 +- if (is_null($object)) { +- return "NULL"; +- } +- $arr = $object->toArray(); +- $fields = array(); +- foreach ($arr as $k => $v) { +- $fields[] = "$k='$v'"; +- } +- $objstring = $object->tableName() . '[' . implode(',', $fields) . ']'; +- return $objstring; ++ if (is_null($object)) { ++ return "null"; ++ } ++ $arr = $object->toArray(); ++ $fields = array(); ++ foreach ($arr as $k => $v) { ++ $fields[] = "$k='$v'"; ++ } ++ $objstring = $object->tableName() . '[' . implode(',', $fields) . ']'; ++ return $objstring; +hunk ./lib/util.php 1754 +- return Validate::uri($url, array('allowed_schemes' => array('http', 'https'))); ++ return Validate::uri($url, array('allowed_schemes' => array('http', 'https'))); +hunk ./lib/util.php 1758 +- if (preg_match('/^tag:(.*?),(\d{4}(-\d{2}(-\d{2})?)?):(.*)$/', $tag, $matches)) { +- return (Validate::email($matches[1]) || +- preg_match('/^([\w-\.]+)$/', $matches[1])); +- } +- return false; ++ if (preg_match('/^tag:(.*?),(\d{4}(-\d{2}(-\d{2})?)?):(.*)$/', $tag, $matches)) { ++ return (Validate::email($matches[1]) || ++ preg_match('/^([\w-\.]+)$/', $matches[1])); ++ } ++ return false; +hunk ./lib/util.php 1765 +-# Does a little before-after block for next/prev page ++// Does a little before-after block for next/prev page +hunk ./lib/util.php 1767 +-function common_pagination($have_before, $have_after, $page, $action, $args=NULL) { ++function common_pagination($have_before, $have_after, $page, $action, $args=null) { +hunk ./lib/util.php 1769 +- if ($have_before || $have_after) { +- common_element_start('div', array('id' => 'pagination')); +- common_element_start('ul', array('id' => 'nav_pagination')); +- } ++ if ($have_before || $have_after) { ++ common_element_start('div', array('id' => 'pagination')); ++ common_element_start('ul', array('id' => 'nav_pagination')); ++ } +hunk ./lib/util.php 1774 +- if ($have_before) { +- $pargs = array('page' => $page-1); +- $newargs = ($args) ? array_merge($args,$pargs) : $pargs; ++ if ($have_before) { ++ $pargs = array('page' => $page-1); ++ $newargs = ($args) ? array_merge($args,$pargs) : $pargs; +hunk ./lib/util.php 1778 +- common_element_start('li', 'before'); +- common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'prev'), +- _('« After')); +- common_element_end('li'); +- } ++ common_element_start('li', 'before'); ++ common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'prev'), ++ _('« After')); ++ common_element_end('li'); ++ } +hunk ./lib/util.php 1784 +- if ($have_after) { +- $pargs = array('page' => $page+1); +- $newargs = ($args) ? array_merge($args,$pargs) : $pargs; +- common_element_start('li', 'after'); +- common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'next'), +- _('Before »')); +- common_element_end('li'); +- } ++ if ($have_after) { ++ $pargs = array('page' => $page+1); ++ $newargs = ($args) ? array_merge($args,$pargs) : $pargs; ++ common_element_start('li', 'after'); ++ common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'next'), ++ _('Before »')); ++ common_element_end('li'); ++ } +hunk ./lib/util.php 1793 +- if ($have_before || $have_after) { +- common_element_end('ul'); +- common_element_end('div'); +- } ++ if ($have_before || $have_after) { ++ common_element_end('ul'); ++ common_element_end('div'); ++ } +hunk ./lib/util.php 1803 +- # No arg means accept anything (per HTTP spec) +- if(!$accept) { +- return array($def => 1); +- } ++ // No arg means accept anything (per HTTP spec) ++ if(!$accept) { ++ return array($def => 1); ++ } +hunk ./lib/util.php 1808 +- $prefs = array(); ++ $prefs = array(); +hunk ./lib/util.php 1810 +- $parts = explode(',', $accept); ++ $parts = explode(',', $accept); +hunk ./lib/util.php 1812 +- foreach($parts as $part) { +- # FIXME: doesn't deal with params like 'text/html; level=1' +- @list($value, $qpart) = explode(';', $part); +- $match = array(); +- if(!isset($qpart)) { +- $prefs[$value] = 1; +- } elseif(preg_match('/q\s*=\s*(\d*\.\d+)/', $qpart, $match)) { +- $prefs[$value] = $match[1]; +- } +- } ++ foreach($parts as $part) { ++ // FIXME: doesn't deal with params like 'text/html; level=1' ++ @list($value, $qpart) = explode(';', $part); ++ $match = array(); ++ if(!isset($qpart)) { ++ $prefs[$value] = 1; ++ } elseif(preg_match('/q\s*=\s*(\d*\.\d+)/', $qpart, $match)) { ++ $prefs[$value] = $match[1]; ++ } ++ } +hunk ./lib/util.php 1823 +- return $prefs; ++ return $prefs; +hunk ./lib/util.php 1827 +- if(array_key_exists($type, $avail)) { +- return $type; +- } else { +- $parts = explode('/', $type); +- if(array_key_exists($parts[0] . '/*', $avail)) { +- return $parts[0] . '/*'; +- } elseif(array_key_exists('*/*', $avail)) { +- return '*/*'; +- } else { +- return NULL; +- } +- } ++ if(array_key_exists($type, $avail)) { ++ return $type; ++ } else { ++ $parts = explode('/', $type); ++ if(array_key_exists($parts[0] . '/*', $avail)) { ++ return $parts[0] . '/*'; ++ } elseif(array_key_exists('*/*', $avail)) { ++ return '*/*'; ++ } else { ++ return null; ++ } ++ } +hunk ./lib/util.php 1842 +- $combine = array(); ++ $combine = array(); +hunk ./lib/util.php 1844 +- foreach(array_keys($sprefs) as $type) { +- $parts = explode('/', $type); +- if($parts[1] != '*') { +- $ckey = common_mime_type_match($type, $cprefs); +- if($ckey) { +- $combine[$type] = $sprefs[$type] * $cprefs[$ckey]; +- } +- } +- } ++ foreach(array_keys($sprefs) as $type) { ++ $parts = explode('/', $type); ++ if($parts[1] != '*') { ++ $ckey = common_mime_type_match($type, $cprefs); ++ if($ckey) { ++ $combine[$type] = $sprefs[$type] * $cprefs[$ckey]; ++ } ++ } ++ } +hunk ./lib/util.php 1854 +- foreach(array_keys($cprefs) as $type) { +- $parts = explode('/', $type); +- if($parts[1] != '*' && !array_key_exists($type, $sprefs)) { +- $skey = common_mime_type_match($type, $sprefs); +- if($skey) { +- $combine[$type] = $sprefs[$skey] * $cprefs[$type]; +- } +- } +- } ++ foreach(array_keys($cprefs) as $type) { ++ $parts = explode('/', $type); ++ if($parts[1] != '*' && !array_key_exists($type, $sprefs)) { ++ $skey = common_mime_type_match($type, $sprefs); ++ if($skey) { ++ $combine[$type] = $sprefs[$skey] * $cprefs[$type]; ++ } ++ } ++ } +hunk ./lib/util.php 1864 +- $bestq = 0; +- $besttype = "text/html"; ++ $bestq = 0; ++ $besttype = "text/html"; +hunk ./lib/util.php 1867 +- foreach(array_keys($combine) as $type) { +- if($combine[$type] > $bestq) { +- $besttype = $type; +- $bestq = $combine[$type]; +- } +- } ++ foreach(array_keys($combine) as $type) { ++ if($combine[$type] > $bestq) { ++ $besttype = $type; ++ $bestq = $combine[$type]; ++ } ++ } +hunk ./lib/util.php 1874 +- return $besttype; ++ return $besttype; +hunk ./lib/util.php 1878 +- global $config; +- return isset($config[$main][$sub]) ? $config[$main][$sub] : false; ++ global $config; ++ return isset($config[$main][$sub]) ? $config[$main][$sub] : false; +hunk ./lib/util.php 1883 +- $to = array(); +- $strip = get_magic_quotes_gpc(); +- foreach ($from as $k => $v) { +- $to[$k] = ($strip) ? stripslashes($v) : $v; +- } +- return $to; ++ $to = array(); ++ $strip = get_magic_quotes_gpc(); ++ foreach ($from as $k => $v) { ++ $to[$k] = ($strip) ? stripslashes($v) : $v; ++ } ++ return $to; +hunk ./lib/util.php 1894 +- if(get_magic_quotes_gpc()) { +- $_POST=array_map('stripslashes',$_POST); +- $_GET=array_map('stripslashes',$_GET); +- } ++ if(get_magic_quotes_gpc()) { ++ $_POST=array_map('stripslashes',$_POST); ++ $_GET=array_map('stripslashes',$_GET); ++ } +hunk ./lib/util.php 1901 +- return common_local_url('userbyid', array('id' => $user->id)); ++ return common_local_url('userbyid', array('id' => $user->id)); +hunk ./lib/util.php 1905 +- return common_local_url('shownotice', +- array('notice' => $notice->id)); ++ return common_local_url('shownotice', ++ array('notice' => $notice->id)); +hunk ./lib/util.php 1909 +-# 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits ++// 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits +hunk ./lib/util.php 1912 +- # 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits +- static $codechars = '23456789ABCDEFGHJKLMNPQRSTUVWXYZ'; +- $chars = ceil($bits/5); +- $code = ''; +- for ($i = 0; $i < $chars; $i++) { +- # XXX: convert to string and back +- $num = hexdec(common_good_rand(1)); +- # XXX: randomness is too precious to throw away almost +- # 40% of the bits we get! +- $code .= $codechars[$num%32]; +- } +- return $code; ++ // 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits ++ static $codechars = '23456789ABCDEFGHJKLMNPQRSTUVWXYZ'; ++ $chars = ceil($bits/5); ++ $code = ''; ++ for ($i = 0; $i < $chars; $i++) { ++ // XXX: convert to string and back ++ $num = hexdec(common_good_rand(1)); ++ // XXX: randomness is too precious to throw away almost ++ // 40% of the bits we get! ++ $code .= $codechars[$num%32]; ++ } ++ return $code; +hunk ./lib/util.php 1926 +-# convert markup to HTML ++// convert markup to HTML +hunk ./lib/util.php 1929 +- $c = preg_replace('/%%action.(\w+)%%/e', "common_local_url('\\1')", $c); +- $c = preg_replace('/%%doc.(\w+)%%/e', "common_local_url('doc', array('title'=>'\\1'))", $c); +- $c = preg_replace('/%%(\w+).(\w+)%%/e', 'common_config(\'\\1\', \'\\2\')', $c); +- return Markdown($c); ++ $c = preg_replace('/%%action.(\w+)%%/e', "common_local_url('\\1')", $c); ++ $c = preg_replace('/%%doc.(\w+)%%/e', "common_local_url('doc', array('title'=>'\\1'))", $c); ++ $c = preg_replace('/%%(\w+).(\w+)%%/e', 'common_config(\'\\1\', \'\\2\')', $c); ++ return Markdown($c); +hunk ./lib/util.php 1936 +- $avatar = $profile->getAvatar($size); +- if ($avatar) { +- return common_avatar_display_url($avatar); +- } else { +- return common_default_avatar($size); +- } ++ $avatar = $profile->getAvatar($size); ++ if ($avatar) { ++ return common_avatar_display_url($avatar); ++ } else { ++ return common_default_avatar($size); ++ } +hunk ./lib/util.php 1945 +- if (!$profile) { +- return NULL; +- } +- $user = User::staticGet($profile->id); +- if ($user) { +- return $user->uri; +- } ++ if (!$profile) { ++ return null; ++ } ++ $user = User::staticGet($profile->id); ++ if ($user) { ++ return $user->uri; ++ } +hunk ./lib/util.php 1953 +- $remote = Remote_profile::staticGet($profile->id); +- if ($remote) { +- return $remote->uri; +- } +- # XXX: this is a very bad profile! +- return NULL; ++ $remote = Remote_profile::staticGet($profile->id); ++ if ($remote) { ++ return $remote->uri; ++ } ++ // XXX: this is a very bad profile! ++ return null; +hunk ./lib/util.php 1962 +- # strip non-digits +- preg_replace('/\D/', '', $sms); +- return $sms; ++ // strip non-digits ++ preg_replace('/\D/', '', $sms); ++ return $sms; +hunk ./lib/util.php 1970 +- common_log(LOG_ERR, "[$errno] $errstr ($errfile:$errline)"); +- exit(1); +- break; ++ common_log(LOG_ERR, "[$errno] $errstr ($errfile:$errline)"); ++ exit(1); ++ break; +hunk ./lib/util.php 1974 +- case E_USER_WARNING: +- common_log(LOG_WARNING, "[$errno] $errstr ($errfile:$errline)"); +- break; ++ case E_USER_WARNING: ++ common_log(LOG_WARNING, "[$errno] $errstr ($errfile:$errline)"); ++ break; +hunk ./lib/util.php 1979 +- common_log(LOG_NOTICE, "[$errno] $errstr ($errfile:$errline)"); +- break; ++ common_log(LOG_NOTICE, "[$errno] $errstr ($errfile:$errline)"); ++ break; +hunk ./lib/util.php 1983 +- # FIXME: show error page if we're on the Web ++ // FIXME: show error page if we're on the Web +hunk ./lib/util.php 1989 +- common_ensure_session(); +- if (!array_key_exists('token', $_SESSION)) { +- $_SESSION['token'] = common_good_rand(64); +- } +- return $_SESSION['token']; ++ common_ensure_session(); ++ if (!array_key_exists('token', $_SESSION)) { ++ $_SESSION['token'] = common_good_rand(64); ++ } ++ return $_SESSION['token']; +hunk ./lib/util.php 1997 +- common_element_start('form', array('id' => 'disfavor-' . $notice->id, +- 'method' => 'post', +- 'class' => 'disfavor', +- 'action' => common_local_url('disfavor'))); ++ common_element_start('form', array('id' => 'disfavor-' . $notice->id, ++ 'method' => 'post', ++ 'class' => 'disfavor', ++ 'action' => common_local_url('disfavor'))); +hunk ./lib/util.php 2002 +- common_element('input', array('type' => 'hidden', +- 'name' => 'token-'. $notice->id, +- 'id' => 'token-'. $notice->id, +- 'class' => 'token', +- 'value' => common_session_token())); ++ common_element('input', array('type' => 'hidden', ++ 'name' => 'token-'. $notice->id, ++ 'id' => 'token-'. $notice->id, ++ 'class' => 'token', ++ 'value' => common_session_token())); +hunk ./lib/util.php 2008 +- common_element('input', array('type' => 'hidden', +- 'name' => 'notice', +- 'id' => 'notice-n'. $notice->id, +- 'class' => 'notice', +- 'value' => $notice->id)); ++ common_element('input', array('type' => 'hidden', ++ 'name' => 'notice', ++ 'id' => 'notice-n'. $notice->id, ++ 'class' => 'notice', ++ 'value' => $notice->id)); +hunk ./lib/util.php 2014 +- common_element('input', array('type' => 'submit', +- 'id' => 'disfavor-submit-' . $notice->id, +- 'name' => 'disfavor-submit-' . $notice->id, +- 'class' => 'disfavor', +- 'value' => 'Disfavor favorite', +- 'title' => 'Remove this message from favorites')); +- common_element_end('form'); ++ common_element('input', array('type' => 'submit', ++ 'id' => 'disfavor-submit-' . $notice->id, ++ 'name' => 'disfavor-submit-' . $notice->id, ++ 'class' => 'disfavor', ++ 'value' => 'Disfavor favorite', ++ 'title' => 'Remove this message from favorites')); ++ common_element_end('form'); +hunk ./lib/util.php 2024 +- common_element_start('form', array('id' => 'favor-' . $notice->id, +- 'method' => 'post', +- 'class' => 'favor', +- 'action' => common_local_url('favor'))); ++ common_element_start('form', array('id' => 'favor-' . $notice->id, ++ 'method' => 'post', ++ 'class' => 'favor', ++ 'action' => common_local_url('favor'))); +hunk ./lib/util.php 2029 +- common_element('input', array('type' => 'hidden', +- 'name' => 'token-'. $notice->id, +- 'id' => 'token-'. $notice->id, +- 'class' => 'token', +- 'value' => common_session_token())); ++ common_element('input', array('type' => 'hidden', ++ 'name' => 'token-'. $notice->id, ++ 'id' => 'token-'. $notice->id, ++ 'class' => 'token', ++ 'value' => common_session_token())); +hunk ./lib/util.php 2035 +- common_element('input', array('type' => 'hidden', +- 'name' => 'notice', +- 'id' => 'notice-n'. $notice->id, +- 'class' => 'notice', +- 'value' => $notice->id)); ++ common_element('input', array('type' => 'hidden', ++ 'name' => 'notice', ++ 'id' => 'notice-n'. $notice->id, ++ 'class' => 'notice', ++ 'value' => $notice->id)); +hunk ./lib/util.php 2041 +- common_element('input', array('type' => 'submit', +- 'id' => 'favor-submit-' . $notice->id, +- 'name' => 'favor-submit-' . $notice->id, +- 'class' => 'favor', +- 'value' => 'Add to favorites', +- 'title' => 'Add this message to favorites')); +- common_element_end('form'); ++ common_element('input', array('type' => 'submit', ++ 'id' => 'favor-submit-' . $notice->id, ++ 'name' => 'favor-submit-' . $notice->id, ++ 'class' => 'favor', ++ 'value' => 'Add to favorites', ++ 'title' => 'Add this message to favorites')); ++ common_element_end('form'); +hunk ./lib/util.php 2051 +- common_element_start('form', array('id' => 'nudge', 'method' => 'post', +- 'action' => common_local_url('nudge', array('nickname' => $profile->nickname)))); +- common_hidden('token', common_session_token()); +- common_element('input', array('type' => 'submit', +- 'class' => 'submit', +- 'value' => _('Send a nudge'))); +- common_element_end('form'); ++ common_element_start('form', array('id' => 'nudge', 'method' => 'post', ++ 'action' => common_local_url('nudge', array('nickname' => $profile->nickname)))); ++ common_hidden('token', common_session_token()); ++ common_element('input', array('type' => 'submit', ++ 'class' => 'submit', ++ 'value' => _('Send a nudge'))); ++ common_element_end('form'); +hunk ./lib/util.php 2060 +- common_element('p', array('id' => 'nudge_response'), _('Nudge sent!')); ++ common_element('p', array('id' => 'nudge_response'), _('Nudge sent!')); +hunk ./lib/util.php 2064 +- common_element_start('form', array('id' => 'subscribe-' . $profile->id, +- 'method' => 'post', +- 'class' => 'subscribe', +- 'action' => common_local_url('subscribe'))); +- common_hidden('token', common_session_token()); +- common_element('input', array('id' => 'subscribeto-' . $profile->id, +- 'name' => 'subscribeto', +- 'type' => 'hidden', +- 'value' => $profile->id)); +- common_element('input', array('type' => 'submit', +- 'class' => 'submit', +- 'value' => _('Subscribe'))); +- common_element_end('form'); ++ common_element_start('form', array('id' => 'subscribe-' . $profile->id, ++ 'method' => 'post', ++ 'class' => 'subscribe', ++ 'action' => common_local_url('subscribe'))); ++ common_hidden('token', common_session_token()); ++ common_element('input', array('id' => 'subscribeto-' . $profile->id, ++ 'name' => 'subscribeto', ++ 'type' => 'hidden', ++ 'value' => $profile->id)); ++ common_element('input', array('type' => 'submit', ++ 'class' => 'submit', ++ 'value' => _('Subscribe'))); ++ common_element_end('form'); +hunk ./lib/util.php 2080 +- common_element_start('form', array('id' => 'unsubscribe-' . $profile->id, +- 'method' => 'post', +- 'class' => 'unsubscribe', +- 'action' => common_local_url('unsubscribe'))); +- common_hidden('token', common_session_token()); +- common_element('input', array('id' => 'unsubscribeto-' . $profile->id, +- 'name' => 'unsubscribeto', +- 'type' => 'hidden', +- 'value' => $profile->id)); +- common_element('input', array('type' => 'submit', +- 'class' => 'submit', +- 'value' => _('Unsubscribe'))); +- common_element_end('form'); ++ common_element_start('form', array('id' => 'unsubscribe-' . $profile->id, ++ 'method' => 'post', ++ 'class' => 'unsubscribe', ++ 'action' => common_local_url('unsubscribe'))); ++ common_hidden('token', common_session_token()); ++ common_element('input', array('id' => 'unsubscribeto-' . $profile->id, ++ 'name' => 'unsubscribeto', ++ 'type' => 'hidden', ++ 'value' => $profile->id)); ++ common_element('input', array('type' => 'submit', ++ 'class' => 'submit', ++ 'value' => _('Unsubscribe'))); ++ common_element_end('form'); +hunk ./lib/util.php 2097 +- $user = User::staticGet('id', $profile->id); ++ $user = User::staticGet('id', $profile->id); +hunk ./lib/util.php 2099 +- if ($cur && $cur->id != $user->id && $cur->mutuallySubscribed($user)) { ++ if ($cur && $cur->id != $user->id && $cur->mutuallySubscribed($user)) { +hunk ./lib/util.php 2101 +- common_element('a', array('href' => common_local_url('newmessage', array('to' => $user->id))), +- _('Send a message')); ++ common_element('a', array('href' => common_local_url('newmessage', array('to' => $user->id))), ++ _('Send a message')); +hunk ./lib/util.php 2105 +- if ($user->email && $user->emailnotifynudge) { ++ if ($user->email && $user->emailnotifynudge) { +hunk ./lib/util.php 2110 +- } ++ } +hunk ./lib/util.php 2114 +- return 'laconica:' . common_keyize(common_config('site', 'name')) . ':' . $extra; ++ return 'laconica:' . common_keyize(common_config('site', 'name')) . ':' . $extra; +hunk ./lib/util.php 2118 +- $str = strtolower($str); +- $str = preg_replace('/\s/', '_', $str); +- return $str; ++ $str = strtolower($str); ++ $str = preg_replace('/\s/', '_', $str); ++ return $str; +hunk ./lib/util.php 2125 +- common_element_start('form', array('id' => 'message_form', +- 'method' => 'post', +- 'action' => common_local_url('newmessage'))); ++ common_element_start('form', array('id' => 'message_form', ++ 'method' => 'post', ++ 'action' => common_local_url('newmessage'))); +hunk ./lib/util.php 2129 +- $mutual_users = $user->mutuallySubscribedUsers(); ++ $mutual_users = $user->mutuallySubscribedUsers(); +hunk ./lib/util.php 2131 +- $mutual = array(); ++ $mutual = array(); +hunk ./lib/util.php 2133 +- while ($mutual_users->fetch()) { +- if ($mutual_users->id != $user->id) { +- $mutual[$mutual_users->id] = $mutual_users->nickname; +- } +- } ++ while ($mutual_users->fetch()) { ++ if ($mutual_users->id != $user->id) { ++ $mutual[$mutual_users->id] = $mutual_users->nickname; ++ } ++ } +hunk ./lib/util.php 2139 +- $mutual_users->free(); +- unset($mutual_users); ++ $mutual_users->free(); ++ unset($mutual_users); +hunk ./lib/util.php 2142 +- common_dropdown('to', _('To'), $mutual, NULL, FALSE, $to->id); ++ common_dropdown('to', _('To'), $mutual, null, FALSE, $to->id); +hunk ./lib/util.php 2144 +- common_element_start('p'); ++ common_element_start('p'); +hunk ./lib/util.php 2146 +- common_element('textarea', array('id' => 'message_content', +- 'cols' => 60, +- 'rows' => 3, +- 'name' => 'content'), +- ($content) ? $content : ''); ++ common_element('textarea', array('id' => 'message_content', ++ 'cols' => 60, ++ 'rows' => 3, ++ 'name' => 'content'), ++ ($content) ? $content : ''); +hunk ./lib/util.php 2152 +- common_element('input', array('id' => 'message_send', +- 'name' => 'message_send', +- 'type' => 'submit', +- 'value' => _('Send'))); ++ common_element('input', array('id' => 'message_send', ++ 'name' => 'message_send', ++ 'type' => 'submit', ++ 'value' => _('Send'))); +hunk ./lib/util.php 2157 +- common_hidden('token', common_session_token()); ++ common_hidden('token', common_session_token()); +hunk ./lib/util.php 2159 +- common_element_end('p'); +- common_element_end('form'); ++ common_element_end('p'); ++ common_element_end('form'); +hunk ./lib/util.php 2164 +- static $cache = NULL; +- if (!common_config('memcached', 'enabled')) { +- return NULL; +- } else { +- if (!$cache) { +- $cache = new Memcache(); +- $servers = common_config('memcached', 'server'); +- if (is_array($servers)) { +- foreach($servers as $server) { +- $cache->addServer($server); +- } +- } else { +- $cache->addServer($servers); +- } +- } +- return $cache; +- } ++ static $cache = null; ++ if (!common_config('memcached', 'enabled')) { ++ return null; ++ } else { ++ if (!$cache) { ++ $cache = new Memcache(); ++ $servers = common_config('memcached', 'server'); ++ if (is_array($servers)) { ++ foreach($servers as $server) { ++ $cache->addServer($server); ++ } ++ } else { ++ $cache->addServer($servers); ++ } ++ } ++ return $cache; + } +hunk ./lib/util.php 2184 +- # XXX: better compatibility check needed here! +- return ($from == $to); ++ // XXX: better compatibility check needed here! ++ return ($from == $to); +hunk ./lib/util.php 2190 +-function common_block_form($profile, $args=NULL) { ++function common_block_form($profile, $args=null) { +hunk ./lib/util.php 2194 +-function common_unblock_form($profile, $args=NULL) { ++function common_unblock_form($profile, $args=null) { +hunk ./lib/util.php 2198 +-function common_blocking_form($type, $label, $profile, $args=NULL) { ++function common_blocking_form($type, $label, $profile, $args=null) { +hunk ./lib/util.php 2220 +- diff --git a/lib/util.php b/lib/util.php index 8eeda11156..f0387ebe5a 100644 --- a/lib/util.php +++ b/lib/util.php @@ -19,116 +19,116 @@ /* XXX: break up into separate modules (HTTP, HTML, user, files) */ -# Show a server error +// Show a server error function common_server_error($msg, $code=500) { - static $status = array(500 => 'Internal Server Error', - 501 => 'Not Implemented', - 502 => 'Bad Gateway', - 503 => 'Service Unavailable', - 504 => 'Gateway Timeout', - 505 => 'HTTP Version Not Supported'); - - if (!array_key_exists($code, $status)) { - $code = 500; - } + static $status = array(500 => 'Internal Server Error', + 501 => 'Not Implemented', + 502 => 'Bad Gateway', + 503 => 'Service Unavailable', + 504 => 'Gateway Timeout', + 505 => 'HTTP Version Not Supported'); + + if (!array_key_exists($code, $status)) { + $code = 500; + } - $status_string = $status[$code]; + $status_string = $status[$code]; - header('HTTP/1.1 '.$code.' '.$status_string); - header('Content-type: text/plain'); + header('HTTP/1.1 '.$code.' '.$status_string); + header('Content-type: text/plain'); - print $msg; - print "\n"; - exit(); + print $msg; + print "\n"; + exit(); } -# Show a user error +// Show a user error function common_user_error($msg, $code=400) { - static $status = array(400 => 'Bad Request', - 401 => 'Unauthorized', - 402 => 'Payment Required', - 403 => 'Forbidden', - 404 => 'Not Found', - 405 => 'Method Not Allowed', - 406 => 'Not Acceptable', - 407 => 'Proxy Authentication Required', - 408 => 'Request Timeout', - 409 => 'Conflict', - 410 => 'Gone', - 411 => 'Length Required', - 412 => 'Precondition Failed', - 413 => 'Request Entity Too Large', - 414 => 'Request-URI Too Long', - 415 => 'Unsupported Media Type', - 416 => 'Requested Range Not Satisfiable', - 417 => 'Expectation Failed'); - - if (!array_key_exists($code, $status)) { - $code = 400; - } - - $status_string = $status[$code]; - - header('HTTP/1.1 '.$code.' '.$status_string); - - common_show_header('Error'); - common_element('div', array('class' => 'error'), $msg); - common_show_footer(); + static $status = array(400 => 'Bad Request', + 401 => 'Unauthorized', + 402 => 'Payment Required', + 403 => 'Forbidden', + 404 => 'Not Found', + 405 => 'Method Not Allowed', + 406 => 'Not Acceptable', + 407 => 'Proxy Authentication Required', + 408 => 'Request Timeout', + 409 => 'Conflict', + 410 => 'Gone', + 411 => 'Length Required', + 412 => 'Precondition Failed', + 413 => 'Request Entity Too Large', + 414 => 'Request-URI Too Long', + 415 => 'Unsupported Media Type', + 416 => 'Requested Range Not Satisfiable', + 417 => 'Expectation Failed'); + + if (!array_key_exists($code, $status)) { + $code = 400; + } + + $status_string = $status[$code]; + + header('HTTP/1.1 '.$code.' '.$status_string); + + common_show_header('Error'); + common_element('div', array('class' => 'error'), $msg); + common_show_footer(); } $xw = null; -# Start an HTML element -function common_element_start($tag, $attrs=NULL) { - global $xw; - $xw->startElement($tag); - if (is_array($attrs)) { - foreach ($attrs as $name => $value) { - $xw->writeAttribute($name, $value); - } - } else if (is_string($attrs)) { - $xw->writeAttribute('class', $attrs); - } +// Start an HTML element +function common_element_start($tag, $attrs=null) { + global $xw; + $xw->startElement($tag); + if (is_array($attrs)) { + foreach ($attrs as $name => $value) { + $xw->writeAttribute($name, $value); + } + } else if (is_string($attrs)) { + $xw->writeAttribute('class', $attrs); + } } function common_element_end($tag) { - static $empty_tag = array('base', 'meta', 'link', 'hr', - 'br', 'param', 'img', 'area', - 'input', 'col'); - global $xw; - # XXX: check namespace - if (in_array($tag, $empty_tag)) { - $xw->endElement(); - } else { - $xw->fullEndElement(); - } -} - -function common_element($tag, $attrs=NULL, $content=NULL) { - common_element_start($tag, $attrs); - global $xw; - if (!is_null($content)) { - $xw->text($content); - } - common_element_end($tag); -} - -function common_start_xml($doc=NULL, $public=NULL, $system=NULL, $indent=true) { - global $xw; - $xw = new XMLWriter(); - $xw->openURI('php://output'); - $xw->setIndent($indent); - $xw->startDocument('1.0', 'UTF-8'); - if ($doc) { - $xw->writeDTD($doc, $public, $system); - } + static $empty_tag = array('base', 'meta', 'link', 'hr', + 'br', 'param', 'img', 'area', + 'input', 'col'); + global $xw; + // XXX: check namespace + if (in_array($tag, $empty_tag)) { + $xw->endElement(); + } else { + $xw->fullEndElement(); + } +} + +function common_element($tag, $attrs=null, $content=null) { + common_element_start($tag, $attrs); + global $xw; + if (!is_null($content)) { + $xw->text($content); + } + common_element_end($tag); +} + +function common_start_xml($doc=null, $public=null, $system=null, $indent=true) { + global $xw; + $xw = new XMLWriter(); + $xw->openURI('php://output'); + $xw->setIndent($indent); + $xw->startDocument('1.0', 'UTF-8'); + if ($doc) { + $xw->writeDTD($doc, $public, $system); + } } function common_end_xml() { - global $xw; - $xw->endDocument(); - $xw->flush(); + global $xw; + $xw->endDocument(); + $xw->flush(); } function common_init_locale($language=null) { @@ -138,433 +138,433 @@ function common_init_locale($language=null) { putenv('LANGUAGE='.$language); putenv('LANG='.$language); return setlocale(LC_ALL, $language . ".utf8", - $language . ".UTF8", - $language . ".utf-8", - $language . ".UTF-8", - $language); + $language . ".UTF8", + $language . ".utf-8", + $language . ".UTF-8", + $language); } function common_init_language() { - mb_internal_encoding('UTF-8'); - $language = common_language(); - # So we don't have to make people install the gettext locales - $locale_set = common_init_locale($language); - bindtextdomain("laconica", common_config('site','locale_path')); - bind_textdomain_codeset("laconica", "UTF-8"); - textdomain("laconica"); - setlocale(LC_CTYPE, 'C'); - if(!$locale_set) { - common_log(LOG_INFO,'Language requested:'.$language.' - locale could not be set:',__FILE__); - } + mb_internal_encoding('UTF-8'); + $language = common_language(); + // So we don't have to make people install the gettext locales + $locale_set = common_init_locale($language); + bindtextdomain("laconica", common_config('site','locale_path')); + bind_textdomain_codeset("laconica", "UTF-8"); + textdomain("laconica"); + setlocale(LC_CTYPE, 'C'); + if(!$locale_set) { + common_log(LOG_INFO,'Language requested:'.$language.' - locale could not be set:',__FILE__); + } } define('PAGE_TYPE_PREFS', 'text/html,application/xhtml+xml,application/xml;q=0.3,text/xml;q=0.2'); -function common_show_header($pagetitle, $callable=NULL, $data=NULL, $headercall=NULL) { +function common_show_header($pagetitle, $callable=null, $data=null, $headercall=null) { - global $config, $xw; + global $config, $xw; global $action; /* XXX: kind of cheating here. */ - common_start_html(); - - common_element_start('head'); - common_element('title', NULL, - $pagetitle . " - " . $config['site']['name']); - common_element('link', array('rel' => 'stylesheet', - 'type' => 'text/css', - 'href' => theme_path('display.css') . '?version=' . LACONICA_VERSION, - 'media' => 'screen, projection, tv')); - foreach (array(6,7) as $ver) { - if (file_exists(theme_file('ie'.$ver.'.css'))) { - # Yes, IE people should be put in jail. - $xw->writeComment('[if lte IE '.$ver.']> 'text/javascript', - 'src' => common_path('js/jquery.min.js')), - ' '); - common_element('script', array('type' => 'text/javascript', - 'src' => common_path('js/jquery.form.js')), - ' '); - common_element('script', array('type' => 'text/javascript', - 'src' => common_path('js/xbImportNode.js')), - ' '); - common_element('script', array('type' => 'text/javascript', - 'src' => common_path('js/util.js?version='.LACONICA_VERSION)), - ' '); - common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', - 'href' => common_local_url('opensearch', array('type' => 'people')), - 'title' => common_config('site', 'name').' People Search')); - - common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', - 'href' => common_local_url('opensearch', array('type' => 'notice')), - 'title' => common_config('site', 'name').' Notice Search')); - - if ($callable) { - if ($data) { - call_user_func($callable, $data); - } else { - call_user_func($callable); - } - } - common_element_end('head'); - common_element_start('body', $action); - common_element_start('div', array('id' => 'wrap')); - common_element_start('div', array('id' => 'header')); - common_nav_menu(); - if ((isset($config['site']['logo']) && is_string($config['site']['logo']) && (strlen($config['site']['logo']) > 0)) - || file_exists(theme_file('logo.png'))) - { - common_element_start('a', array('href' => common_local_url('public'))); - common_element('img', array('src' => isset($config['site']['logo']) ? - ($config['site']['logo']) : theme_path('logo.png'), - 'alt' => $config['site']['name'], - 'id' => 'logo')); - common_element_end('a'); - } else { - common_element_start('p', array('id' => 'branding')); - common_element('a', array('href' => common_local_url('public')), - $config['site']['name']); - common_element_end('p'); - } - - common_element('h1', 'pagetitle', $pagetitle); - - if ($headercall) { - if ($data) { - call_user_func($headercall, $data); - } else { - call_user_func($headercall); - } - } - common_element_end('div'); - common_element_start('div', array('id' => 'content')); -} - -function common_start_html($type=NULL, $indent=true) { - - if (!$type) { - $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ? $_SERVER['HTTP_ACCEPT'] : NULL; - - # XXX: allow content negotiation for RDF, RSS, or XRDS - - $type = common_negotiate_type(common_accept_to_prefs($httpaccept), - common_accept_to_prefs(PAGE_TYPE_PREFS)); - - if (!$type) { - common_user_error(_('This page is not available in a media type you accept'), 406); - exit(0); - } - } - - header('Content-Type: '.$type); - - common_start_xml('html', - '-//W3C//DTD XHTML 1.0 Strict//EN', - 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd', $indent); - - # FIXME: correct language for interface - - $language = common_language(); - - common_element_start('html', array('xmlns' => 'http://www.w3.org/1999/xhtml', - 'xml:lang' => $language, - 'lang' => $language)); + common_start_html(); + + common_element_start('head'); + common_element('title', null, + $pagetitle . " - " . $config['site']['name']); + common_element('link', array('rel' => 'stylesheet', + 'type' => 'text/css', + 'href' => theme_path('display.css') . '?version=' . LACONICA_VERSION, + 'media' => 'screen, projection, tv')); + foreach (array(6,7) as $ver) { + if (file_exists(theme_file('ie'.$ver.'.css'))) { + // Yes, IE people should be put in jail. + $xw->writeComment('[if lte IE '.$ver.']> 'text/javascript', + 'src' => common_path('js/jquery.min.js')), + ' '); + common_element('script', array('type' => 'text/javascript', + 'src' => common_path('js/jquery.form.js')), + ' '); + common_element('script', array('type' => 'text/javascript', + 'src' => common_path('js/xbImportNode.js')), + ' '); + common_element('script', array('type' => 'text/javascript', + 'src' => common_path('js/util.js?version='.LACONICA_VERSION)), + ' '); + common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', + 'href' => common_local_url('opensearch', array('type' => 'people')), + 'title' => common_config('site', 'name').' People Search')); + + common_element('link', array('rel' => 'search', 'type' => 'application/opensearchdescription+xml', + 'href' => common_local_url('opensearch', array('type' => 'notice')), + 'title' => common_config('site', 'name').' Notice Search')); + + if ($callable) { + if ($data) { + call_user_func($callable, $data); + } else { + call_user_func($callable); + } + } + common_element_end('head'); + common_element_start('body', $action); + common_element_start('div', array('id' => 'wrap')); + common_element_start('div', array('id' => 'header')); + common_nav_menu(); + if ((isset($config['site']['logo']) && is_string($config['site']['logo']) && (strlen($config['site']['logo']) > 0)) + || file_exists(theme_file('logo.png'))) + { + common_element_start('a', array('href' => common_local_url('public'))); + common_element('img', array('src' => isset($config['site']['logo']) ? + ($config['site']['logo']) : theme_path('logo.png'), + 'alt' => $config['site']['name'], + 'id' => 'logo')); + common_element_end('a'); + } else { + common_element_start('p', array('id' => 'branding')); + common_element('a', array('href' => common_local_url('public')), + $config['site']['name']); + common_element_end('p'); + } + + common_element('h1', 'pagetitle', $pagetitle); + + if ($headercall) { + if ($data) { + call_user_func($headercall, $data); + } else { + call_user_func($headercall); + } + } + common_element_end('div'); + common_element_start('div', array('id' => 'content')); +} + +function common_start_html($type=null, $indent=true) { + + if (!$type) { + $httpaccept = isset($_SERVER['HTTP_ACCEPT']) ? $_SERVER['HTTP_ACCEPT'] : null; + + // XXX: allow content negotiation for RDF, RSS, or XRDS + + $type = common_negotiate_type(common_accept_to_prefs($httpaccept), + common_accept_to_prefs(PAGE_TYPE_PREFS)); + + if (!$type) { + common_user_error(_('This page is not available in a media type you accept'), 406); + exit(0); + } + } + + header('Content-Type: '.$type); + + common_start_xml('html', + '-//W3C//DTD XHTML 1.0 Strict//EN', + 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd', $indent); + + // FIXME: correct language for interface + + $language = common_language(); + + common_element_start('html', array('xmlns' => 'http://www.w3.org/1999/xhtml', + 'xml:lang' => $language, + 'lang' => $language)); } function common_show_footer() { - global $xw, $config; - common_element_end('div'); # content div - common_foot_menu(); - common_element_start('div', array('id' => 'footer')); - common_element_start('div', 'laconica'); - if (common_config('site', 'broughtby')) { - $instr = _('**%%site.name%%** is a microblogging service brought to you by [%%site.broughtby%%](%%site.broughtbyurl%%). '); - } else { - $instr = _('**%%site.name%%** is a microblogging service. '); - } - $instr .= sprintf(_('It runs the [Laconica](http://laconi.ca/) microblogging software, version %s, available under the [GNU Affero General Public License](http://www.fsf.org/licensing/licenses/agpl-3.0.html).'), LACONICA_VERSION); + global $xw, $config; + common_element_end('div'); // content div + common_foot_menu(); + common_element_start('div', array('id' => 'footer')); + common_element_start('div', 'laconica'); + if (common_config('site', 'broughtby')) { + $instr = _('**%%site.name%%** is a microblogging service brought to you by [%%site.broughtby%%](%%site.broughtbyurl%%). '); + } else { + $instr = _('**%%site.name%%** is a microblogging service. '); + } + $instr .= sprintf(_('It runs the [Laconica](http://laconi.ca/) microblogging software, version %s, available under the [GNU Affero General Public License](http://www.fsf.org/licensing/licenses/agpl-3.0.html).'), LACONICA_VERSION); $output = common_markup_to_html($instr); common_raw($output); - common_element_end('div'); - common_element('img', array('id' => 'cc', - 'src' => $config['license']['image'], - 'alt' => $config['license']['title'])); - common_element_start('p'); - common_text(_('Unless otherwise specified, contents of this site are copyright by the contributors and available under the ')); - common_element('a', array('class' => 'license', - 'rel' => 'license', - 'href' => $config['license']['url']), - $config['license']['title']); - common_text(_('. Contributors should be attributed by full name or nickname.')); - common_element_end('p'); - common_element_end('div'); - common_element_end('div'); - common_element_end('body'); - common_element_end('html'); - common_end_xml(); + common_element_end('div'); + common_element('img', array('id' => 'cc', + 'src' => $config['license']['image'], + 'alt' => $config['license']['title'])); + common_element_start('p'); + common_text(_('Unless otherwise specified, contents of this site are copyright by the contributors and available under the ')); + common_element('a', array('class' => 'license', + 'rel' => 'license', + 'href' => $config['license']['url']), + $config['license']['title']); + common_text(_('. Contributors should be attributed by full name or nickname.')); + common_element_end('p'); + common_element_end('div'); + common_element_end('div'); + common_element_end('body'); + common_element_end('html'); + common_end_xml(); } function common_text($txt) { - global $xw; - $xw->text($txt); + global $xw; + $xw->text($txt); } function common_raw($xml) { - global $xw; - $xw->writeRaw($xml); + global $xw; + $xw->writeRaw($xml); } function common_nav_menu() { - $user = common_current_user(); - common_element_start('ul', array('id' => 'nav')); - if ($user) { - common_menu_item(common_local_url('all', array('nickname' => $user->nickname)), - _('Home')); - } - common_menu_item(common_local_url('peoplesearch'), _('Search')); - if ($user) { - common_menu_item(common_local_url('profilesettings'), - _('Settings')); - common_menu_item(common_local_url('invite'), - _('Invite')); - common_menu_item(common_local_url('logout'), - _('Logout')); - } else { - common_menu_item(common_local_url('login'), _('Login')); - if (!common_config('site', 'closed')) { - common_menu_item(common_local_url('register'), _('Register')); - } - common_menu_item(common_local_url('openidlogin'), _('OpenID')); - } - common_menu_item(common_local_url('doc', array('title' => 'help')), - _('Help')); - common_element_end('ul'); + $user = common_current_user(); + common_element_start('ul', array('id' => 'nav')); + if ($user) { + common_menu_item(common_local_url('all', array('nickname' => $user->nickname)), + _('Home')); + } + common_menu_item(common_local_url('peoplesearch'), _('Search')); + if ($user) { + common_menu_item(common_local_url('profilesettings'), + _('Settings')); + common_menu_item(common_local_url('invite'), + _('Invite')); + common_menu_item(common_local_url('logout'), + _('Logout')); + } else { + common_menu_item(common_local_url('login'), _('Login')); + if (!common_config('site', 'closed')) { + common_menu_item(common_local_url('register'), _('Register')); + } + common_menu_item(common_local_url('openidlogin'), _('OpenID')); + } + common_menu_item(common_local_url('doc', array('title' => 'help')), + _('Help')); + common_element_end('ul'); } function common_foot_menu() { - common_element_start('ul', array('id' => 'nav_sub')); - common_menu_item(common_local_url('doc', array('title' => 'help')), - _('Help')); - common_menu_item(common_local_url('doc', array('title' => 'about')), - _('About')); - common_menu_item(common_local_url('doc', array('title' => 'faq')), - _('FAQ')); - common_menu_item(common_local_url('doc', array('title' => 'privacy')), - _('Privacy')); - common_menu_item(common_local_url('doc', array('title' => 'source')), - _('Source')); - common_menu_item(common_local_url('doc', array('title' => 'contact')), - _('Contact')); - common_element_end('ul'); -} - -function common_menu_item($url, $text, $title=NULL, $is_selected=false) { - $lattrs = array(); - if ($is_selected) { - $lattrs['class'] = 'current'; - } - common_element_start('li', $lattrs); - $attrs['href'] = $url; - if ($title) { - $attrs['title'] = $title; - } - common_element('a', $attrs, $text); - common_element_end('li'); -} - -function common_input($id, $label, $value=NULL,$instructions=NULL) { - common_element_start('p'); - common_element('label', array('for' => $id), $label); - $attrs = array('name' => $id, - 'type' => 'text', - 'class' => 'input_text', - 'id' => $id); - if ($value) { - $attrs['value'] = htmlspecialchars($value); - } - common_element('input', $attrs); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); -} - -function common_checkbox($id, $label, $checked=false, $instructions=NULL, $value='true', $disabled=false) + common_element_start('ul', array('id' => 'nav_sub')); + common_menu_item(common_local_url('doc', array('title' => 'help')), + _('Help')); + common_menu_item(common_local_url('doc', array('title' => 'about')), + _('About')); + common_menu_item(common_local_url('doc', array('title' => 'faq')), + _('FAQ')); + common_menu_item(common_local_url('doc', array('title' => 'privacy')), + _('Privacy')); + common_menu_item(common_local_url('doc', array('title' => 'source')), + _('Source')); + common_menu_item(common_local_url('doc', array('title' => 'contact')), + _('Contact')); + common_element_end('ul'); +} + +function common_menu_item($url, $text, $title=null, $is_selected=false) { + $lattrs = array(); + if ($is_selected) { + $lattrs['class'] = 'current'; + } + common_element_start('li', $lattrs); + $attrs['href'] = $url; + if ($title) { + $attrs['title'] = $title; + } + common_element('a', $attrs, $text); + common_element_end('li'); +} + +function common_input($id, $label, $value=null,$instructions=null) { + common_element_start('p'); + common_element('label', array('for' => $id), $label); + $attrs = array('name' => $id, + 'type' => 'text', + 'class' => 'input_text', + 'id' => $id); + if ($value) { + $attrs['value'] = htmlspecialchars($value); + } + common_element('input', $attrs); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); +} + +function common_checkbox($id, $label, $checked=false, $instructions=null, $value='true', $disabled=false) { - common_element_start('p'); - $attrs = array('name' => $id, - 'type' => 'checkbox', - 'class' => 'checkbox', - 'id' => $id); - if ($value) { - $attrs['value'] = htmlspecialchars($value); - } - if ($checked) { - $attrs['checked'] = 'checked'; - } - if ($disabled) { - $attrs['disabled'] = 'true'; - } - common_element('input', $attrs); - common_text(' '); - common_element('label', array('class' => 'checkbox_label', 'for' => $id), $label); - common_text(' '); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); -} - -function common_dropdown($id, $label, $content, $instructions=NULL, $blank_select=FALSE, $selected=NULL) { - common_element_start('p'); - common_element('label', array('for' => $id), $label); - common_element_start('select', array('id' => $id, 'name' => $id)); - if ($blank_select) { - common_element('option', array('value' => '')); - } - foreach ($content as $value => $option) { - if ($value == $selected) { - common_element('option', array('value' => $value, 'selected' => $value), $option); - } else { - common_element('option', array('value' => $value), $option); - } - } - common_element_end('select'); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); + common_element_start('p'); + $attrs = array('name' => $id, + 'type' => 'checkbox', + 'class' => 'checkbox', + 'id' => $id); + if ($value) { + $attrs['value'] = htmlspecialchars($value); + } + if ($checked) { + $attrs['checked'] = 'checked'; + } + if ($disabled) { + $attrs['disabled'] = 'true'; + } + common_element('input', $attrs); + common_text(' '); + common_element('label', array('class' => 'checkbox_label', 'for' => $id), $label); + common_text(' '); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); +} + +function common_dropdown($id, $label, $content, $instructions=null, $blank_select=FALSE, $selected=null) { + common_element_start('p'); + common_element('label', array('for' => $id), $label); + common_element_start('select', array('id' => $id, 'name' => $id)); + if ($blank_select) { + common_element('option', array('value' => '')); + } + foreach ($content as $value => $option) { + if ($value == $selected) { + common_element('option', array('value' => $value, 'selected' => $value), $option); + } else { + common_element('option', array('value' => $value), $option); + } + } + common_element_end('select'); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); } function common_hidden($id, $value) { - common_element('input', array('name' => $id, - 'type' => 'hidden', - 'id' => $id, - 'value' => $value)); -} - -function common_password($id, $label, $instructions=NULL) { - common_element_start('p'); - common_element('label', array('for' => $id), $label); - $attrs = array('name' => $id, - 'type' => 'password', - 'class' => 'password', - 'id' => $id); - common_element('input', $attrs); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); + common_element('input', array('name' => $id, + 'type' => 'hidden', + 'id' => $id, + 'value' => $value)); +} + +function common_password($id, $label, $instructions=null) { + common_element_start('p'); + common_element('label', array('for' => $id), $label); + $attrs = array('name' => $id, + 'type' => 'password', + 'class' => 'password', + 'id' => $id); + common_element('input', $attrs); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); } function common_submit($id, $label, $cls='submit') { - global $xw; - common_element_start('p'); - common_element('input', array('type' => 'submit', - 'id' => $id, - 'name' => $id, - 'class' => $cls, - 'value' => $label)); - common_element_end('p'); -} - -function common_textarea($id, $label, $content=NULL, $instructions=NULL) { - common_element_start('p'); - common_element('label', array('for' => $id), $label); - common_element('textarea', array('rows' => 3, - 'cols' => 40, - 'name' => $id, - 'id' => $id), - ($content) ? $content : ''); - if ($instructions) { - common_element('span', 'input_instructions', $instructions); - } - common_element_end('p'); + global $xw; + common_element_start('p'); + common_element('input', array('type' => 'submit', + 'id' => $id, + 'name' => $id, + 'class' => $cls, + 'value' => $label)); + common_element_end('p'); +} + +function common_textarea($id, $label, $content=null, $instructions=null) { + common_element_start('p'); + common_element('label', array('for' => $id), $label); + common_element('textarea', array('rows' => 3, + 'cols' => 40, + 'name' => $id, + 'id' => $id), + ($content) ? $content : ''); + if ($instructions) { + common_element('span', 'input_instructions', $instructions); + } + common_element_end('p'); } function common_timezone() { - if (common_logged_in()) { - $user = common_current_user(); - if ($user->timezone) { - return $user->timezone; - } - } + if (common_logged_in()) { + $user = common_current_user(); + if ($user->timezone) { + return $user->timezone; + } + } - global $config; - return $config['site']['timezone']; + global $config; + return $config['site']['timezone']; } function common_language() { - // If there is a user logged in and they've set a language preference - // then return that one... - if (common_logged_in()) { - $user = common_current_user(); - $user_language = $user->language; - if ($user_language) - return $user_language; - } + // If there is a user logged in and they've set a language preference + // then return that one... + if (common_logged_in()) { + $user = common_current_user(); + $user_language = $user->language; + if ($user_language) + return $user_language; + } - // Otherwise, find the best match for the languages requested by the - // user's browser... - $httplang = isset($_SERVER['HTTP_ACCEPT_LANGUAGE']) ? $_SERVER['HTTP_ACCEPT_LANGUAGE'] : NULL; - if (!empty($httplang)) { - $language = client_prefered_language($httplang); - if ($language) - return $language; - } + // Otherwise, find the best match for the languages requested by the + // user's browser... + $httplang = isset($_SERVER['HTTP_ACCEPT_LANGUAGE']) ? $_SERVER['HTTP_ACCEPT_LANGUAGE'] : null; + if (!empty($httplang)) { + $language = client_prefered_language($httplang); + if ($language) + return $language; + } - // Finally, if none of the above worked, use the site's default... - return common_config('site', 'language'); + // Finally, if none of the above worked, use the site's default... + return common_config('site', 'language'); } -# salted, hashed passwords are stored in the DB +// salted, hashed passwords are stored in the DB function common_munge_password($password, $id) { - return md5($password . $id); + return md5($password . $id); } -# check if a username exists and has matching password +// check if a username exists and has matching password function common_check_user($nickname, $password) { - # NEVER allow blank passwords, even if they match the DB - if (mb_strlen($password) == 0) { - return false; - } - $user = User::staticGet('nickname', $nickname); - if (is_null($user)) { - return false; - } else { - if (0 == strcmp(common_munge_password($password, $user->id), - $user->password)) { - return $user; - } else { - return false; - } - } -} - -# is the current user logged in? + // NEVER allow blank passwords, even if they match the DB + if (mb_strlen($password) == 0) { + return false; + } + $user = User::staticGet('nickname', $nickname); + if (is_null($user)) { + return false; + } else { + if (0 == strcmp(common_munge_password($password, $user->id), + $user->password)) { + return $user; + } else { + return false; + } + } +} + +// is the current user logged in? function common_logged_in() { - return (!is_null(common_current_user())); + return (!is_null(common_current_user())); } function common_have_session() { - return (0 != strcmp(session_id(), '')); + return (0 != strcmp(session_id(), '')); } function common_ensure_session() { - if (!common_have_session()) { - @session_start(); - } + if (!common_have_session()) { + @session_start(); + } } -# Three kinds of arguments: -# 1) a user object -# 2) a nickname -# 3) NULL to clear +// Three kinds of arguments: +// 1) a user object +// 2) a nickname +// 3) null to clear -# Initialize to false; set to NULL if none found +// Initialize to false; set to null if none found $_cur = false; @@ -572,92 +572,92 @@ function common_set_user($user) { global $_cur; - if (is_null($user) && common_have_session()) { - $_cur = NULL; - unset($_SESSION['userid']); - return true; - } else if (is_string($user)) { - $nickname = $user; - $user = User::staticGet('nickname', $nickname); - } else if (!($user instanceof User)) { - return false; - } - - if ($user) { - common_ensure_session(); - $_SESSION['userid'] = $user->id; + if (is_null($user) && common_have_session()) { + $_cur = null; + unset($_SESSION['userid']); + return true; + } else if (is_string($user)) { + $nickname = $user; + $user = User::staticGet('nickname', $nickname); + } else if (!($user instanceof User)) { + return false; + } + + if ($user) { + common_ensure_session(); + $_SESSION['userid'] = $user->id; $_cur = $user; - return $_cur; - } - return false; + return $_cur; + } + return false; } function common_set_cookie($key, $value, $expiration=0) { - $path = common_config('site', 'path'); - $server = common_config('site', 'server'); + $path = common_config('site', 'path'); + $server = common_config('site', 'server'); - if ($path && ($path != '/')) { - $cookiepath = '/' . $path . '/'; - } else { - $cookiepath = '/'; - } - return setcookie($key, - $value, - $expiration, - $cookiepath, - $server); + if ($path && ($path != '/')) { + $cookiepath = '/' . $path . '/'; + } else { + $cookiepath = '/'; + } + return setcookie($key, + $value, + $expiration, + $cookiepath, + $server); } define('REMEMBERME', 'rememberme'); -define('REMEMBERME_EXPIRY', 30 * 24 * 60 * 60); # 30 days +define('REMEMBERME_EXPIRY', 30 * 24 * 60 * 60); // 30 days -function common_rememberme($user=NULL) { - if (!$user) { - $user = common_current_user(); - if (!$user) { - common_debug('No current user to remember', __FILE__); - return false; - } - } +function common_rememberme($user=null) { + if (!$user) { + $user = common_current_user(); + if (!$user) { + common_debug('No current user to remember', __FILE__); + return false; + } + } - $rm = new Remember_me(); + $rm = new Remember_me(); - $rm->code = common_good_rand(16); - $rm->user_id = $user->id; + $rm->code = common_good_rand(16); + $rm->user_id = $user->id; - # Wrap the insert in some good ol' fashioned transaction code + // Wrap the insert in some good ol' fashioned transaction code $rm->query('BEGIN'); - $result = $rm->insert(); + $result = $rm->insert(); - if (!$result) { - common_log_db_error($rm, 'INSERT', __FILE__); - common_debug('Error adding rememberme record for ' . $user->nickname, __FILE__); - return false; + if (!$result) { + common_log_db_error($rm, 'INSERT', __FILE__); + common_debug('Error adding rememberme record for ' . $user->nickname, __FILE__); + return false; } $rm->query('COMMIT'); - common_debug('Inserted rememberme record (' . $rm->code . ', ' . $rm->user_id . '); result = ' . $result . '.', __FILE__); + common_debug('Inserted rememberme record (' . $rm->code . ', ' . $rm->user_id . '); result = ' . $result . '.', __FILE__); $cookieval = $rm->user_id . ':' . $rm->code; - common_log(LOG_INFO, 'adding rememberme cookie "' . $cookieval . '" for ' . $user->nickname); + common_log(LOG_INFO, 'adding rememberme cookie "' . $cookieval . '" for ' . $user->nickname); - common_set_cookie(REMEMBERME, $cookieval, time() + REMEMBERME_EXPIRY); + common_set_cookie(REMEMBERME, $cookieval, time() + REMEMBERME_EXPIRY); - return true; + return true; } function common_remembered_user() { - $user = NULL; + $user = null; - $packed = isset($_COOKIE[REMEMBERME]) ? $_COOKIE[REMEMBERME] : NULL; + $packed = isset($_COOKIE[REMEMBERME]) ? $_COOKIE[REMEMBERME] : null; - if (!$packed) { - return NULL; + if (!$packed) { + return null; } list($id, $code) = explode(':', $packed); @@ -665,7 +665,7 @@ function common_remembered_user() { if (!$id || !$code) { common_log(LOG_WARNING, 'Malformed rememberme cookie: ' . $packed); common_forgetme(); - return NULL; + return null; } $rm = Remember_me::staticGet($code); @@ -673,13 +673,13 @@ function common_remembered_user() { if (!$rm) { common_log(LOG_WARNING, 'No such remember code: ' . $code); common_forgetme(); - return NULL; + return null; } if ($rm->user_id != $id) { common_log(LOG_WARNING, 'Rememberme code for wrong user: ' . $rm->user_id . ' != ' . $id); common_forgetme(); - return NULL; + return null; } $user = User::staticGet($rm->user_id); @@ -687,17 +687,17 @@ function common_remembered_user() { if (!$user) { common_log(LOG_WARNING, 'No such user for rememberme: ' . $rm->user_id); common_forgetme(); - return NULL; + return null; } - # successful! + // successful! $result = $rm->delete(); if (!$result) { common_log_db_error($rm, 'DELETE', __FILE__); common_log(LOG_WARNING, 'Could not delete rememberme: ' . $code); common_forgetme(); - return NULL; + return null; } common_log(LOG_INFO, 'logging in ' . $user->nickname . ' using rememberme code ' . $rm->code); @@ -705,21 +705,21 @@ function common_remembered_user() { common_set_user($user); common_real_login(false); - # We issue a new cookie, so they can log in - # automatically again after this session + // We issue a new cookie, so they can log in + // automatically again after this session common_rememberme($user); - return $user; + return $user; } -# must be called with a valid user! +// must be called with a valid user! function common_forgetme() { - common_set_cookie(REMEMBERME, '', 0); + common_set_cookie(REMEMBERME, '', 0); } -# who is the current user? +// who is the current user? function common_current_user() { global $_cur; @@ -734,99 +734,99 @@ function common_current_user() { } } - # that didn't work; try to remember; will init $_cur to NULL on failure + // that didn't work; try to remember; will init $_cur to null on failure $_cur = common_remembered_user(); if ($_cur) { common_debug("Got User " . $_cur->nickname); common_debug("Faking session on remembered user"); - # XXX: Is this necessary? + // XXX: Is this necessary? $_SESSION['userid'] = $_cur->id; } } - return $_cur; + return $_cur; } -# Logins that are 'remembered' aren't 'real' -- they're subject to -# cookie-stealing. So, we don't let them do certain things. New reg, -# OpenID, and password logins _are_ real. +// Logins that are 'remembered' aren't 'real' -- they're subject to +// cookie-stealing. So, we don't let them do certain things. New reg, +// OpenID, and password logins _are_ real. function common_real_login($real=true) { - common_ensure_session(); - $_SESSION['real_login'] = $real; + common_ensure_session(); + $_SESSION['real_login'] = $real; } function common_is_real_login() { - return common_logged_in() && $_SESSION['real_login']; + return common_logged_in() && $_SESSION['real_login']; } -# get canonical version of nickname for comparison +// get canonical version of nickname for comparison function common_canonical_nickname($nickname) { - # XXX: UTF-8 canonicalization (like combining chars) - return strtolower($nickname); + // XXX: UTF-8 canonicalization (like combining chars) + return strtolower($nickname); } -# get canonical version of email for comparison +// get canonical version of email for comparison function common_canonical_email($email) { - # XXX: canonicalize UTF-8 - # XXX: lcase the domain part - return $email; + // XXX: canonicalize UTF-8 + // XXX: lcase the domain part + return $email; } define('URL_REGEX', '^|[ \t\r\n])((ftp|http|https|gopher|mailto|news|nntp|telnet|wais|file|prospero|aim|webcal):(([A-Za-z0-9$_.+!*(),;/?:@&~=-])|%[A-Fa-f0-9]{2}){2,}(#([a-zA-Z0-9][a-zA-Z0-9$_.+!*(),;/?:@&~=%-]*))?([A-Za-z0-9$_+!*();/?:~-]))'); function common_render_content($text, $notice) { - $r = common_render_text($text); - $id = $notice->profile_id; - $r = preg_replace('/(^|\s+)@([A-Za-z0-9]{1,64})/e', "'\\1@'.common_at_link($id, '\\2')", $r); - $r = preg_replace('/^T ([A-Z0-9]{1,64}) /e', "'T '.common_at_link($id, '\\1').' '", $r); - $r = preg_replace('/(^|\s+)@#([A-Za-z0-9]{1,64})/e', "'\\1@#'.common_at_hash_link($id, '\\2')", $r); - return $r; + $r = common_render_text($text); + $id = $notice->profile_id; + $r = preg_replace('/(^|\s+)@([A-Za-z0-9]{1,64})/e', "'\\1@'.common_at_link($id, '\\2')", $r); + $r = preg_replace('/^T ([A-Z0-9]{1,64}) /e', "'T '.common_at_link($id, '\\1').' '", $r); + $r = preg_replace('/(^|\s+)@#([A-Za-z0-9]{1,64})/e', "'\\1@#'.common_at_hash_link($id, '\\2')", $r); + return $r; } function common_render_text($text) { - $r = htmlspecialchars($text); + $r = htmlspecialchars($text); - $r = preg_replace('/[\x{0}-\x{8}\x{b}-\x{c}\x{e}-\x{19}]/', '', $r); - $r = preg_replace_callback('@https?://[^\]>\s]+@', 'common_render_uri_thingy', $r); - $r = preg_replace('/(^|\s+)#([A-Za-z0-9_\-\.]{1,64})/e', "'\\1#'.common_tag_link('\\2')", $r); - # XXX: machine tags - return $r; + $r = preg_replace('/[\x{0}-\x{8}\x{b}-\x{c}\x{e}-\x{19}]/', '', $r); + $r = preg_replace_callback('@https?://[^\]>\s]+@', 'common_render_uri_thingy', $r); + $r = preg_replace('/(^|\s+)#([A-Za-z0-9_\-\.]{1,64})/e', "'\\1#'.common_tag_link('\\2')", $r); + // XXX: machine tags + return $r; } function common_render_uri_thingy($matches) { - $uri = $matches[0]; - $trailer = ''; - - # Some heuristics for extracting URIs from surrounding punctuation - # Strip from trailing text... - if (preg_match('/^(.*)([,.:"\']+)$/', $uri, $matches)) { - $uri = $matches[1]; - $trailer = $matches[2]; - } - - $pairs = array( - ']' => '[', # technically disallowed in URIs, but used in Java docs - ')' => '(', # far too frequent in Wikipedia and MSDN - ); - $final = substr($uri, -1, 1); - if (isset($pairs[$final])) { - $openers = substr_count($uri, $pairs[$final]); - $closers = substr_count($uri, $final); - if ($closers > $openers) { - // Assume the paren was opened outside the URI - $uri = substr($uri, 0, -1); - $trailer = $final . $trailer; - } - } - if ($longurl = common_longurl($uri)) { - $longurl = htmlentities($longurl, ENT_QUOTES, 'UTF-8'); - $title = " title='$longurl'"; - } - else $title = ''; - - return '' . $uri . '' . $trailer; + $uri = $matches[0]; + $trailer = ''; + + // Some heuristics for extracting URIs from surrounding punctuation + // Strip from trailing text... + if (preg_match('/^(.*)([,.:"\']+)$/', $uri, $matches)) { + $uri = $matches[1]; + $trailer = $matches[2]; + } + + $pairs = array( + ']' => '[', // technically disallowed in URIs, but used in Java docs + ')' => '(', // far too frequent in Wikipedia and MSDN + ); + $final = substr($uri, -1, 1); + if (isset($pairs[$final])) { + $openers = substr_count($uri, $pairs[$final]); + $closers = substr_count($uri, $final); + if ($closers > $openers) { + // Assume the paren was opened outside the URI + $uri = substr($uri, 0, -1); + $trailer = $final . $trailer; + } + } + if ($longurl = common_longurl($uri)) { + $longurl = htmlentities($longurl, ENT_QUOTES, 'UTF-8'); + $title = " title='$longurl'"; + } + else $title = ''; + + return '' . $uri . '' . $trailer; } function common_longurl($short_url) { @@ -836,10 +836,10 @@ function common_longurl($short_url) { } function common_longurl2($uri) { - $uri_e = urlencode($uri); - $longurl = unserialize(file_get_contents("http://api.longurl.org/v1/expand?format=php&url=$uri_e")); - if (empty($longurl['long_url']) || $uri === $longurl['long_url']) return false; - return stripslashes($longurl['long_url']); + $uri_e = urlencode($uri); + $longurl = unserialize(file_get_contents("http://api.longurl.org/v1/expand?format=php&url=$uri_e")); + if (empty($longurl['long_url']) || $uri === $longurl['long_url']) return false; + return stripslashes($longurl['long_url']); } function common_shorten_links($text) { @@ -847,465 +847,465 @@ function common_shorten_links($text) { static $cache = array(); if (isset($cache[$text])) return $cache[$text]; // \s = not a horizontal whitespace character (since PHP 5.2.4) - return $cache[$text] = preg_replace('@https?://[^)\]>\s]+@e', "common_shorten_link('\\0')", $text); + return $cache[$text] = preg_replace('@https?://[^)\]>\s]+@e', "common_shorten_link('\\0')", $text); } function common_shorten_link($url, $reverse = false) { - static $url_cache = array(); + static $url_cache = array(); if ($reverse) return isset($url_cache[$url]) ? $url_cache[$url] : $url; - $user = common_current_user(); - - $curlh = curl_init(); - curl_setopt($curlh, CURLOPT_CONNECTTIMEOUT, 20); // # seconds to wait - curl_setopt($curlh, CURLOPT_USERAGENT, 'Laconica'); - curl_setopt($curlh, CURLOPT_RETURNTRANSFER, true); - - switch($user->urlshorteningservice) { - case 'ur1.ca': - $short_url_service = new LilUrl; - $short_url = $short_url_service->shorten($url); - break; - - case '2tu.us': - $short_url_service = new TightUrl; - $short_url = $short_url_service->shorten($url); - break; - - case 'ptiturl.com': - $short_url_service = new PtitUrl; - $short_url = $short_url_service->shorten($url); - break; - - case 'bit.ly': - curl_setopt($curlh, CURLOPT_URL, 'http://bit.ly/api?method=shorten&long_url='.urlencode($url)); - $short_url = current(json_decode(curl_exec($curlh))->results)->hashUrl; - break; - - case 'is.gd': - curl_setopt($curlh, CURLOPT_URL, 'http://is.gd/api.php?longurl='.urlencode($url)); - $short_url = curl_exec($curlh); - break; - case 'snipr.com': - curl_setopt($curlh, CURLOPT_URL, 'http://snipr.com/site/snip?r=simple&link='.urlencode($url)); - $short_url = curl_exec($curlh); - break; - case 'metamark.net': - curl_setopt($curlh, CURLOPT_URL, 'http://metamark.net/api/rest/simple?long_url='.urlencode($url)); - $short_url = curl_exec($curlh); - break; - case 'tinyurl.com': - curl_setopt($curlh, CURLOPT_URL, 'http://tinyurl.com/api-create.php?url='.urlencode($url)); - $short_url = curl_exec($curlh); - break; - default: - $short_url = false; - } - - curl_close($curlh); - - if ($short_url) { + $user = common_current_user(); + + $curlh = curl_init(); + curl_setopt($curlh, CURLOPT_CONNECTTIMEOUT, 20); // # seconds to wait + curl_setopt($curlh, CURLOPT_USERAGENT, 'Laconica'); + curl_setopt($curlh, CURLOPT_RETURNTRANSFER, true); + + switch($user->urlshorteningservice) { + case 'ur1.ca': + $short_url_service = new LilUrl; + $short_url = $short_url_service->shorten($url); + break; + + case '2tu.us': + $short_url_service = new TightUrl; + $short_url = $short_url_service->shorten($url); + break; + + case 'ptiturl.com': + $short_url_service = new PtitUrl; + $short_url = $short_url_service->shorten($url); + break; + + case 'bit.ly': + curl_setopt($curlh, CURLOPT_URL, 'http://bit.ly/api?method=shorten&long_url='.urlencode($url)); + $short_url = current(json_decode(curl_exec($curlh))->results)->hashUrl; + break; + + case 'is.gd': + curl_setopt($curlh, CURLOPT_URL, 'http://is.gd/api.php?longurl='.urlencode($url)); + $short_url = curl_exec($curlh); + break; + case 'snipr.com': + curl_setopt($curlh, CURLOPT_URL, 'http://snipr.com/site/snip?r=simple&link='.urlencode($url)); + $short_url = curl_exec($curlh); + break; + case 'metamark.net': + curl_setopt($curlh, CURLOPT_URL, 'http://metamark.net/api/rest/simple?long_url='.urlencode($url)); + $short_url = curl_exec($curlh); + break; + case 'tinyurl.com': + curl_setopt($curlh, CURLOPT_URL, 'http://tinyurl.com/api-create.php?url='.urlencode($url)); + $short_url = curl_exec($curlh); + break; + default: + $short_url = false; + } + + curl_close($curlh); + + if ($short_url) { $url_cache[(string)$short_url] = $url; - return (string)$short_url; - } - return $url; + return (string)$short_url; + } + return $url; } function common_xml_safe_str($str) { - $xmlStr = htmlentities(iconv('UTF-8', 'UTF-8//IGNORE', $str), ENT_NOQUOTES, 'UTF-8'); + $xmlStr = htmlentities(iconv('UTF-8', 'UTF-8//IGNORE', $str), ENT_NOQUOTES, 'UTF-8'); - // Replace control, formatting, and surrogate characters with '*', ala Twitter - return preg_replace('/[\p{Cc}\p{Cf}\p{Cs}]/u', '*', $str); + // Replace control, formatting, and surrogate characters with '*', ala Twitter + return preg_replace('/[\p{Cc}\p{Cf}\p{Cs}]/u', '*', $str); } function common_tag_link($tag) { - $canonical = common_canonical_tag($tag); - $url = common_local_url('tag', array('tag' => $canonical)); - return ''; + $canonical = common_canonical_tag($tag); + $url = common_local_url('tag', array('tag' => $canonical)); + return ''; } function common_canonical_tag($tag) { - return strtolower(str_replace(array('-', '_', '.'), '', $tag)); + return strtolower(str_replace(array('-', '_', '.'), '', $tag)); } function common_valid_profile_tag($str) { - return preg_match('/^[A-Za-z0-9_\-\.]{1,64}$/', $str); + return preg_match('/^[A-Za-z0-9_\-\.]{1,64}$/', $str); } function common_at_link($sender_id, $nickname) { - $sender = Profile::staticGet($sender_id); - $recipient = common_relative_profile($sender, common_canonical_nickname($nickname)); - if ($recipient) { - return ''.$nickname.''; - } else { - return $nickname; - } + $sender = Profile::staticGet($sender_id); + $recipient = common_relative_profile($sender, common_canonical_nickname($nickname)); + if ($recipient) { + return ''.$nickname.''; + } else { + return $nickname; + } } function common_at_hash_link($sender_id, $tag) { - $user = User::staticGet($sender_id); - if (!$user) { - return $tag; - } - $tagged = Profile_tag::getTagged($user->id, common_canonical_tag($tag)); - if ($tagged) { - $url = common_local_url('subscriptions', - array('nickname' => $user->nickname, - 'tag' => $tag)); - return ''.$tag.''; - } else { - return $tag; - } -} - -function common_relative_profile($sender, $nickname, $dt=NULL) { - # Try to find profiles this profile is subscribed to that have this nickname - $recipient = new Profile(); - # XXX: use a join instead of a subquery - $recipient->whereAdd('EXISTS (SELECT subscribed from subscription where subscriber = '.$sender->id.' and subscribed = id)', 'AND'); - $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); - if ($recipient->find(TRUE)) { - # XXX: should probably differentiate between profiles with - # the same name by date of most recent update - return $recipient; - } - # Try to find profiles that listen to this profile and that have this nickname - $recipient = new Profile(); - # XXX: use a join instead of a subquery - $recipient->whereAdd('EXISTS (SELECT subscriber from subscription where subscribed = '.$sender->id.' and subscriber = id)', 'AND'); - $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); - if ($recipient->find(TRUE)) { - # XXX: should probably differentiate between profiles with - # the same name by date of most recent update - return $recipient; - } - # If this is a local user, try to find a local user with that nickname. - $sender = User::staticGet($sender->id); - if ($sender) { - $recipient_user = User::staticGet('nickname', $nickname); - if ($recipient_user) { - return $recipient_user->getProfile(); - } - } - # Otherwise, no links. @messages from local users to remote users, - # or from remote users to other remote users, are just - # outside our ability to make intelligent guesses about - return NULL; + $user = User::staticGet($sender_id); + if (!$user) { + return $tag; + } + $tagged = Profile_tag::getTagged($user->id, common_canonical_tag($tag)); + if ($tagged) { + $url = common_local_url('subscriptions', + array('nickname' => $user->nickname, + 'tag' => $tag)); + return ''.$tag.''; + } else { + return $tag; + } +} + +function common_relative_profile($sender, $nickname, $dt=null) { + // Try to find profiles this profile is subscribed to that have this nickname + $recipient = new Profile(); + // XXX: use a join instead of a subquery + $recipient->whereAdd('EXISTS (SELECT subscribed from subscription where subscriber = '.$sender->id.' and subscribed = id)', 'AND'); + $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); + if ($recipient->find(TRUE)) { + // XXX: should probably differentiate between profiles with + // the same name by date of most recent update + return $recipient; + } + // Try to find profiles that listen to this profile and that have this nickname + $recipient = new Profile(); + // XXX: use a join instead of a subquery + $recipient->whereAdd('EXISTS (SELECT subscriber from subscription where subscribed = '.$sender->id.' and subscriber = id)', 'AND'); + $recipient->whereAdd('nickname = "' . trim($nickname) . '"', 'AND'); + if ($recipient->find(TRUE)) { + // XXX: should probably differentiate between profiles with + // the same name by date of most recent update + return $recipient; + } + // If this is a local user, try to find a local user with that nickname. + $sender = User::staticGet($sender->id); + if ($sender) { + $recipient_user = User::staticGet('nickname', $nickname); + if ($recipient_user) { + return $recipient_user->getProfile(); + } + } + // Otherwise, no links. @messages from local users to remote users, + // or from remote users to other remote users, are just + // outside our ability to make intelligent guesses about + return null; } // where should the avatar go for this user? -function common_avatar_filename($id, $extension, $size=NULL, $extra=NULL) { - global $config; +function common_avatar_filename($id, $extension, $size=null, $extra=null) { + global $config; - if ($size) { - return $id . '-' . $size . (($extra) ? ('-' . $extra) : '') . $extension; - } else { - return $id . '-original' . (($extra) ? ('-' . $extra) : '') . $extension; - } + if ($size) { + return $id . '-' . $size . (($extra) ? ('-' . $extra) : '') . $extension; + } else { + return $id . '-original' . (($extra) ? ('-' . $extra) : '') . $extension; + } } function common_avatar_path($filename) { - global $config; - return INSTALLDIR . '/avatar/' . $filename; + global $config; + return INSTALLDIR . '/avatar/' . $filename; } function common_avatar_url($filename) { - return common_path('avatar/'.$filename); + return common_path('avatar/'.$filename); } function common_avatar_display_url($avatar) { - $server = common_config('avatar', 'server'); - if ($server) { - return 'http://'.$server.'/'.$avatar->filename; - } else { - return $avatar->url; - } + $server = common_config('avatar', 'server'); + if ($server) { + return 'http://'.$server.'/'.$avatar->filename; + } else { + return $avatar->url; + } } function common_default_avatar($size) { - static $sizenames = array(AVATAR_PROFILE_SIZE => 'profile', - AVATAR_STREAM_SIZE => 'stream', - AVATAR_MINI_SIZE => 'mini'); - return theme_path('default-avatar-'.$sizenames[$size].'.png'); -} - -function common_local_url($action, $args=NULL, $fragment=NULL) { - $url = NULL; - if (common_config('site','fancy')) { - $url = common_fancy_url($action, $args); - } else { - $url = common_simple_url($action, $args); - } - if (!is_null($fragment)) { - $url .= '#'.$fragment; - } - return $url; -} - -function common_fancy_url($action, $args=NULL) { - switch (strtolower($action)) { - case 'public': - if ($args && isset($args['page'])) { - return common_path('?page=' . $args['page']); - } else { - return common_path(''); - } - case 'featured': - if ($args && isset($args['page'])) { - return common_path('featured?page=' . $args['page']); - } else { - return common_path('featured'); - } - case 'favorited': - if ($args && isset($args['page'])) { - return common_path('favorited?page=' . $args['page']); - } else { - return common_path('favorited'); - } - case 'publicrss': - return common_path('rss'); - case 'publicatom': - return common_path("api/statuses/public_timeline.atom"); - case 'publicxrds': - return common_path('xrds'); - case 'featuredrss': - return common_path('featuredrss'); - case 'favoritedrss': - return common_path('favoritedrss'); - case 'opensearch': - if ($args && $args['type']) { - return common_path('opensearch/'.$args['type']); - } else { - return common_path('opensearch/people'); - } - case 'doc': - return common_path('doc/'.$args['title']); + static $sizenames = array(AVATAR_PROFILE_SIZE => 'profile', + AVATAR_STREAM_SIZE => 'stream', + AVATAR_MINI_SIZE => 'mini'); + return theme_path('default-avatar-'.$sizenames[$size].'.png'); +} + +function common_local_url($action, $args=null, $fragment=null) { + $url = null; + if (common_config('site','fancy')) { + $url = common_fancy_url($action, $args); + } else { + $url = common_simple_url($action, $args); + } + if (!is_null($fragment)) { + $url .= '#'.$fragment; + } + return $url; +} + +function common_fancy_url($action, $args=null) { + switch (strtolower($action)) { + case 'public': + if ($args && isset($args['page'])) { + return common_path('?page=' . $args['page']); + } else { + return common_path(''); + } + case 'featured': + if ($args && isset($args['page'])) { + return common_path('featured?page=' . $args['page']); + } else { + return common_path('featured'); + } + case 'favorited': + if ($args && isset($args['page'])) { + return common_path('favorited?page=' . $args['page']); + } else { + return common_path('favorited'); + } + case 'publicrss': + return common_path('rss'); + case 'publicatom': + return common_path("api/statuses/public_timeline.atom"); + case 'publicxrds': + return common_path('xrds'); + case 'featuredrss': + return common_path('featuredrss'); + case 'favoritedrss': + return common_path('favoritedrss'); + case 'opensearch': + if ($args && $args['type']) { + return common_path('opensearch/'.$args['type']); + } else { + return common_path('opensearch/people'); + } + case 'doc': + return common_path('doc/'.$args['title']); case 'block': - case 'login': - case 'logout': - case 'subscribe': - case 'unsubscribe': - case 'invite': - return common_path('main/'.$action); - case 'tagother': - return common_path('main/tagother?id='.$args['id']); - case 'register': - if ($args && $args['code']) { - return common_path('main/register/'.$args['code']); - } else { - return common_path('main/register'); - } - case 'remotesubscribe': - if ($args && $args['nickname']) { - return common_path('main/remote?nickname=' . $args['nickname']); - } else { - return common_path('main/remote'); - } - case 'nudge': - return common_path($args['nickname'].'/nudge'); - case 'openidlogin': - return common_path('main/openid'); - case 'profilesettings': - return common_path('settings/profile'); - case 'emailsettings': - return common_path('settings/email'); - case 'openidsettings': - return common_path('settings/openid'); - case 'smssettings': - return common_path('settings/sms'); - case 'twittersettings': - return common_path('settings/twitter'); - case 'othersettings': - return common_path('settings/other'); + case 'login': + case 'logout': + case 'subscribe': + case 'unsubscribe': + case 'invite': + return common_path('main/'.$action); + case 'tagother': + return common_path('main/tagother?id='.$args['id']); + case 'register': + if ($args && $args['code']) { + return common_path('main/register/'.$args['code']); + } else { + return common_path('main/register'); + } + case 'remotesubscribe': + if ($args && $args['nickname']) { + return common_path('main/remote?nickname=' . $args['nickname']); + } else { + return common_path('main/remote'); + } + case 'nudge': + return common_path($args['nickname'].'/nudge'); + case 'openidlogin': + return common_path('main/openid'); + case 'profilesettings': + return common_path('settings/profile'); + case 'emailsettings': + return common_path('settings/email'); + case 'openidsettings': + return common_path('settings/openid'); + case 'smssettings': + return common_path('settings/sms'); + case 'twittersettings': + return common_path('settings/twitter'); + case 'othersettings': + return common_path('settings/other'); case 'deleteprofile': return common_path('settings/delete'); - case 'newnotice': - if ($args && $args['replyto']) { - return common_path('notice/new?replyto='.$args['replyto']); - } else { - return common_path('notice/new'); - } - case 'shownotice': - return common_path('notice/'.$args['notice']); - case 'deletenotice': - if ($args && $args['notice']) { - return common_path('notice/delete/'.$args['notice']); - } else { - return common_path('notice/delete'); - } - case 'microsummary': - case 'xrds': - case 'foaf': - return common_path($args['nickname'].'/'.$action); - case 'all': - case 'replies': - case 'inbox': - case 'outbox': - if ($args && isset($args['page'])) { - return common_path($args['nickname'].'/'.$action.'?page=' . $args['page']); - } else { - return common_path($args['nickname'].'/'.$action); - } - case 'subscriptions': - case 'subscribers': - $nickname = $args['nickname']; - unset($args['nickname']); - if (isset($args['tag'])) { - $tag = $args['tag']; - unset($args['tag']); - } - $params = http_build_query($args); - if ($params) { - return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '') . '?' . $params); - } else { - return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '')); - } - case 'allrss': - return common_path($args['nickname'].'/all/rss'); - case 'repliesrss': - return common_path($args['nickname'].'/replies/rss'); - case 'userrss': + case 'newnotice': + if ($args && $args['replyto']) { + return common_path('notice/new?replyto='.$args['replyto']); + } else { + return common_path('notice/new'); + } + case 'shownotice': + return common_path('notice/'.$args['notice']); + case 'deletenotice': + if ($args && $args['notice']) { + return common_path('notice/delete/'.$args['notice']); + } else { + return common_path('notice/delete'); + } + case 'microsummary': + case 'xrds': + case 'foaf': + return common_path($args['nickname'].'/'.$action); + case 'all': + case 'replies': + case 'inbox': + case 'outbox': + if ($args && isset($args['page'])) { + return common_path($args['nickname'].'/'.$action.'?page=' . $args['page']); + } else { + return common_path($args['nickname'].'/'.$action); + } + case 'subscriptions': + case 'subscribers': + $nickname = $args['nickname']; + unset($args['nickname']); + if (isset($args['tag'])) { + $tag = $args['tag']; + unset($args['tag']); + } + $params = http_build_query($args); + if ($params) { + return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '') . '?' . $params); + } else { + return common_path($nickname.'/'.$action . (($tag) ? '/' . $tag : '')); + } + case 'allrss': + return common_path($args['nickname'].'/all/rss'); + case 'repliesrss': + return common_path($args['nickname'].'/replies/rss'); + case 'userrss': if (isset($args['limit'])) - return common_path($args['nickname'].'/rss?limit=' . $args['limit']); - return common_path($args['nickname'].'/rss'); - case 'showstream': - if ($args && isset($args['page'])) { - return common_path($args['nickname'].'?page=' . $args['page']); - } else { - return common_path($args['nickname']); - } - - case 'usertimeline': - return common_path("api/statuses/user_timeline/".$args['nickname'].".atom"); - case 'confirmaddress': - return common_path('main/confirmaddress/'.$args['code']); - case 'userbyid': - return common_path('user/'.$args['id']); - case 'recoverpassword': - $path = 'main/recoverpassword'; - if ($args['code']) { - $path .= '/' . $args['code']; - } - return common_path($path); - case 'imsettings': - return common_path('settings/im'); - case 'peoplesearch': - return common_path('search/people' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'noticesearch': - return common_path('search/notice' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'noticesearchrss': - return common_path('search/notice/rss' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'avatarbynickname': - return common_path($args['nickname'].'/avatar/'.$args['size']); - case 'tag': - if (isset($args['tag']) && $args['tag']) { - $path = 'tag/' . $args['tag']; - unset($args['tag']); - } else { - $path = 'tags'; - } - return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); - case 'peopletag': - $path = 'peopletag/' . $args['tag']; - unset($args['tag']); - return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); - case 'tags': - return common_path('tags' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'favor': - return common_path('main/favor'); - case 'disfavor': - return common_path('main/disfavor'); - case 'showfavorites': - if ($args && isset($args['page'])) { - return common_path($args['nickname'].'/favorites?page=' . $args['page']); - } else { - return common_path($args['nickname'].'/favorites'); - } - case 'favoritesrss': - return common_path($args['nickname'].'/favorites/rss'); - case 'showmessage': - return common_path('message/' . $args['message']); - case 'newmessage': - return common_path('message/new' . (($args) ? ('?' . http_build_query($args)) : '')); - case 'api': - # XXX: do fancy URLs for all the API methods - switch (strtolower($args['apiaction'])) { - case 'statuses': - switch (strtolower($args['method'])) { - case 'user_timeline.rss': - return common_path('api/statuses/user_timeline/'.$args['argument'].'.rss'); - case 'user_timeline.atom': - return common_path('api/statuses/user_timeline/'.$args['argument'].'.atom'); - case 'user_timeline.json': - return common_path('api/statuses/user_timeline/'.$args['argument'].'.json'); - case 'user_timeline.xml': - return common_path('api/statuses/user_timeline/'.$args['argument'].'.xml'); - default: return common_simple_url($action, $args); - } - default: return common_simple_url($action, $args); - } - case 'sup': - if ($args && isset($args['seconds'])) { - return common_path('main/sup?seconds='.$args['seconds']); - } else { - return common_path('main/sup'); - } - default: - return common_simple_url($action, $args); - } -} - -function common_simple_url($action, $args=NULL) { - global $config; - /* XXX: pretty URLs */ - $extra = ''; - if ($args) { - foreach ($args as $key => $value) { - $extra .= "&${key}=${value}"; - } - } - return common_path("index.php?action=${action}${extra}"); + return common_path($args['nickname'].'/rss?limit=' . $args['limit']); + return common_path($args['nickname'].'/rss'); + case 'showstream': + if ($args && isset($args['page'])) { + return common_path($args['nickname'].'?page=' . $args['page']); + } else { + return common_path($args['nickname']); + } + + case 'usertimeline': + return common_path("api/statuses/user_timeline/".$args['nickname'].".atom"); + case 'confirmaddress': + return common_path('main/confirmaddress/'.$args['code']); + case 'userbyid': + return common_path('user/'.$args['id']); + case 'recoverpassword': + $path = 'main/recoverpassword'; + if ($args['code']) { + $path .= '/' . $args['code']; + } + return common_path($path); + case 'imsettings': + return common_path('settings/im'); + case 'peoplesearch': + return common_path('search/people' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'noticesearch': + return common_path('search/notice' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'noticesearchrss': + return common_path('search/notice/rss' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'avatarbynickname': + return common_path($args['nickname'].'/avatar/'.$args['size']); + case 'tag': + if (isset($args['tag']) && $args['tag']) { + $path = 'tag/' . $args['tag']; + unset($args['tag']); + } else { + $path = 'tags'; + } + return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); + case 'peopletag': + $path = 'peopletag/' . $args['tag']; + unset($args['tag']); + return common_path($path . (($args) ? ('?' . http_build_query($args)) : '')); + case 'tags': + return common_path('tags' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'favor': + return common_path('main/favor'); + case 'disfavor': + return common_path('main/disfavor'); + case 'showfavorites': + if ($args && isset($args['page'])) { + return common_path($args['nickname'].'/favorites?page=' . $args['page']); + } else { + return common_path($args['nickname'].'/favorites'); + } + case 'favoritesrss': + return common_path($args['nickname'].'/favorites/rss'); + case 'showmessage': + return common_path('message/' . $args['message']); + case 'newmessage': + return common_path('message/new' . (($args) ? ('?' . http_build_query($args)) : '')); + case 'api': + // XXX: do fancy URLs for all the API methods + switch (strtolower($args['apiaction'])) { + case 'statuses': + switch (strtolower($args['method'])) { + case 'user_timeline.rss': + return common_path('api/statuses/user_timeline/'.$args['argument'].'.rss'); + case 'user_timeline.atom': + return common_path('api/statuses/user_timeline/'.$args['argument'].'.atom'); + case 'user_timeline.json': + return common_path('api/statuses/user_timeline/'.$args['argument'].'.json'); + case 'user_timeline.xml': + return common_path('api/statuses/user_timeline/'.$args['argument'].'.xml'); + default: return common_simple_url($action, $args); + } + default: return common_simple_url($action, $args); + } + case 'sup': + if ($args && isset($args['seconds'])) { + return common_path('main/sup?seconds='.$args['seconds']); + } else { + return common_path('main/sup'); + } + default: + return common_simple_url($action, $args); + } +} + +function common_simple_url($action, $args=null) { + global $config; + /* XXX: pretty URLs */ + $extra = ''; + if ($args) { + foreach ($args as $key => $value) { + $extra .= "&${key}=${value}"; + } + } + return common_path("index.php?action=${action}${extra}"); } function common_path($relative) { - global $config; - $pathpart = ($config['site']['path']) ? $config['site']['path']."/" : ''; - return "http://".$config['site']['server'].'/'.$pathpart.$relative; + global $config; + $pathpart = ($config['site']['path']) ? $config['site']['path']."/" : ''; + return "http://".$config['site']['server'].'/'.$pathpart.$relative; } function common_date_string($dt) { - // XXX: do some sexy date formatting - // return date(DATE_RFC822, $dt); - $t = strtotime($dt); - $now = time(); - $diff = $now - $t; - - if ($now < $t) { # that shouldn't happen! - return common_exact_date($dt); - } else if ($diff < 60) { - return _('a few seconds ago'); - } else if ($diff < 92) { - return _('about a minute ago'); - } else if ($diff < 3300) { - return sprintf(_('about %d minutes ago'), round($diff/60)); - } else if ($diff < 5400) { - return _('about an hour ago'); - } else if ($diff < 22 * 3600) { - return sprintf(_('about %d hours ago'), round($diff/3600)); - } else if ($diff < 37 * 3600) { - return _('about a day ago'); - } else if ($diff < 24 * 24 * 3600) { - return sprintf(_('about %d days ago'), round($diff/(24*3600))); - } else if ($diff < 46 * 24 * 3600) { - return _('about a month ago'); - } else if ($diff < 330 * 24 * 3600) { - return sprintf(_('about %d months ago'), round($diff/(30*24*3600))); - } else if ($diff < 480 * 24 * 3600) { - return _('about a year ago'); - } else { - return common_exact_date($dt); - } + // XXX: do some sexy date formatting + // return date(DATE_RFC822, $dt); + $t = strtotime($dt); + $now = time(); + $diff = $now - $t; + + if ($now < $t) { // that shouldn't happen! + return common_exact_date($dt); + } else if ($diff < 60) { + return _('a few seconds ago'); + } else if ($diff < 92) { + return _('about a minute ago'); + } else if ($diff < 3300) { + return sprintf(_('about %d minutes ago'), round($diff/60)); + } else if ($diff < 5400) { + return _('about an hour ago'); + } else if ($diff < 22 * 3600) { + return sprintf(_('about %d hours ago'), round($diff/3600)); + } else if ($diff < 37 * 3600) { + return _('about a day ago'); + } else if ($diff < 24 * 24 * 3600) { + return sprintf(_('about %d days ago'), round($diff/(24*3600))); + } else if ($diff < 46 * 24 * 3600) { + return _('about a month ago'); + } else if ($diff < 330 * 24 * 3600) { + return sprintf(_('about %d months ago'), round($diff/(30*24*3600))); + } else if ($diff < 480 * 24 * 3600) { + return _('about a year ago'); + } else { + return common_exact_date($dt); + } } function common_exact_date($dt) { @@ -1317,885 +1317,885 @@ function common_exact_date($dt) { $_siteTz = new DateTimeZone(common_timezone()); } - $dateStr = date('d F Y H:i:s', strtotime($dt)); - $d = new DateTime($dateStr, $_utc); - $d->setTimezone($_siteTz); - return $d->format(DATE_RFC850); + $dateStr = date('d F Y H:i:s', strtotime($dt)); + $d = new DateTime($dateStr, $_utc); + $d->setTimezone($_siteTz); + return $d->format(DATE_RFC850); } function common_date_w3dtf($dt) { - $dateStr = date('d F Y H:i:s', strtotime($dt)); - $d = new DateTime($dateStr, new DateTimeZone('UTC')); - $d->setTimezone(new DateTimeZone(common_timezone())); - return $d->format(DATE_W3C); + $dateStr = date('d F Y H:i:s', strtotime($dt)); + $d = new DateTime($dateStr, new DateTimeZone('UTC')); + $d->setTimezone(new DateTimeZone(common_timezone())); + return $d->format(DATE_W3C); } function common_date_rfc2822($dt) { - $dateStr = date('d F Y H:i:s', strtotime($dt)); - $d = new DateTime($dateStr, new DateTimeZone('UTC')); - $d->setTimezone(new DateTimeZone(common_timezone())); - return $d->format('r'); + $dateStr = date('d F Y H:i:s', strtotime($dt)); + $d = new DateTime($dateStr, new DateTimeZone('UTC')); + $d->setTimezone(new DateTimeZone(common_timezone())); + return $d->format('r'); } function common_date_iso8601($dt) { - $dateStr = date('d F Y H:i:s', strtotime($dt)); - $d = new DateTime($dateStr, new DateTimeZone('UTC')); - $d->setTimezone(new DateTimeZone(common_timezone())); - return $d->format('c'); + $dateStr = date('d F Y H:i:s', strtotime($dt)); + $d = new DateTime($dateStr, new DateTimeZone('UTC')); + $d->setTimezone(new DateTimeZone(common_timezone())); + return $d->format('c'); } function common_sql_now() { - return strftime('%Y-%m-%d %H:%M:%S', time()); + return strftime('%Y-%m-%d %H:%M:%S', time()); } function common_redirect($url, $code=307) { - static $status = array(301 => "Moved Permanently", - 302 => "Found", - 303 => "See Other", - 307 => "Temporary Redirect"); - header("Status: ${code} $status[$code]"); - header("Location: $url"); - - common_start_xml('a', - '-//W3C//DTD XHTML 1.0 Strict//EN', - 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'); - common_element('a', array('href' => $url), $url); - common_end_xml(); + static $status = array(301 => "Moved Permanently", + 302 => "Found", + 303 => "See Other", + 307 => "Temporary Redirect"); + header("Status: ${code} $status[$code]"); + header("Location: $url"); + + common_start_xml('a', + '-//W3C//DTD XHTML 1.0 Strict//EN', + 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'); + common_element('a', array('href' => $url), $url); + common_end_xml(); exit; } function common_save_replies($notice) { - # Alternative reply format - $tname = false; - if (preg_match('/^T ([A-Z0-9]{1,64}) /', $notice->content, $match)) { - $tname = $match[1]; - } - # extract all @messages - $cnt = preg_match_all('/(?:^|\s)@([a-z0-9]{1,64})/', $notice->content, $match); - - $names = array(); - - if ($cnt || $tname) { - # XXX: is there another way to make an array copy? - $names = ($tname) ? array_unique(array_merge(array(strtolower($tname)), $match[1])) : array_unique($match[1]); - } - - $sender = Profile::staticGet($notice->profile_id); - - $replied = array(); - - # store replied only for first @ (what user/notice what the reply directed, - # we assume first @ is it) - - for ($i=0; $icreated); - if (!$recipient) { - continue; - } - if ($i == 0 && ($recipient->id != $sender->id) && !$notice->reply_to) { # Don't save reply to self - $reply_for = $recipient; - $recipient_notice = $reply_for->getCurrentNotice(); - if ($recipient_notice) { - $orig = clone($notice); - $notice->reply_to = $recipient_notice->id; - $notice->update($orig); - } - } - # Don't save replies from blocked profile to local user + // Alternative reply format + $tname = false; + if (preg_match('/^T ([A-Z0-9]{1,64}) /', $notice->content, $match)) { + $tname = $match[1]; + } + // extract all @messages + $cnt = preg_match_all('/(?:^|\s)@([a-z0-9]{1,64})/', $notice->content, $match); + + $names = array(); + + if ($cnt || $tname) { + // XXX: is there another way to make an array copy? + $names = ($tname) ? array_unique(array_merge(array(strtolower($tname)), $match[1])) : array_unique($match[1]); + } + + $sender = Profile::staticGet($notice->profile_id); + + $replied = array(); + + // store replied only for first @ (what user/notice what the reply directed, + // we assume first @ is it) + + for ($i=0; $icreated); + if (!$recipient) { + continue; + } + if ($i == 0 && ($recipient->id != $sender->id) && !$notice->reply_to) { // Don't save reply to self + $reply_for = $recipient; + $recipient_notice = $reply_for->getCurrentNotice(); + if ($recipient_notice) { + $orig = clone($notice); + $notice->reply_to = $recipient_notice->id; + $notice->update($orig); + } + } + // Don't save replies from blocked profile to local user $recipient_user = User::staticGet('id', $recipient->id); if ($recipient_user && $recipient_user->hasBlocked($sender)) { continue; } - $reply = new Reply(); - $reply->notice_id = $notice->id; - $reply->profile_id = $recipient->id; - $id = $reply->insert(); - if (!$id) { - $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); - common_log(LOG_ERR, 'DB error inserting reply: ' . $last_error->message); - common_server_error(sprintf(_('DB error inserting reply: %s'), $last_error->message)); - return; - } else { - $replied[$recipient->id] = 1; - } - } - - # Hash format replies, too - $cnt = preg_match_all('/(?:^|\s)@#([a-z0-9]{1,64})/', $notice->content, $match); - if ($cnt) { - foreach ($match[1] as $tag) { - $tagged = Profile_tag::getTagged($sender->id, $tag); - foreach ($tagged as $t) { - if (!$replied[$t->id]) { - # Don't save replies from blocked profile to local user + $reply = new Reply(); + $reply->notice_id = $notice->id; + $reply->profile_id = $recipient->id; + $id = $reply->insert(); + if (!$id) { + $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); + common_log(LOG_ERR, 'DB error inserting reply: ' . $last_error->message); + common_server_error(sprintf(_('DB error inserting reply: %s'), $last_error->message)); + return; + } else { + $replied[$recipient->id] = 1; + } + } + + // Hash format replies, too + $cnt = preg_match_all('/(?:^|\s)@#([a-z0-9]{1,64})/', $notice->content, $match); + if ($cnt) { + foreach ($match[1] as $tag) { + $tagged = Profile_tag::getTagged($sender->id, $tag); + foreach ($tagged as $t) { + if (!$replied[$t->id]) { + // Don't save replies from blocked profile to local user $t_user = User::staticGet('id', $t->id); if ($t_user && $t_user->hasBlocked($sender)) { continue; } - $reply = new Reply(); - $reply->notice_id = $notice->id; - $reply->profile_id = $t->id; - $id = $reply->insert(); - if (!$id) { - common_log_db_error($reply, 'INSERT', __FILE__); - return; - } - } - } - } - } + $reply = new Reply(); + $reply->notice_id = $notice->id; + $reply->profile_id = $t->id; + $id = $reply->insert(); + if (!$id) { + common_log_db_error($reply, 'INSERT', __FILE__); + return; + } + } + } + } + } } function common_broadcast_notice($notice, $remote=false) { - // Check to see if notice should go to Twitter - $flink = Foreign_link::getByUserID($notice->profile_id, 1); // 1 == Twitter - if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) { + // Check to see if notice should go to Twitter + $flink = Foreign_link::getByUserID($notice->profile_id, 1); // 1 == Twitter + if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) { - // If it's not a Twitter-style reply, or if the user WANTS to send replies... + // If it's not a Twitter-style reply, or if the user WANTS to send replies... - if (!preg_match('/^@[a-zA-Z0-9_]{1,15}\b/u', $notice->content) || - (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) { + if (!preg_match('/^@[a-zA-Z0-9_]{1,15}\b/u', $notice->content) || + (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) { - $result = common_twitter_broadcast($notice, $flink); + $result = common_twitter_broadcast($notice, $flink); - if (!$result) { - common_debug('Unable to send notice: ' . $notice->id . ' to Twitter.', __FILE__); - } - } - } + if (!$result) { + common_debug('Unable to send notice: ' . $notice->id . ' to Twitter.', __FILE__); + } + } + } - if (common_config('queue', 'enabled')) { - # Do it later! - return common_enqueue_notice($notice); - } else { - return common_real_broadcast($notice, $remote); - } + if (common_config('queue', 'enabled')) { + // Do it later! + return common_enqueue_notice($notice); + } else { + return common_real_broadcast($notice, $remote); + } } function common_twitter_broadcast($notice, $flink) { - global $config; - $success = true; - $fuser = $flink->getForeignUser(); - $twitter_user = $fuser->nickname; - $twitter_password = $flink->credentials; - $uri = 'http://www.twitter.com/statuses/update.json'; - - // XXX: Hack to get around PHP cURL's use of @ being a a meta character - $statustxt = preg_replace('/^@/', ' @', $notice->content); - - $options = array( - CURLOPT_USERPWD => "$twitter_user:$twitter_password", - CURLOPT_POST => true, - CURLOPT_POSTFIELDS => array( - 'status' => $statustxt, - 'source' => $config['integration']['source'] - ), - CURLOPT_RETURNTRANSFER => true, - CURLOPT_FAILONERROR => true, - CURLOPT_HEADER => false, - CURLOPT_FOLLOWLOCATION => true, - CURLOPT_USERAGENT => "Laconica", - CURLOPT_CONNECTTIMEOUT => 120, // XXX: Scary!!!! How long should this be? - CURLOPT_TIMEOUT => 120 - ); - - $ch = curl_init($uri); + global $config; + $success = true; + $fuser = $flink->getForeignUser(); + $twitter_user = $fuser->nickname; + $twitter_password = $flink->credentials; + $uri = 'http://www.twitter.com/statuses/update.json'; + + // XXX: Hack to get around PHP cURL's use of @ being a a meta character + $statustxt = preg_replace('/^@/', ' @', $notice->content); + + $options = array( + CURLOPT_USERPWD => "$twitter_user:$twitter_password", + CURLOPT_POST => true, + CURLOPT_POSTFIELDS => array( + 'status' => $statustxt, + 'source' => $config['integration']['source'] + ), + CURLOPT_RETURNTRANSFER => true, + CURLOPT_FAILONERROR => true, + CURLOPT_HEADER => false, + CURLOPT_FOLLOWLOCATION => true, + CURLOPT_USERAGENT => "Laconica", + CURLOPT_CONNECTTIMEOUT => 120, // XXX: Scary!!!! How long should this be? + CURLOPT_TIMEOUT => 120 + ); + + $ch = curl_init($uri); curl_setopt_array($ch, $options); $data = curl_exec($ch); $errmsg = curl_error($ch); - if ($errmsg) { - common_debug("cURL error: $errmsg - trying to send notice for $twitter_user.", - __FILE__); - $success = false; - } + if ($errmsg) { + common_debug("cURL error: $errmsg - trying to send notice for $twitter_user.", + __FILE__); + $success = false; + } - curl_close($ch); + curl_close($ch); - if (!$data) { - common_debug("No data returned by Twitter's API trying to send update for $twitter_user", - __FILE__); - $success = false; - } + if (!$data) { + common_debug("No data returned by Twitter's API trying to send update for $twitter_user", + __FILE__); + $success = false; + } - // Twitter should return a status - $status = json_decode($data); + // Twitter should return a status + $status = json_decode($data); - if (!$status->id) { - common_debug("Unexpected data returned by Twitter API trying to send update for $twitter_user", - __FILE__); - $success = false; - } + if (!$status->id) { + common_debug("Unexpected data returned by Twitter API trying to send update for $twitter_user", + __FILE__); + $success = false; + } - return $success; + return $success; } -# Stick the notice on the queue +// Stick the notice on the queue function common_enqueue_notice($notice) { - foreach (array('jabber', 'omb', 'sms', 'public') as $transport) { - $qi = new Queue_item(); - $qi->notice_id = $notice->id; - $qi->transport = $transport; - $qi->created = $notice->created; + foreach (array('jabber', 'omb', 'sms', 'public') as $transport) { + $qi = new Queue_item(); + $qi->notice_id = $notice->id; + $qi->transport = $transport; + $qi->created = $notice->created; $result = $qi->insert(); - if (!$result) { - $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); - common_log(LOG_ERR, 'DB error inserting queue item: ' . $last_error->message); - return false; - } - common_log(LOG_DEBUG, 'complete queueing notice ID = ' . $notice->id . ' for ' . $transport); - } - return $result; + if (!$result) { + $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); + common_log(LOG_ERR, 'DB error inserting queue item: ' . $last_error->message); + return false; + } + common_log(LOG_DEBUG, 'complete queueing notice ID = ' . $notice->id . ' for ' . $transport); + } + return $result; } function common_dequeue_notice($notice) { - $qi = Queue_item::staticGet($notice->id); - if ($qi) { - $result = $qi->delete(); - if (!$result) { - $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); - common_log(LOG_ERR, 'DB error deleting queue item: ' . $last_error->message); - return false; - } - common_log(LOG_DEBUG, 'complete dequeueing notice ID = ' . $notice->id); - return $result; - } else { + $qi = Queue_item::staticGet($notice->id); + if ($qi) { + $result = $qi->delete(); + if (!$result) { + $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); + common_log(LOG_ERR, 'DB error deleting queue item: ' . $last_error->message); return false; } + common_log(LOG_DEBUG, 'complete dequeueing notice ID = ' . $notice->id); + return $result; + } else { + return false; + } } function common_real_broadcast($notice, $remote=false) { - $success = true; - if (!$remote) { - # Make sure we have the OMB stuff - require_once(INSTALLDIR.'/lib/omb.php'); - $success = omb_broadcast_remote_subscribers($notice); - if (!$success) { - common_log(LOG_ERR, 'Error in OMB broadcast for notice ' . $notice->id); - } - } - if ($success) { - require_once(INSTALLDIR.'/lib/jabber.php'); - $success = jabber_broadcast_notice($notice); - if (!$success) { - common_log(LOG_ERR, 'Error in jabber broadcast for notice ' . $notice->id); - } - } - if ($success) { - require_once(INSTALLDIR.'/lib/mail.php'); - $success = mail_broadcast_notice_sms($notice); - if (!$success) { - common_log(LOG_ERR, 'Error in sms broadcast for notice ' . $notice->id); - } - } - if ($success) { - $success = jabber_public_notice($notice); - if (!$success) { - common_log(LOG_ERR, 'Error in public broadcast for notice ' . $notice->id); - } - } - // XXX: broadcast notices to other IM - return $success; + $success = true; + if (!$remote) { + // Make sure we have the OMB stuff + require_once(INSTALLDIR.'/lib/omb.php'); + $success = omb_broadcast_remote_subscribers($notice); + if (!$success) { + common_log(LOG_ERR, 'Error in OMB broadcast for notice ' . $notice->id); + } + } + if ($success) { + require_once(INSTALLDIR.'/lib/jabber.php'); + $success = jabber_broadcast_notice($notice); + if (!$success) { + common_log(LOG_ERR, 'Error in jabber broadcast for notice ' . $notice->id); + } + } + if ($success) { + require_once(INSTALLDIR.'/lib/mail.php'); + $success = mail_broadcast_notice_sms($notice); + if (!$success) { + common_log(LOG_ERR, 'Error in sms broadcast for notice ' . $notice->id); + } + } + if ($success) { + $success = jabber_public_notice($notice); + if (!$success) { + common_log(LOG_ERR, 'Error in public broadcast for notice ' . $notice->id); + } + } + // XXX: broadcast notices to other IM + return $success; } function common_broadcast_profile($profile) { - // XXX: optionally use a queue system like http://code.google.com/p/microapps/wiki/NQDQ - require_once(INSTALLDIR.'/lib/omb.php'); - omb_broadcast_profile($profile); - // XXX: Other broadcasts...? - return true; + // XXX: optionally use a queue system like http://code.google.com/p/microapps/wiki/NQDQ + require_once(INSTALLDIR.'/lib/omb.php'); + omb_broadcast_profile($profile); + // XXX: Other broadcasts...? + return true; } function common_profile_url($nickname) { - return common_local_url('showstream', array('nickname' => $nickname)); + return common_local_url('showstream', array('nickname' => $nickname)); } -# Don't call if nobody's logged in +// Don't call if nobody's logged in -function common_notice_form($action=NULL, $content=NULL) { - $user = common_current_user(); - assert(!is_null($user)); - common_element_start('form', array('id' => 'status_form', - 'method' => 'post', - 'action' => common_local_url('newnotice'))); - common_element_start('p'); - common_element('label', array('for' => 'status_textarea', - 'id' => 'status_label'), - sprintf(_('What\'s up, %s?'), $user->nickname)); +function common_notice_form($action=null, $content=null) { + $user = common_current_user(); + assert(!is_null($user)); + common_element_start('form', array('id' => 'status_form', + 'method' => 'post', + 'action' => common_local_url('newnotice'))); + common_element_start('p'); + common_element('label', array('for' => 'status_textarea', + 'id' => 'status_label'), + sprintf(_('What\'s up, %s?'), $user->nickname)); common_element('span', array('id' => 'counter', 'class' => 'counter'), '140'); - common_element('textarea', array('id' => 'status_textarea', - 'cols' => 60, - 'rows' => 3, - 'name' => 'status_textarea'), - ($content) ? $content : ''); - common_hidden('token', common_session_token()); - if ($action) { - common_hidden('returnto', $action); - } - # set by JavaScript - common_hidden('inreplyto', 'false'); - common_element('input', array('id' => 'status_submit', - 'name' => 'status_submit', - 'type' => 'submit', - 'value' => _('Send'))); - common_element_end('p'); - common_element_end('form'); -} - -# Should make up a reasonable root URL + common_element('textarea', array('id' => 'status_textarea', + 'cols' => 60, + 'rows' => 3, + 'name' => 'status_textarea'), + ($content) ? $content : ''); + common_hidden('token', common_session_token()); + if ($action) { + common_hidden('returnto', $action); + } + // set by JavaScript + common_hidden('inreplyto', 'false'); + common_element('input', array('id' => 'status_submit', + 'name' => 'status_submit', + 'type' => 'submit', + 'value' => _('Send'))); + common_element_end('p'); + common_element_end('form'); +} + +// Should make up a reasonable root URL function common_root_url() { - return common_path(''); + return common_path(''); } -# returns $bytes bytes of random data as a hexadecimal string -# "good" here is a goal and not a guarantee +// returns $bytes bytes of random data as a hexadecimal string +// "good" here is a goal and not a guarantee function common_good_rand($bytes) { - # XXX: use random.org...? - if (file_exists('/dev/urandom')) { - return common_urandom($bytes); - } else { # FIXME: this is probably not good enough - return common_mtrand($bytes); - } + // XXX: use random.org...? + if (file_exists('/dev/urandom')) { + return common_urandom($bytes); + } else { // FIXME: this is probably not good enough + return common_mtrand($bytes); + } } function common_urandom($bytes) { - $h = fopen('/dev/urandom', 'rb'); - # should not block - $src = fread($h, $bytes); - fclose($h); - $enc = ''; - for ($i = 0; $i < $bytes; $i++) { - $enc .= sprintf("%02x", (ord($src[$i]))); - } - return $enc; + $h = fopen('/dev/urandom', 'rb'); + // should not block + $src = fread($h, $bytes); + fclose($h); + $enc = ''; + for ($i = 0; $i < $bytes; $i++) { + $enc .= sprintf("%02x", (ord($src[$i]))); + } + return $enc; } function common_mtrand($bytes) { - $enc = ''; - for ($i = 0; $i < $bytes; $i++) { - $enc .= sprintf("%02x", mt_rand(0, 255)); - } - return $enc; + $enc = ''; + for ($i = 0; $i < $bytes; $i++) { + $enc .= sprintf("%02x", mt_rand(0, 255)); + } + return $enc; } function common_set_returnto($url) { - common_ensure_session(); - $_SESSION['returnto'] = $url; + common_ensure_session(); + $_SESSION['returnto'] = $url; } function common_get_returnto() { - common_ensure_session(); - return $_SESSION['returnto']; + common_ensure_session(); + return $_SESSION['returnto']; } function common_timestamp() { - return date('YmdHis'); + return date('YmdHis'); } function common_ensure_syslog() { - static $initialized = false; - if (!$initialized) { - global $config; - openlog($config['syslog']['appname'], 0, LOG_USER); - $initialized = true; - } -} - -function common_log($priority, $msg, $filename=NULL) { - $logfile = common_config('site', 'logfile'); - if ($logfile) { - $log = fopen($logfile, "a"); - if ($log) { - static $syslog_priorities = array('LOG_EMERG', 'LOG_ALERT', 'LOG_CRIT', 'LOG_ERR', - 'LOG_WARNING', 'LOG_NOTICE', 'LOG_INFO', 'LOG_DEBUG'); - $output = date('Y-m-d H:i:s') . ' ' . $syslog_priorities[$priority] . ': ' . $msg . "\n"; - fwrite($log, $output); - fclose($log); - } - } else { - common_ensure_syslog(); - syslog($priority, $msg); - } -} - -function common_debug($msg, $filename=NULL) { - if ($filename) { - common_log(LOG_DEBUG, basename($filename).' - '.$msg); - } else { - common_log(LOG_DEBUG, $msg); - } -} - -function common_log_db_error(&$object, $verb, $filename=NULL) { - $objstr = common_log_objstring($object); - $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); - common_log(LOG_ERR, $last_error->message . '(' . $verb . ' on ' . $objstr . ')', $filename); + static $initialized = false; + if (!$initialized) { + global $config; + openlog($config['syslog']['appname'], 0, LOG_USER); + $initialized = true; + } +} + +function common_log($priority, $msg, $filename=null) { + $logfile = common_config('site', 'logfile'); + if ($logfile) { + $log = fopen($logfile, "a"); + if ($log) { + static $syslog_priorities = array('LOG_EMERG', 'LOG_ALERT', 'LOG_CRIT', 'LOG_ERR', + 'LOG_WARNING', 'LOG_NOTICE', 'LOG_INFO', 'LOG_DEBUG'); + $output = date('Y-m-d H:i:s') . ' ' . $syslog_priorities[$priority] . ': ' . $msg . "\n"; + fwrite($log, $output); + fclose($log); + } + } else { + common_ensure_syslog(); + syslog($priority, $msg); + } +} + +function common_debug($msg, $filename=null) { + if ($filename) { + common_log(LOG_DEBUG, basename($filename).' - '.$msg); + } else { + common_log(LOG_DEBUG, $msg); + } +} + +function common_log_db_error(&$object, $verb, $filename=null) { + $objstr = common_log_objstring($object); + $last_error = &PEAR::getStaticProperty('DB_DataObject','lastError'); + common_log(LOG_ERR, $last_error->message . '(' . $verb . ' on ' . $objstr . ')', $filename); } function common_log_objstring(&$object) { - if (is_null($object)) { - return "NULL"; - } - $arr = $object->toArray(); - $fields = array(); - foreach ($arr as $k => $v) { - $fields[] = "$k='$v'"; - } - $objstring = $object->tableName() . '[' . implode(',', $fields) . ']'; - return $objstring; + if (is_null($object)) { + return "null"; + } + $arr = $object->toArray(); + $fields = array(); + foreach ($arr as $k => $v) { + $fields[] = "$k='$v'"; + } + $objstring = $object->tableName() . '[' . implode(',', $fields) . ']'; + return $objstring; } function common_valid_http_url($url) { - return Validate::uri($url, array('allowed_schemes' => array('http', 'https'))); + return Validate::uri($url, array('allowed_schemes' => array('http', 'https'))); } function common_valid_tag($tag) { - if (preg_match('/^tag:(.*?),(\d{4}(-\d{2}(-\d{2})?)?):(.*)$/', $tag, $matches)) { - return (Validate::email($matches[1]) || - preg_match('/^([\w-\.]+)$/', $matches[1])); - } - return false; + if (preg_match('/^tag:(.*?),(\d{4}(-\d{2}(-\d{2})?)?):(.*)$/', $tag, $matches)) { + return (Validate::email($matches[1]) || + preg_match('/^([\w-\.]+)$/', $matches[1])); + } + return false; } -# Does a little before-after block for next/prev page +// Does a little before-after block for next/prev page -function common_pagination($have_before, $have_after, $page, $action, $args=NULL) { +function common_pagination($have_before, $have_after, $page, $action, $args=null) { - if ($have_before || $have_after) { - common_element_start('div', array('id' => 'pagination')); - common_element_start('ul', array('id' => 'nav_pagination')); - } + if ($have_before || $have_after) { + common_element_start('div', array('id' => 'pagination')); + common_element_start('ul', array('id' => 'nav_pagination')); + } - if ($have_before) { - $pargs = array('page' => $page-1); - $newargs = ($args) ? array_merge($args,$pargs) : $pargs; + if ($have_before) { + $pargs = array('page' => $page-1); + $newargs = ($args) ? array_merge($args,$pargs) : $pargs; - common_element_start('li', 'before'); - common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'prev'), - _('« After')); - common_element_end('li'); - } + common_element_start('li', 'before'); + common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'prev'), + _('« After')); + common_element_end('li'); + } - if ($have_after) { - $pargs = array('page' => $page+1); - $newargs = ($args) ? array_merge($args,$pargs) : $pargs; - common_element_start('li', 'after'); - common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'next'), - _('Before »')); - common_element_end('li'); - } + if ($have_after) { + $pargs = array('page' => $page+1); + $newargs = ($args) ? array_merge($args,$pargs) : $pargs; + common_element_start('li', 'after'); + common_element('a', array('href' => common_local_url($action, $newargs), 'rel' => 'next'), + _('Before »')); + common_element_end('li'); + } - if ($have_before || $have_after) { - common_element_end('ul'); - common_element_end('div'); - } + if ($have_before || $have_after) { + common_element_end('ul'); + common_element_end('div'); + } } /* Following functions are copied from MediaWiki GlobalFunctions.php * and written by Evan Prodromou. */ function common_accept_to_prefs($accept, $def = '*/*') { - # No arg means accept anything (per HTTP spec) - if(!$accept) { - return array($def => 1); - } + // No arg means accept anything (per HTTP spec) + if(!$accept) { + return array($def => 1); + } - $prefs = array(); + $prefs = array(); - $parts = explode(',', $accept); + $parts = explode(',', $accept); - foreach($parts as $part) { - # FIXME: doesn't deal with params like 'text/html; level=1' - @list($value, $qpart) = explode(';', $part); - $match = array(); - if(!isset($qpart)) { - $prefs[$value] = 1; - } elseif(preg_match('/q\s*=\s*(\d*\.\d+)/', $qpart, $match)) { - $prefs[$value] = $match[1]; - } - } + foreach($parts as $part) { + // FIXME: doesn't deal with params like 'text/html; level=1' + @list($value, $qpart) = explode(';', $part); + $match = array(); + if(!isset($qpart)) { + $prefs[$value] = 1; + } elseif(preg_match('/q\s*=\s*(\d*\.\d+)/', $qpart, $match)) { + $prefs[$value] = $match[1]; + } + } - return $prefs; + return $prefs; } function common_mime_type_match($type, $avail) { - if(array_key_exists($type, $avail)) { - return $type; - } else { - $parts = explode('/', $type); - if(array_key_exists($parts[0] . '/*', $avail)) { - return $parts[0] . '/*'; - } elseif(array_key_exists('*/*', $avail)) { - return '*/*'; - } else { - return NULL; - } - } + if(array_key_exists($type, $avail)) { + return $type; + } else { + $parts = explode('/', $type); + if(array_key_exists($parts[0] . '/*', $avail)) { + return $parts[0] . '/*'; + } elseif(array_key_exists('*/*', $avail)) { + return '*/*'; + } else { + return null; + } + } } function common_negotiate_type($cprefs, $sprefs) { - $combine = array(); - - foreach(array_keys($sprefs) as $type) { - $parts = explode('/', $type); - if($parts[1] != '*') { - $ckey = common_mime_type_match($type, $cprefs); - if($ckey) { - $combine[$type] = $sprefs[$type] * $cprefs[$ckey]; - } - } - } - - foreach(array_keys($cprefs) as $type) { - $parts = explode('/', $type); - if($parts[1] != '*' && !array_key_exists($type, $sprefs)) { - $skey = common_mime_type_match($type, $sprefs); - if($skey) { - $combine[$type] = $sprefs[$skey] * $cprefs[$type]; - } - } - } - - $bestq = 0; - $besttype = "text/html"; - - foreach(array_keys($combine) as $type) { - if($combine[$type] > $bestq) { - $besttype = $type; - $bestq = $combine[$type]; - } - } - - return $besttype; + $combine = array(); + + foreach(array_keys($sprefs) as $type) { + $parts = explode('/', $type); + if($parts[1] != '*') { + $ckey = common_mime_type_match($type, $cprefs); + if($ckey) { + $combine[$type] = $sprefs[$type] * $cprefs[$ckey]; + } + } + } + + foreach(array_keys($cprefs) as $type) { + $parts = explode('/', $type); + if($parts[1] != '*' && !array_key_exists($type, $sprefs)) { + $skey = common_mime_type_match($type, $sprefs); + if($skey) { + $combine[$type] = $sprefs[$skey] * $cprefs[$type]; + } + } + } + + $bestq = 0; + $besttype = "text/html"; + + foreach(array_keys($combine) as $type) { + if($combine[$type] > $bestq) { + $besttype = $type; + $bestq = $combine[$type]; + } + } + + return $besttype; } function common_config($main, $sub) { - global $config; - return isset($config[$main][$sub]) ? $config[$main][$sub] : false; + global $config; + return isset($config[$main][$sub]) ? $config[$main][$sub] : false; } function common_copy_args($from) { - $to = array(); - $strip = get_magic_quotes_gpc(); - foreach ($from as $k => $v) { - $to[$k] = ($strip) ? stripslashes($v) : $v; - } - return $to; + $to = array(); + $strip = get_magic_quotes_gpc(); + foreach ($from as $k => $v) { + $to[$k] = ($strip) ? stripslashes($v) : $v; + } + return $to; } // Neutralise the evil effects of magic_quotes_gpc in the current request. // This is used before handing a request off to OAuthRequest::from_request. function common_remove_magic_from_request() { - if(get_magic_quotes_gpc()) { - $_POST=array_map('stripslashes',$_POST); - $_GET=array_map('stripslashes',$_GET); - } + if(get_magic_quotes_gpc()) { + $_POST=array_map('stripslashes',$_POST); + $_GET=array_map('stripslashes',$_GET); + } } function common_user_uri(&$user) { - return common_local_url('userbyid', array('id' => $user->id)); + return common_local_url('userbyid', array('id' => $user->id)); } function common_notice_uri(&$notice) { - return common_local_url('shownotice', - array('notice' => $notice->id)); + return common_local_url('shownotice', + array('notice' => $notice->id)); } -# 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits +// 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits function common_confirmation_code($bits) { - # 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits - static $codechars = '23456789ABCDEFGHJKLMNPQRSTUVWXYZ'; - $chars = ceil($bits/5); - $code = ''; - for ($i = 0; $i < $chars; $i++) { - # XXX: convert to string and back - $num = hexdec(common_good_rand(1)); - # XXX: randomness is too precious to throw away almost - # 40% of the bits we get! - $code .= $codechars[$num%32]; - } - return $code; -} - -# convert markup to HTML + // 36 alphanums - lookalikes (0, O, 1, I) = 32 chars = 5 bits + static $codechars = '23456789ABCDEFGHJKLMNPQRSTUVWXYZ'; + $chars = ceil($bits/5); + $code = ''; + for ($i = 0; $i < $chars; $i++) { + // XXX: convert to string and back + $num = hexdec(common_good_rand(1)); + // XXX: randomness is too precious to throw away almost + // 40% of the bits we get! + $code .= $codechars[$num%32]; + } + return $code; +} + +// convert markup to HTML function common_markup_to_html($c) { - $c = preg_replace('/%%action.(\w+)%%/e', "common_local_url('\\1')", $c); - $c = preg_replace('/%%doc.(\w+)%%/e', "common_local_url('doc', array('title'=>'\\1'))", $c); - $c = preg_replace('/%%(\w+).(\w+)%%/e', 'common_config(\'\\1\', \'\\2\')', $c); - return Markdown($c); + $c = preg_replace('/%%action.(\w+)%%/e', "common_local_url('\\1')", $c); + $c = preg_replace('/%%doc.(\w+)%%/e', "common_local_url('doc', array('title'=>'\\1'))", $c); + $c = preg_replace('/%%(\w+).(\w+)%%/e', 'common_config(\'\\1\', \'\\2\')', $c); + return Markdown($c); } function common_profile_avatar_url($profile, $size=AVATAR_PROFILE_SIZE) { - $avatar = $profile->getAvatar($size); - if ($avatar) { - return common_avatar_display_url($avatar); - } else { - return common_default_avatar($size); - } + $avatar = $profile->getAvatar($size); + if ($avatar) { + return common_avatar_display_url($avatar); + } else { + return common_default_avatar($size); + } } function common_profile_uri($profile) { - if (!$profile) { - return NULL; - } - $user = User::staticGet($profile->id); - if ($user) { - return $user->uri; - } - - $remote = Remote_profile::staticGet($profile->id); - if ($remote) { - return $remote->uri; - } - # XXX: this is a very bad profile! - return NULL; + if (!$profile) { + return null; + } + $user = User::staticGet($profile->id); + if ($user) { + return $user->uri; + } + + $remote = Remote_profile::staticGet($profile->id); + if ($remote) { + return $remote->uri; + } + // XXX: this is a very bad profile! + return null; } function common_canonical_sms($sms) { - # strip non-digits - preg_replace('/\D/', '', $sms); - return $sms; + // strip non-digits + preg_replace('/\D/', '', $sms); + return $sms; } function common_error_handler($errno, $errstr, $errfile, $errline, $errcontext) { switch ($errno) { case E_USER_ERROR: - common_log(LOG_ERR, "[$errno] $errstr ($errfile:$errline)"); - exit(1); - break; + common_log(LOG_ERR, "[$errno] $errstr ($errfile:$errline)"); + exit(1); + break; - case E_USER_WARNING: - common_log(LOG_WARNING, "[$errno] $errstr ($errfile:$errline)"); - break; + case E_USER_WARNING: + common_log(LOG_WARNING, "[$errno] $errstr ($errfile:$errline)"); + break; case E_USER_NOTICE: - common_log(LOG_NOTICE, "[$errno] $errstr ($errfile:$errline)"); - break; + common_log(LOG_NOTICE, "[$errno] $errstr ($errfile:$errline)"); + break; } - # FIXME: show error page if we're on the Web + // FIXME: show error page if we're on the Web /* Don't execute PHP internal error handler */ return true; } function common_session_token() { - common_ensure_session(); - if (!array_key_exists('token', $_SESSION)) { - $_SESSION['token'] = common_good_rand(64); - } - return $_SESSION['token']; + common_ensure_session(); + if (!array_key_exists('token', $_SESSION)) { + $_SESSION['token'] = common_good_rand(64); + } + return $_SESSION['token']; } function common_disfavor_form($notice) { - common_element_start('form', array('id' => 'disfavor-' . $notice->id, - 'method' => 'post', - 'class' => 'disfavor', - 'action' => common_local_url('disfavor'))); - - common_element('input', array('type' => 'hidden', - 'name' => 'token-'. $notice->id, - 'id' => 'token-'. $notice->id, - 'class' => 'token', - 'value' => common_session_token())); - - common_element('input', array('type' => 'hidden', - 'name' => 'notice', - 'id' => 'notice-n'. $notice->id, - 'class' => 'notice', - 'value' => $notice->id)); - - common_element('input', array('type' => 'submit', - 'id' => 'disfavor-submit-' . $notice->id, - 'name' => 'disfavor-submit-' . $notice->id, - 'class' => 'disfavor', - 'value' => 'Disfavor favorite', - 'title' => 'Remove this message from favorites')); - common_element_end('form'); + common_element_start('form', array('id' => 'disfavor-' . $notice->id, + 'method' => 'post', + 'class' => 'disfavor', + 'action' => common_local_url('disfavor'))); + + common_element('input', array('type' => 'hidden', + 'name' => 'token-'. $notice->id, + 'id' => 'token-'. $notice->id, + 'class' => 'token', + 'value' => common_session_token())); + + common_element('input', array('type' => 'hidden', + 'name' => 'notice', + 'id' => 'notice-n'. $notice->id, + 'class' => 'notice', + 'value' => $notice->id)); + + common_element('input', array('type' => 'submit', + 'id' => 'disfavor-submit-' . $notice->id, + 'name' => 'disfavor-submit-' . $notice->id, + 'class' => 'disfavor', + 'value' => 'Disfavor favorite', + 'title' => 'Remove this message from favorites')); + common_element_end('form'); } function common_favor_form($notice) { - common_element_start('form', array('id' => 'favor-' . $notice->id, - 'method' => 'post', - 'class' => 'favor', - 'action' => common_local_url('favor'))); - - common_element('input', array('type' => 'hidden', - 'name' => 'token-'. $notice->id, - 'id' => 'token-'. $notice->id, - 'class' => 'token', - 'value' => common_session_token())); - - common_element('input', array('type' => 'hidden', - 'name' => 'notice', - 'id' => 'notice-n'. $notice->id, - 'class' => 'notice', - 'value' => $notice->id)); - - common_element('input', array('type' => 'submit', - 'id' => 'favor-submit-' . $notice->id, - 'name' => 'favor-submit-' . $notice->id, - 'class' => 'favor', - 'value' => 'Add to favorites', - 'title' => 'Add this message to favorites')); - common_element_end('form'); + common_element_start('form', array('id' => 'favor-' . $notice->id, + 'method' => 'post', + 'class' => 'favor', + 'action' => common_local_url('favor'))); + + common_element('input', array('type' => 'hidden', + 'name' => 'token-'. $notice->id, + 'id' => 'token-'. $notice->id, + 'class' => 'token', + 'value' => common_session_token())); + + common_element('input', array('type' => 'hidden', + 'name' => 'notice', + 'id' => 'notice-n'. $notice->id, + 'class' => 'notice', + 'value' => $notice->id)); + + common_element('input', array('type' => 'submit', + 'id' => 'favor-submit-' . $notice->id, + 'name' => 'favor-submit-' . $notice->id, + 'class' => 'favor', + 'value' => 'Add to favorites', + 'title' => 'Add this message to favorites')); + common_element_end('form'); } function common_nudge_form($profile) { - common_element_start('form', array('id' => 'nudge', 'method' => 'post', - 'action' => common_local_url('nudge', array('nickname' => $profile->nickname)))); - common_hidden('token', common_session_token()); - common_element('input', array('type' => 'submit', - 'class' => 'submit', - 'value' => _('Send a nudge'))); - common_element_end('form'); + common_element_start('form', array('id' => 'nudge', 'method' => 'post', + 'action' => common_local_url('nudge', array('nickname' => $profile->nickname)))); + common_hidden('token', common_session_token()); + common_element('input', array('type' => 'submit', + 'class' => 'submit', + 'value' => _('Send a nudge'))); + common_element_end('form'); } function common_nudge_response() { - common_element('p', array('id' => 'nudge_response'), _('Nudge sent!')); + common_element('p', array('id' => 'nudge_response'), _('Nudge sent!')); } function common_subscribe_form($profile) { - common_element_start('form', array('id' => 'subscribe-' . $profile->id, - 'method' => 'post', - 'class' => 'subscribe', - 'action' => common_local_url('subscribe'))); - common_hidden('token', common_session_token()); - common_element('input', array('id' => 'subscribeto-' . $profile->id, - 'name' => 'subscribeto', - 'type' => 'hidden', - 'value' => $profile->id)); - common_element('input', array('type' => 'submit', - 'class' => 'submit', - 'value' => _('Subscribe'))); - common_element_end('form'); + common_element_start('form', array('id' => 'subscribe-' . $profile->id, + 'method' => 'post', + 'class' => 'subscribe', + 'action' => common_local_url('subscribe'))); + common_hidden('token', common_session_token()); + common_element('input', array('id' => 'subscribeto-' . $profile->id, + 'name' => 'subscribeto', + 'type' => 'hidden', + 'value' => $profile->id)); + common_element('input', array('type' => 'submit', + 'class' => 'submit', + 'value' => _('Subscribe'))); + common_element_end('form'); } function common_unsubscribe_form($profile) { - common_element_start('form', array('id' => 'unsubscribe-' . $profile->id, - 'method' => 'post', - 'class' => 'unsubscribe', - 'action' => common_local_url('unsubscribe'))); - common_hidden('token', common_session_token()); - common_element('input', array('id' => 'unsubscribeto-' . $profile->id, - 'name' => 'unsubscribeto', - 'type' => 'hidden', - 'value' => $profile->id)); - common_element('input', array('type' => 'submit', - 'class' => 'submit', - 'value' => _('Unsubscribe'))); - common_element_end('form'); + common_element_start('form', array('id' => 'unsubscribe-' . $profile->id, + 'method' => 'post', + 'class' => 'unsubscribe', + 'action' => common_local_url('unsubscribe'))); + common_hidden('token', common_session_token()); + common_element('input', array('id' => 'unsubscribeto-' . $profile->id, + 'name' => 'unsubscribeto', + 'type' => 'hidden', + 'value' => $profile->id)); + common_element('input', array('type' => 'submit', + 'class' => 'submit', + 'value' => _('Unsubscribe'))); + common_element_end('form'); } // XXX: Refactor this code function common_profile_new_message_nudge ($cur, $profile) { - $user = User::staticGet('id', $profile->id); + $user = User::staticGet('id', $profile->id); - if ($cur && $cur->id != $user->id && $cur->mutuallySubscribed($user)) { + if ($cur && $cur->id != $user->id && $cur->mutuallySubscribed($user)) { common_element_start('li', array('id' => 'profile_send_a_new_message')); - common_element('a', array('href' => common_local_url('newmessage', array('to' => $user->id))), - _('Send a message')); + common_element('a', array('href' => common_local_url('newmessage', array('to' => $user->id))), + _('Send a message')); common_element_end('li'); - if ($user->email && $user->emailnotifynudge) { + if ($user->email && $user->emailnotifynudge) { common_element_start('li', array('id' => 'profile_nudge')); common_nudge_form($user); common_element_end('li'); } - } + } } function common_cache_key($extra) { - return 'laconica:' . common_keyize(common_config('site', 'name')) . ':' . $extra; + return 'laconica:' . common_keyize(common_config('site', 'name')) . ':' . $extra; } function common_keyize($str) { - $str = strtolower($str); - $str = preg_replace('/\s/', '_', $str); - return $str; + $str = strtolower($str); + $str = preg_replace('/\s/', '_', $str); + return $str; } function common_message_form($content, $user, $to) { - common_element_start('form', array('id' => 'message_form', - 'method' => 'post', - 'action' => common_local_url('newmessage'))); + common_element_start('form', array('id' => 'message_form', + 'method' => 'post', + 'action' => common_local_url('newmessage'))); - $mutual_users = $user->mutuallySubscribedUsers(); + $mutual_users = $user->mutuallySubscribedUsers(); - $mutual = array(); + $mutual = array(); - while ($mutual_users->fetch()) { - if ($mutual_users->id != $user->id) { - $mutual[$mutual_users->id] = $mutual_users->nickname; - } - } + while ($mutual_users->fetch()) { + if ($mutual_users->id != $user->id) { + $mutual[$mutual_users->id] = $mutual_users->nickname; + } + } - $mutual_users->free(); - unset($mutual_users); + $mutual_users->free(); + unset($mutual_users); - common_dropdown('to', _('To'), $mutual, NULL, FALSE, $to->id); + common_dropdown('to', _('To'), $mutual, null, FALSE, $to->id); - common_element_start('p'); + common_element_start('p'); - common_element('textarea', array('id' => 'message_content', - 'cols' => 60, - 'rows' => 3, - 'name' => 'content'), - ($content) ? $content : ''); + common_element('textarea', array('id' => 'message_content', + 'cols' => 60, + 'rows' => 3, + 'name' => 'content'), + ($content) ? $content : ''); - common_element('input', array('id' => 'message_send', - 'name' => 'message_send', - 'type' => 'submit', - 'value' => _('Send'))); + common_element('input', array('id' => 'message_send', + 'name' => 'message_send', + 'type' => 'submit', + 'value' => _('Send'))); - common_hidden('token', common_session_token()); + common_hidden('token', common_session_token()); - common_element_end('p'); - common_element_end('form'); + common_element_end('p'); + common_element_end('form'); } function common_memcache() { - static $cache = NULL; - if (!common_config('memcached', 'enabled')) { - return NULL; - } else { - if (!$cache) { - $cache = new Memcache(); - $servers = common_config('memcached', 'server'); - if (is_array($servers)) { - foreach($servers as $server) { - $cache->addServer($server); - } - } else { - $cache->addServer($servers); - } - } - return $cache; - } + static $cache = null; + if (!common_config('memcached', 'enabled')) { + return null; + } else { + if (!$cache) { + $cache = new Memcache(); + $servers = common_config('memcached', 'server'); + if (is_array($servers)) { + foreach($servers as $server) { + $cache->addServer($server); + } + } else { + $cache->addServer($servers); + } + } + return $cache; + } } function common_compatible_license($from, $to) { - # XXX: better compatibility check needed here! - return ($from == $to); + // XXX: better compatibility check needed here! + return ($from == $to); } /* These are almost identical, so we use a helper function */ -function common_block_form($profile, $args=NULL) { +function common_block_form($profile, $args=null) { common_blocking_form('block', _('Block'), $profile, $args); } -function common_unblock_form($profile, $args=NULL) { +function common_unblock_form($profile, $args=null) { common_blocking_form('unblock', _('Unblock'), $profile, $args); } -function common_blocking_form($type, $label, $profile, $args=NULL) { +function common_blocking_form($type, $label, $profile, $args=null) { common_element_start('form', array('id' => $type . '-' . $profile->id, 'method' => 'post', 'class' => $type, @@ -2217,4 +2217,3 @@ function common_blocking_form($type, $label, $profile, $args=NULL) { common_element_end('form'); return; } - -- 2.39.5