Merge branch 'testing' of git@gitorious.org:statusnet/mainline into 0.9.x
80
README
@ -2,8 +2,8 @@
|
|||||||
README
|
README
|
||||||
------
|
------
|
||||||
|
|
||||||
StatusNet 0.9.0 ("Stand") Beta 4
|
StatusNet 0.9.0 ("Stand") Beta 5
|
||||||
27 Jan 2010
|
1 Feb 2010
|
||||||
|
|
||||||
This is the README file for StatusNet (formerly Laconica), the Open
|
This is the README file for StatusNet (formerly Laconica), the Open
|
||||||
Source microblogging platform. It includes installation instructions,
|
Source microblogging platform. It includes installation instructions,
|
||||||
@ -78,6 +78,11 @@ New this version
|
|||||||
================
|
================
|
||||||
|
|
||||||
This is a major feature release since version 0.8.2, released Nov 1 2009.
|
This is a major feature release since version 0.8.2, released Nov 1 2009.
|
||||||
|
It is also a security release since 0.9.0beta4 January 27 2010. Beta
|
||||||
|
users are strongly encouraged to upgrade to deal with a security alert.
|
||||||
|
|
||||||
|
http://status.net/wiki/Security_alert_0000002
|
||||||
|
|
||||||
Notable changes this version:
|
Notable changes this version:
|
||||||
|
|
||||||
- Records of deleted notices are stored without the notice content.
|
- Records of deleted notices are stored without the notice content.
|
||||||
@ -198,6 +203,77 @@ Notable changes this version:
|
|||||||
- Major refactoring of queue handlers to manage very
|
- Major refactoring of queue handlers to manage very
|
||||||
large hosting site (like status.net)
|
large hosting site (like status.net)
|
||||||
- SubscriptionThrottle plugin to prevent subscription spamming
|
- SubscriptionThrottle plugin to prevent subscription spamming
|
||||||
|
- Don't enqueue into plugin or SMS queues when disabled (breaks unqueuehandler if SMS queue isn't attached)
|
||||||
|
- Improve name validation checks on local File references
|
||||||
|
- fix local file include vulnerability in doc.php
|
||||||
|
- Reusing fixed selector name for 'processing' in util.js
|
||||||
|
- Removed hAtom pattern from registration page.
|
||||||
|
- restructuring of User::registerNew() lost password munging
|
||||||
|
- Add a script to clear the cache for a given key
|
||||||
|
- buggy fetch for site owner
|
||||||
|
- Added missing concat of </li> in Realtime response
|
||||||
|
- Updated XHR binded events to work better in jQuery 1.4.1. Using .live() for event delegation instead of jQuery.data() and checking to see if an element was previously binded.
|
||||||
|
- Updated jQuery Form Plugin from v2.17 to v2.36
|
||||||
|
- Updated jQuery JavaScript Library from v1.3.2 to v1.4.1
|
||||||
|
- move schema.type.php to typeschema.php like other files
|
||||||
|
- Add Really Simple Discovery (RSD) support
|
||||||
|
- Add a robots.txt URL to the site root
|
||||||
|
- error clearing tags for profiles from memcached
|
||||||
|
- on exceptions, stomp logs the error and reenqueues
|
||||||
|
- add lat, lon, location and remove closing tag from geocode.php
|
||||||
|
- Use passed-in lat long in geocode.php
|
||||||
|
- better handling of null responses from geonames.org
|
||||||
|
- Globalized form notice data geo values
|
||||||
|
- Using jQuery chaining in FormNoticeXHR
|
||||||
|
- Using form object instead of form_id and find(). Slightly faster and easier to read.
|
||||||
|
- removed describeTable from base class, and fixed it up in pgsql
|
||||||
|
- getTableDef() mostly working in postgres
|
||||||
|
- move the schema DDL sql off into seperate files for each db we support
|
||||||
|
- plugin to limit number of registered users
|
||||||
|
- add hooks for user registration
|
||||||
|
- live fast, die young in bash scripts
|
||||||
|
- for single-user mode, retrieve either site owner or defined nickname
|
||||||
|
- method to get the site owner
|
||||||
|
- define a constant for the 'owner' role of a site
|
||||||
|
- add simple cache getter/setter static functions to Memcached_DataObject
|
||||||
|
- Adds notice author's name to @title in Realtime response
|
||||||
|
- Hides .author from XHR response in showstream
|
||||||
|
- Hides .author from XHR response in showstream
|
||||||
|
- Fix more fatal errors in queue edge cases
|
||||||
|
- Don't attempt to resend XMPP messages that can't be broadcast due to the profile being deleted.
|
||||||
|
- Wrap each bit of distrib queue handler's saving operation in a try/catch; log exceptions but let everything else continue.
|
||||||
|
- Log exceptions from queuedaemon.php if they're not already caught
|
||||||
|
- Move sessions settings to its own panel
|
||||||
|
- Fixes for status_network db object .ini and tag setter script
|
||||||
|
- Add a script to set tags for sites
|
||||||
|
- Adjust API authentication to also check for OAuth protocol params in the HTTP Authorization header, as defined in OAuth HTTP Authorization Scheme.
|
||||||
|
- Last-chance distribution if enqueueing fails
|
||||||
|
- Manual failover for stomp queues.
|
||||||
|
- lost config in index.php made all traffic go to master
|
||||||
|
- "Revert "move RW setup above user get in index.php so remember_me works""
|
||||||
|
- Revert "move RW setup above user get in index.php so remember_me works"
|
||||||
|
- move RW setup above user get in index.php so remember_me works
|
||||||
|
- hide most DB_DataObject errors
|
||||||
|
- always set up database_rw, regardless, so cached sessions work
|
||||||
|
- update mysqltimestamps on insert and update
|
||||||
|
- additional debugging data for Sessions
|
||||||
|
- 'Sign in with Twitter' button img
|
||||||
|
- Update to biz theme
|
||||||
|
- Remove redundant session token field from form (was already being added by base class).
|
||||||
|
- 'Sign in with Twitter' button img
|
||||||
|
- Can now set $config['queue']['stomp_persistent'] = false; to explicitly disable persistence when we queue items
|
||||||
|
- Showing processing indicator for form_repeat on submit instead of form
|
||||||
|
- Removed avatar from repeat of username (matches noticelist)
|
||||||
|
- Removed unused variable assignment for avatar URL and added missing fn
|
||||||
|
- Don't preemptively close existing DB connections for web views (needed to keep # of conns from going insane on multi-site queue daemons, so just doing for CLI) May, or may not, help with mystery session problems
|
||||||
|
- dropping the setcookie() call from common_ensure_session() since we're pretty sure it's unnecessary
|
||||||
|
- append '/' on cookie path for now (may still need some refactoring)
|
||||||
|
- set session cookie correctly
|
||||||
|
- Fix for Mapstraction plugin's zoomed map links
|
||||||
|
- debug log line for control channel sub
|
||||||
|
- Move faceboookapp.js to the Facebook plugin
|
||||||
|
- fix for fix for bad realtime JS load
|
||||||
|
- default 24-hour expiry on Memcached objects where not specified.
|
||||||
|
|
||||||
Prerequisites
|
Prerequisites
|
||||||
=============
|
=============
|
||||||
|
@ -303,6 +303,27 @@ class RegisterAction extends Action
|
|||||||
return ($user !== false);
|
return ($user !== false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// overrrided to add entry-title class
|
||||||
|
function showPageTitle() {
|
||||||
|
if (Event::handle('StartShowPageTitle', array($this))) {
|
||||||
|
$this->element('h1', array('class' => 'entry-title'), $this->title());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// overrided to add hentry, and content-inner class
|
||||||
|
function showContentBlock()
|
||||||
|
{
|
||||||
|
$this->elementStart('div', array('id' => 'content', 'class' => 'hentry'));
|
||||||
|
$this->showPageTitle();
|
||||||
|
$this->showPageNoticeBlock();
|
||||||
|
$this->elementStart('div', array('id' => 'content_inner',
|
||||||
|
'class' => 'entry-content'));
|
||||||
|
// show the actual content (forms, lists, whatever)
|
||||||
|
$this->showContent();
|
||||||
|
$this->elementEnd('div');
|
||||||
|
$this->elementEnd('div');
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instructions or a notice for the page
|
* Instructions or a notice for the page
|
||||||
*
|
*
|
||||||
|
@ -201,7 +201,7 @@ class ShowApplicationAction extends OwnerDesignAction
|
|||||||
$userCnt = $appUsers->count();
|
$userCnt = $appUsers->count();
|
||||||
|
|
||||||
$this->raw(sprintf(
|
$this->raw(sprintf(
|
||||||
_('created by %1$s - %2$s access by default - %3$d users'),
|
_('Created by %1$s - %2$s access by default - %3$d users'),
|
||||||
$profile->getBestName(),
|
$profile->getBestName(),
|
||||||
$defaultAccess,
|
$defaultAccess,
|
||||||
$userCnt
|
$userCnt
|
||||||
|
@ -181,7 +181,7 @@ class File extends Memcached_DataObject
|
|||||||
*/
|
*/
|
||||||
static function validFilename($filename)
|
static function validFilename($filename)
|
||||||
{
|
{
|
||||||
return preg_match('^/[A-Za-z0-9._-]+$/', $filename);
|
return preg_match('/^[A-Za-z0-9._-]+$/', $filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -22,7 +22,7 @@ if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); }
|
|||||||
//exit with 200 response, if this is checking fancy from the installer
|
//exit with 200 response, if this is checking fancy from the installer
|
||||||
if (isset($_REQUEST['p']) && $_REQUEST['p'] == 'check-fancy') { exit; }
|
if (isset($_REQUEST['p']) && $_REQUEST['p'] == 'check-fancy') { exit; }
|
||||||
|
|
||||||
define('STATUSNET_VERSION', '0.9.0beta4');
|
define('STATUSNET_VERSION', '0.9.0beta5');
|
||||||
define('LACONICA_VERSION', STATUSNET_VERSION); // compatibility
|
define('LACONICA_VERSION', STATUSNET_VERSION); // compatibility
|
||||||
|
|
||||||
define('STATUSNET_CODENAME', 'Stand');
|
define('STATUSNET_CODENAME', 'Stand');
|
||||||
|
@ -182,21 +182,6 @@ class UserFlagPlugin extends Plugin
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Add our plugin's CSS to page output
|
|
||||||
*
|
|
||||||
* @param Action $action action being shown
|
|
||||||
*
|
|
||||||
* @return boolean hook result
|
|
||||||
*/
|
|
||||||
|
|
||||||
function onEndShowStatusNetStyles($action)
|
|
||||||
{
|
|
||||||
$action->cssLink(common_path('plugins/UserFlag/userflag.css'),
|
|
||||||
null, 'screen, projection, tv');
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize any flagging buttons on the page
|
* Initialize any flagging buttons on the page
|
||||||
*
|
*
|
||||||
|
@ -54,7 +54,7 @@ class ClearFlagForm extends ProfileActionForm
|
|||||||
|
|
||||||
function formClass()
|
function formClass()
|
||||||
{
|
{
|
||||||
return 'form_entity_clearflag';
|
return 'form_user_clearflag';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,4 +0,0 @@
|
|||||||
.entity_flag input.submit,
|
|
||||||
.entity_flag p {
|
|
||||||
background:url(icon_flag.gif) 5px 5px no-repeat;
|
|
||||||
}
|
|
16
scripts/setconfig.php
Normal file → Executable file
@ -28,6 +28,7 @@ setconfig.php [options] [section] [setting] <value>
|
|||||||
With three args, set the setting to the value.
|
With three args, set the setting to the value.
|
||||||
With two args, just show the setting.
|
With two args, just show the setting.
|
||||||
With -d, delete the setting.
|
With -d, delete the setting.
|
||||||
|
With no args, lists all currently set values.
|
||||||
|
|
||||||
[section] section to use (required)
|
[section] section to use (required)
|
||||||
[setting] setting to use (required)
|
[setting] setting to use (required)
|
||||||
@ -39,6 +40,21 @@ END_OF_SETCONFIG_HELP;
|
|||||||
|
|
||||||
require_once INSTALLDIR.'/scripts/commandline.inc';
|
require_once INSTALLDIR.'/scripts/commandline.inc';
|
||||||
|
|
||||||
|
if (empty($args)) {
|
||||||
|
$count = 0;
|
||||||
|
$config = new Config();
|
||||||
|
$config->find();
|
||||||
|
while ($config->fetch()) {
|
||||||
|
$count++;
|
||||||
|
printf("%-20s %-20s %s\n", $config->section, $config->setting,
|
||||||
|
var_export($config->value, true));
|
||||||
|
}
|
||||||
|
if ($count == 0) {
|
||||||
|
print "No configuration set in database for this site.\n";
|
||||||
|
}
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
if (count($args) < 2 || count($args) > 3) {
|
if (count($args) < 2 || count($args) > 3) {
|
||||||
show_help();
|
show_help();
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -632,7 +632,8 @@ margin-bottom:18px;
|
|||||||
.entity_profile .entity_url,
|
.entity_profile .entity_url,
|
||||||
.entity_profile .entity_note,
|
.entity_profile .entity_note,
|
||||||
.entity_profile .entity_tags,
|
.entity_profile .entity_tags,
|
||||||
.entity_profile .entity_aliases {
|
.entity_profile .entity_aliases,
|
||||||
|
.entity_profile .entity_statistics {
|
||||||
margin-left:113px;
|
margin-left:113px;
|
||||||
margin-bottom:4px;
|
margin-bottom:4px;
|
||||||
}
|
}
|
||||||
@ -1411,6 +1412,9 @@ margin-bottom:18px;
|
|||||||
.hentry .entry-content li li {
|
.hentry .entry-content li li {
|
||||||
margin-left:18px;
|
margin-left:18px;
|
||||||
}
|
}
|
||||||
|
.hentry .entry-content .form_settings ul {
|
||||||
|
margin-left:0;
|
||||||
|
}
|
||||||
|
|
||||||
#content #plugin_authors {
|
#content #plugin_authors {
|
||||||
min-width:122px;
|
min-width:122px;
|
||||||
|
Before Width: | Height: | Size: 3.6 KiB After Width: | Height: | Size: 3.7 KiB |
BIN
theme/base/images/icons/twotone/green/clear.gif
Normal file
After Width: | Height: | Size: 82 B |
Before Width: | Height: | Size: 80 B After Width: | Height: | Size: 80 B |
Before Width: | Height: | Size: 4.9 KiB After Width: | Height: | Size: 9.9 KiB |
@ -18,7 +18,7 @@ font-family: "Lucida Sans Unicode", "Lucida Grande", sans-serif;
|
|||||||
font-size:1em;
|
font-size:1em;
|
||||||
}
|
}
|
||||||
address {
|
address {
|
||||||
margin-right:5.7%;
|
margin-right:5.3%;
|
||||||
}
|
}
|
||||||
input, textarea, select {
|
input, textarea, select {
|
||||||
border-width:2px;
|
border-width:2px;
|
||||||
@ -189,7 +189,10 @@ button.close,
|
|||||||
.notice-options .repeated,
|
.notice-options .repeated,
|
||||||
.form_notice label[for=notice_data-geo],
|
.form_notice label[for=notice_data-geo],
|
||||||
button.minimize,
|
button.minimize,
|
||||||
.form_reset_key input.submit {
|
.form_reset_key input.submit,
|
||||||
|
.entity_clear input.submit,
|
||||||
|
.entity_flag input.submit,
|
||||||
|
.entity_flag p {
|
||||||
background-image:url(../../base/images/icons/icons-01.gif);
|
background-image:url(../../base/images/icons/icons-01.gif);
|
||||||
background-repeat:no-repeat;
|
background-repeat:no-repeat;
|
||||||
background-color:transparent;
|
background-color:transparent;
|
||||||
@ -338,6 +341,13 @@ background-position: 5px -1511px;
|
|||||||
.form_reset_key input.submit {
|
.form_reset_key input.submit {
|
||||||
background-position: 5px -1973px;
|
background-position: 5px -1973px;
|
||||||
}
|
}
|
||||||
|
.entity_clear input.submit {
|
||||||
|
background-position: 5px -2039px;
|
||||||
|
}
|
||||||
|
.entity_flag input.submit,
|
||||||
|
.entity_flag p {
|
||||||
|
background-position: 5px -2105px;
|
||||||
|
}
|
||||||
|
|
||||||
/* NOTICES */
|
/* NOTICES */
|
||||||
.notice .attachment {
|
.notice .attachment {
|
||||||
|
Before Width: | Height: | Size: 6.2 KiB After Width: | Height: | Size: 9.9 KiB |
Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 3.9 KiB |
@ -189,7 +189,10 @@ button.close,
|
|||||||
.notice-options .repeated,
|
.notice-options .repeated,
|
||||||
.form_notice label[for=notice_data-geo],
|
.form_notice label[for=notice_data-geo],
|
||||||
button.minimize,
|
button.minimize,
|
||||||
.form_reset_key input.submit {
|
.form_reset_key input.submit,
|
||||||
|
.entity_clear input.submit,
|
||||||
|
.entity_flag input.submit,
|
||||||
|
.entity_flag p {
|
||||||
background-image:url(../../base/images/icons/icons-01.gif);
|
background-image:url(../../base/images/icons/icons-01.gif);
|
||||||
background-repeat:no-repeat;
|
background-repeat:no-repeat;
|
||||||
background-color:transparent;
|
background-color:transparent;
|
||||||
@ -337,6 +340,13 @@ background-position: 5px -1511px;
|
|||||||
.form_reset_key input.submit {
|
.form_reset_key input.submit {
|
||||||
background-position: 5px -1973px;
|
background-position: 5px -1973px;
|
||||||
}
|
}
|
||||||
|
.entity_clear input.submit {
|
||||||
|
background-position: 5px -2039px;
|
||||||
|
}
|
||||||
|
.entity_flag input.submit,
|
||||||
|
.entity_flag p {
|
||||||
|
background-position: 5px -2105px;
|
||||||
|
}
|
||||||
|
|
||||||
/* NOTICES */
|
/* NOTICES */
|
||||||
.notice .attachment {
|
.notice .attachment {
|
||||||
|
Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 3.9 KiB |