Merge commit 'origin/master' into testing
This commit is contained in:
commit
d00ce38549
@ -147,6 +147,7 @@ class Memcached_DataObject extends DB_DataObject
|
|||||||
{
|
{
|
||||||
$result = parent::insert();
|
$result = parent::insert();
|
||||||
if ($result) {
|
if ($result) {
|
||||||
|
$this->fixupTimestamps();
|
||||||
$this->encache(); // in case of cached negative lookups
|
$this->encache(); // in case of cached negative lookups
|
||||||
}
|
}
|
||||||
return $result;
|
return $result;
|
||||||
@ -159,6 +160,7 @@ class Memcached_DataObject extends DB_DataObject
|
|||||||
}
|
}
|
||||||
$result = parent::update($orig);
|
$result = parent::update($orig);
|
||||||
if ($result) {
|
if ($result) {
|
||||||
|
$this->fixupTimestamps();
|
||||||
$this->encache();
|
$this->encache();
|
||||||
}
|
}
|
||||||
return $result;
|
return $result;
|
||||||
@ -428,7 +430,7 @@ class Memcached_DataObject extends DB_DataObject
|
|||||||
//
|
//
|
||||||
// WARNING WARNING if we end up actually using multiple DBs at a time
|
// WARNING WARNING if we end up actually using multiple DBs at a time
|
||||||
// we'll need some fancier logic here.
|
// we'll need some fancier logic here.
|
||||||
if (!$exists && !empty($_DB_DATAOBJECT['CONNECTIONS'])) {
|
if (!$exists && !empty($_DB_DATAOBJECT['CONNECTIONS']) && php_sapi_name() == 'cli') {
|
||||||
foreach ($_DB_DATAOBJECT['CONNECTIONS'] as $index => $conn) {
|
foreach ($_DB_DATAOBJECT['CONNECTIONS'] as $index => $conn) {
|
||||||
if (!empty($conn)) {
|
if (!empty($conn)) {
|
||||||
$conn->disconnect();
|
$conn->disconnect();
|
||||||
@ -529,4 +531,25 @@ class Memcached_DataObject extends DB_DataObject
|
|||||||
|
|
||||||
return $c->delete($cacheKey);
|
return $c->delete($cacheKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function fixupTimestamps()
|
||||||
|
{
|
||||||
|
// Fake up timestamp columns
|
||||||
|
$columns = $this->table();
|
||||||
|
foreach ($columns as $name => $type) {
|
||||||
|
if ($type & DB_DATAOBJECT_MYSQLTIMESTAMP) {
|
||||||
|
$this->$name = common_sql_now();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function debugDump()
|
||||||
|
{
|
||||||
|
common_debug("debugDump: " . common_log_objstring($this));
|
||||||
|
}
|
||||||
|
|
||||||
|
function raiseError($message, $type = null, $behaviour = null)
|
||||||
|
{
|
||||||
|
throw new ServerException("DB_DataObject error [$type]: $message");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -64,8 +64,12 @@ class Session extends Memcached_DataObject
|
|||||||
$session = Session::staticGet('id', $id);
|
$session = Session::staticGet('id', $id);
|
||||||
|
|
||||||
if (empty($session)) {
|
if (empty($session)) {
|
||||||
|
self::logdeb("Couldn't find '$id'");
|
||||||
return '';
|
return '';
|
||||||
} else {
|
} else {
|
||||||
|
self::logdeb("Found '$id', returning " .
|
||||||
|
strlen($session->session_data) .
|
||||||
|
" chars of data");
|
||||||
return (string)$session->session_data;
|
return (string)$session->session_data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -77,14 +81,24 @@ class Session extends Memcached_DataObject
|
|||||||
$session = Session::staticGet('id', $id);
|
$session = Session::staticGet('id', $id);
|
||||||
|
|
||||||
if (empty($session)) {
|
if (empty($session)) {
|
||||||
|
self::logdeb("'$id' doesn't yet exist; inserting.");
|
||||||
$session = new Session();
|
$session = new Session();
|
||||||
|
|
||||||
$session->id = $id;
|
$session->id = $id;
|
||||||
$session->session_data = $session_data;
|
$session->session_data = $session_data;
|
||||||
$session->created = common_sql_now();
|
$session->created = common_sql_now();
|
||||||
|
|
||||||
return $session->insert();
|
$result = $session->insert();
|
||||||
|
|
||||||
|
if (!$result) {
|
||||||
|
common_log_db_error($session, 'INSERT', __FILE__);
|
||||||
|
self::logdeb("Failed to insert '$id'.");
|
||||||
} else {
|
} else {
|
||||||
|
self::logdeb("Successfully inserted '$id' (result = $result).");
|
||||||
|
}
|
||||||
|
return $result;
|
||||||
|
} else {
|
||||||
|
self::logdeb("'$id' already exists; updating.");
|
||||||
if (strcmp($session->session_data, $session_data) == 0) {
|
if (strcmp($session->session_data, $session_data) == 0) {
|
||||||
self::logdeb("Not writing session '$id'; unchanged");
|
self::logdeb("Not writing session '$id'; unchanged");
|
||||||
return true;
|
return true;
|
||||||
@ -95,7 +109,16 @@ class Session extends Memcached_DataObject
|
|||||||
|
|
||||||
$session->session_data = $session_data;
|
$session->session_data = $session_data;
|
||||||
|
|
||||||
return $session->update($orig);
|
$result = $session->update($orig);
|
||||||
|
|
||||||
|
if (!$result) {
|
||||||
|
common_log_db_error($session, 'UPDATE', __FILE__);
|
||||||
|
self::logdeb("Failed to update '$id'.");
|
||||||
|
} else {
|
||||||
|
self::logdeb("Successfully updated '$id' (result = $result).");
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -106,8 +129,17 @@ class Session extends Memcached_DataObject
|
|||||||
|
|
||||||
$session = Session::staticGet('id', $id);
|
$session = Session::staticGet('id', $id);
|
||||||
|
|
||||||
if (!empty($session)) {
|
if (empty($session)) {
|
||||||
return $session->delete();
|
self::logdeb("Can't find '$id' to delete.");
|
||||||
|
} else {
|
||||||
|
$result = $session->delete();
|
||||||
|
if (!$result) {
|
||||||
|
common_log_db_error($session, 'DELETE', __FILE__);
|
||||||
|
self::logdeb("Failed to delete '$id'.");
|
||||||
|
} else {
|
||||||
|
self::logdeb("Successfully deleted '$id' (result = $result).");
|
||||||
|
}
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -132,7 +164,10 @@ class Session extends Memcached_DataObject
|
|||||||
|
|
||||||
$session->free();
|
$session->free();
|
||||||
|
|
||||||
|
self::logdeb("Found " . count($ids) . " ids to delete.");
|
||||||
|
|
||||||
foreach ($ids as $id) {
|
foreach ($ids as $id) {
|
||||||
|
self::logdeb("Destroying session '$id'.");
|
||||||
self::destroy($id);
|
self::destroy($id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
20
index.php
20
index.php
@ -152,16 +152,6 @@ function checkMirror($action_obj, $args)
|
|||||||
|
|
||||||
static $alwaysRW = array('session', 'remember_me');
|
static $alwaysRW = array('session', 'remember_me');
|
||||||
|
|
||||||
if (common_config('db', 'mirror') && $action_obj->isReadOnly($args)) {
|
|
||||||
if (is_array(common_config('db', 'mirror'))) {
|
|
||||||
// "load balancing", ha ha
|
|
||||||
$arr = common_config('db', 'mirror');
|
|
||||||
$k = array_rand($arr);
|
|
||||||
$mirror = $arr[$k];
|
|
||||||
} else {
|
|
||||||
$mirror = common_config('db', 'mirror');
|
|
||||||
}
|
|
||||||
|
|
||||||
// We ensure that these tables always are used
|
// We ensure that these tables always are used
|
||||||
// on the master DB
|
// on the master DB
|
||||||
|
|
||||||
@ -172,6 +162,16 @@ function checkMirror($action_obj, $args)
|
|||||||
$config['db']['table_'.$table] = 'rw';
|
$config['db']['table_'.$table] = 'rw';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (common_config('db', 'mirror') && $action_obj->isReadOnly($args)) {
|
||||||
|
if (is_array(common_config('db', 'mirror'))) {
|
||||||
|
// "load balancing", ha ha
|
||||||
|
$arr = common_config('db', 'mirror');
|
||||||
|
$k = array_rand($arr);
|
||||||
|
$mirror = $arr[$k];
|
||||||
|
} else {
|
||||||
|
$mirror = common_config('db', 'mirror');
|
||||||
|
}
|
||||||
|
|
||||||
// everyone else uses the mirror
|
// everyone else uses the mirror
|
||||||
|
|
||||||
$config['db']['database'] = $mirror;
|
$config['db']['database'] = $mirror;
|
||||||
|
@ -84,6 +84,7 @@ $default =
|
|||||||
'control_channel' => '/topic/statusnet-control', // broadcasts to all queue daemons
|
'control_channel' => '/topic/statusnet-control', // broadcasts to all queue daemons
|
||||||
'stomp_username' => null,
|
'stomp_username' => null,
|
||||||
'stomp_password' => null,
|
'stomp_password' => null,
|
||||||
|
'stomp_persistent' => true, // keep items across queue server restart, if persistence is enabled
|
||||||
'monitor' => null, // URL to monitor ping endpoint (work in progress)
|
'monitor' => null, // URL to monitor ping endpoint (work in progress)
|
||||||
'softlimit' => '90%', // total size or % of memory_limit at which to restart queue threads gracefully
|
'softlimit' => '90%', // total size or % of memory_limit at which to restart queue threads gracefully
|
||||||
'debug_memory' => false, // true to spit memory usage to log
|
'debug_memory' => false, // true to spit memory usage to log
|
||||||
|
@ -174,12 +174,13 @@ class StompQueueManager extends QueueManager
|
|||||||
|
|
||||||
$this->_connect();
|
$this->_connect();
|
||||||
|
|
||||||
// XXX: serialize and send entire notice
|
$props = array('created' => common_sql_now());
|
||||||
|
if (common_config('queue', 'stomp_persistent')) {
|
||||||
|
$props['persistent'] = 'true';
|
||||||
|
}
|
||||||
$result = $this->con->send($this->queueName($queue),
|
$result = $this->con->send($this->queueName($queue),
|
||||||
$msg, // BODY of the message
|
$msg, // BODY of the message
|
||||||
array ('created' => common_sql_now(),
|
$props);
|
||||||
'persistent' => 'true'));
|
|
||||||
|
|
||||||
if (!$result) {
|
if (!$result) {
|
||||||
common_log(LOG_ERR, "Error sending $rep to $queue queue");
|
common_log(LOG_ERR, "Error sending $rep to $queue queue");
|
||||||
@ -242,6 +243,7 @@ class StompQueueManager extends QueueManager
|
|||||||
parent::start($master);
|
parent::start($master);
|
||||||
$this->_connect();
|
$this->_connect();
|
||||||
|
|
||||||
|
common_log(LOG_INFO, "Subscribing to $this->control");
|
||||||
$this->con->subscribe($this->control);
|
$this->con->subscribe($this->control);
|
||||||
if ($this->sites) {
|
if ($this->sites) {
|
||||||
foreach ($this->sites as $server) {
|
foreach ($this->sites as $server) {
|
||||||
|
@ -178,7 +178,6 @@ function common_ensure_session()
|
|||||||
}
|
}
|
||||||
if (isset($id)) {
|
if (isset($id)) {
|
||||||
session_id($id);
|
session_id($id);
|
||||||
setcookie(session_name(), $id);
|
|
||||||
}
|
}
|
||||||
@session_start();
|
@session_start();
|
||||||
if (!isset($_SESSION['started'])) {
|
if (!isset($_SESSION['started'])) {
|
||||||
|
Loading…
Reference in New Issue
Block a user