]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
caching layer for DB/DataObject
authorEvan Prodromou <evan@controlyourself.ca>
Fri, 26 Sep 2008 16:09:41 +0000 (12:09 -0400)
committerEvan Prodromou <evan@controlyourself.ca>
Fri, 26 Sep 2008 16:09:41 +0000 (12:09 -0400)
I added a new class, Memcached_DataObject, that will (optionally)
fetch data out of a memcached server if it's available. This only
works on 'staticGet'.

Methods that write to the database (insert, update, delete) will clear
and set the cache correctly, too.

darcs-hash:20080926160941-5ed1f-922de078b4c1941853ad014edf9a17fae486f8cf.gz

25 files changed:
classes/Avatar.php
classes/Confirm_address.php
classes/Consumer.php
classes/Fave.php
classes/Foreign_link.php
classes/Foreign_service.php
classes/Foreign_subscription.php
classes/Foreign_user.php
classes/Invitation.php
classes/Memcached_Object.php [new file with mode: 0644]
classes/Message.php
classes/Nonce.php
classes/Notice.php
classes/Notice_source.php
classes/Notice_tag.php
classes/Profile.php
classes/Queue_item.php
classes/Remember_me.php
classes/Remote_profile.php
classes/Reply.php
classes/Sms_carrier.php
classes/Subscription.php
classes/Token.php
classes/User.php
classes/User_openid.php

index 7aaf787b2e5b22e953c34c1974042dabed0b227f..ad5ccd7ba7475ddb99a2a5935145a56a6a1b5ec1 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for avatar
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Avatar extends DB_DataObject 
+class Avatar extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -21,7 +21,7 @@ class Avatar extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Avatar',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Avatar',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index f18d554a362de0df22f078a92ce5732df2760705..9f28dda7360896d0f25fa90bf1eb0813985be11f 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for confirm_address
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Confirm_address extends DB_DataObject 
+class Confirm_address extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -20,7 +20,7 @@ class Confirm_address extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Confirm_address',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Confirm_address',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 6f4513f332847652d7d28b4b7f749488e5592b42..5e457a3fc33b2cd828cf021cb7549e5950e4832d 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for consumer
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Consumer extends DB_DataObject 
+class Consumer extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -16,7 +16,7 @@ class Consumer extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Consumer',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Consumer',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 572dc232eaada1c3d05a48d2f8782dea79143a96..67cdf2cca406289d7f1b3f71f4b07058cd9864c7 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for fave
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Fave extends DB_DataObject 
+class Fave extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -15,7 +15,7 @@ class Fave extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Fave',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Fave',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 0c6df8ffcd9515797983f75b21d3f3d56756c142..ba6624d0697ffb16859c25907d14ea7f28a541dd 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for foreign_link
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Foreign_link extends DB_DataObject 
+class Foreign_link extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -21,7 +21,7 @@ class Foreign_link extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Foreign_link',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Foreign_link',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index ec38c54171cdfd2295a159f5c3c5ab8b7548ba71..61aa4616eb0b6429223cf5fd4914748d18742197 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for foreign_service
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Foreign_service extends DB_DataObject 
+class Foreign_service extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -17,7 +17,7 @@ class Foreign_service extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Foreign_service',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Foreign_service',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index b8cbed8ca67060e3df0a669cfbe1c8c493429ed4..742ea33338bab0471e4d659a799f008bc7b4afc9 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for foreign_subscription
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Foreign_subscription extends DB_DataObject 
+class Foreign_subscription extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -16,7 +16,7 @@ class Foreign_subscription extends DB_DataObject
     public $created;                         // datetime()   not_null
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Foreign_subscription',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Foreign_subscription',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 2b6e810158f1b8a93d44ce5f6041120ac7803571..f1ad6e6dc2370211bfb64a5e95fd6fd4f47e9756 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for foreign_user
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Foreign_user extends DB_DataObject 
+class Foreign_user extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -18,7 +18,7 @@ class Foreign_user extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Foreign_user',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Foreign_user',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index cc3c3b93706e927e2345dc6371d1fc110e67357b..a025d10b148f41230ec82f050d606661ca65a65b 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for invitation
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Invitation extends DB_DataObject 
+class Invitation extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -17,7 +17,7 @@ class Invitation extends DB_DataObject
     public $created;                         // datetime()   not_null
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Invitation',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Invitation',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
diff --git a/classes/Memcached_Object.php b/classes/Memcached_Object.php
new file mode 100644 (file)
index 0000000..a11c988
--- /dev/null
@@ -0,0 +1,144 @@
+<?php
+/*
+ * Laconica - a distributed open-source microblogging tool
+ * Copyright (C) 2008, Controlez-Vous, Inc.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
+if (!defined('LACONICA')) { exit(1); }
+
+require_once 'classes/Memcached_DataObject.php';
+
+class Memcached_DataObject extends DB_DataObject 
+{
+    static function &staticGet($cls, $k, $v=NULL) {
+               $i = $this->getcached($cls, $k, $v);
+               if (!is_null($i)) {
+                       return $i;
+               } else {
+                       $i = parent::staticGet($k, $v);
+                       if (!is_null($i)) {
+                               $i->encache();
+                       }
+                       return $i;
+               }
+       }
+       
+       function insert() {
+               $result = parent::insert();
+               if ($result) {
+                       $this->encache();
+               }
+               return $result;
+       }
+       
+       function update($orig=NULL) {
+               if (!is_null($orig)) {
+                       $orig->decache(); # might be different keys
+               }
+               $result = parent::update($orig);
+               if ($result) {
+                       $this->encache();
+               }
+       }
+       
+       function delete() {
+               $this->decache(); # while we still have the values!
+               return parent::delete();
+       }
+       
+       static function memcache() {
+               if (!common_config('memcached', 'enabled')) {
+                       return NULL;
+               } else {
+                       $cache = new Memcache();
+                       $res = $cache->connect(common_config('memcached', 'server'), 
+                                                                  common_config('memcached', 'port'));
+                       return ($res) ? $cache : NULL;
+               }
+       }
+       
+       static function cacheKey($cls, $k, $v) {
+               return common_cache_key(strtolower($cls) . ':' .
+                                                               $k . ':' .
+                                                               $v);
+       }
+       
+       static function getcached($cls, $k, $v) {
+               $c = Memcached_DataObject::memcache();
+               if (!$c) {
+                       return false;
+               } else {
+                       return $c->get(Memcached_DataObject::cacheKey($cls, $k, $v));
+               }
+       }
+
+       function keyTypes() {
+               global $_DB_DATAOBJECT;
+        if (!isset($_DB_DATAOBJECT['INI'][$this->_database][$this->__table."__keys"])) {
+                       $this->databaseStructure();
+
+        }
+               return $_DB_DATAOBJECT['INI'][$this->_database][$this->__table."__keys"];
+       }
+       
+       function encache() {
+               $c = $this->memcache();
+               if (!$c) {
+                       return false;
+               } else {
+                       $primary = array();
+                       $types = ksort($this->keyTypes());
+                       foreach ($types as $key => $type) {
+                               if ($type == 'K') {
+                                       $primary[] = $key;
+                               } else {
+                                       $c->set($this->cacheKey($this->tableName(), $key, $this->$key),
+                                                       $this);
+                               }
+                       }
+                       # XXX: figure out what to do with compound pkeys
+                       if (count($primary) == 1) {
+                               $key = $primary[0];
+                               $c->set($this->cacheKey($this->tableName(), $key, $this->$key),
+                                               $this);
+                       }
+               }
+       }
+       
+       function decache() {
+               $c = $this->memcache();
+               if (!$c) {
+                       return false;
+               } else {
+                       $primary = array();
+                       $types = ksort($this->keyTypes());
+                       foreach ($types as $key => $type) {
+                               if ($type == 'K') {
+                                       $primary[] = $this->$key;
+                               } else {
+                                       $c->delete($this->cacheKey($this->tableName(), $key, $this->$key),
+                                                          $this);
+                               }
+                       }
+                       # XXX: figure out what to do with compound pkeys
+                       if (count($primary) == 1) {
+                               $key = $primary[0];
+                               $c->delete($this->cacheKey($this->tableName(), $key, $this->$key),
+                                                  $this);
+                       }
+               }
+       }
+}
index a903161f781b64c73ccb41d1293797cf8f08cb3f..12ec10846bf7bb37a108aff600524fc58882c1b1 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for message
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Message extends DB_DataObject 
+class Message extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -22,7 +22,7 @@ class Message extends DB_DataObject
     public $source;                          // varchar(32)  
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Message',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Message',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 987e8d1e85c1fd18b9573a3ef021d889787d5c2f..258726c1e328f292165f0736bf26309a7ebb23eb 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for nonce
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Nonce extends DB_DataObject 
+class Nonce extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -18,7 +18,7 @@ class Nonce extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Nonce',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Nonce',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 2d880f8cb39ad0324f3461e9106c84ea5d329985..4af81f919085613e19d63f5e33bff48ff41cca1c 100644 (file)
@@ -22,9 +22,9 @@ if (!defined('LACONICA')) { exit(1); }
 /**
  * Table Definition for notice
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Notice extends DB_DataObject 
+class Notice extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -43,7 +43,7 @@ class Notice extends DB_DataObject
     public $source;                          // varchar(32)  
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Notice',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Notice',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index fe6d3d4f1dc6d6238829020087efde900d94811f..b05ee9f56e861fbd586ccf358e48947423b66a39 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for notice_source
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Notice_source extends DB_DataObject 
+class Notice_source extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -17,7 +17,7 @@ class Notice_source extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Notice_source',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Notice_source',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 3731d841456567ba6c08f217747843bf6235913e..5dca41a7ab5a5a79ccbaf11ec47bbff43025f37f 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for notice_tag
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Notice_tag extends DB_DataObject 
+class Notice_tag extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -15,7 +15,7 @@ class Notice_tag extends DB_DataObject
     public $created;                         // datetime()   not_null
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Notice_tag',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Notice_tag',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 5f88caf2c41dea018614fd772b9365ff1d31f57c..ab1880470a3cf02ade40e4f5aea31ad3c9a8622e 100644 (file)
@@ -22,9 +22,9 @@ if (!defined('LACONICA')) { exit(1); }
 /**
  * Table Definition for profile
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Profile extends DB_DataObject 
+class Profile extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -41,7 +41,7 @@ class Profile extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Profile',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Profile',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 14d2e34b578257b9c9ea09c676a0cc7485a30699..2fb5b2920aec8e96b7ff5b24adad026ab54321de 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for queue_item
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Queue_item extends DB_DataObject 
+class Queue_item extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -16,7 +16,7 @@ class Queue_item extends DB_DataObject
     public $claimed;                         // datetime()  
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Queue_item',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Queue_item',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index c84668c46b8404b41b564b7ea6f5e72fd925342e..9c86ebf020036e10b4acd8313d4540a17d441c23 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for remember_me
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Remember_me extends DB_DataObject 
+class Remember_me extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -15,7 +15,7 @@ class Remember_me extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Remember_me',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Remember_me',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index e5613125dcf5d564f5ae8aec77ecb07887a87ed6..5afc85d209eb71a4fbe2d12531cb7d170e0f928a 100644 (file)
@@ -22,9 +22,9 @@ if (!defined('LACONICA')) { exit(1); }
 /**
  * Table Definition for remote_profile
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Remote_profile extends DB_DataObject 
+class Remote_profile extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -38,7 +38,7 @@ class Remote_profile extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Remote_profile',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Remote_profile',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 8e26f1684ebcd874698e2e7ef2c865a7dabdc76e..2c364ecaeab9625e40cc2f88bfc05404fe0c39f5 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for reply
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Reply extends DB_DataObject 
+class Reply extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -16,7 +16,7 @@ class Reply extends DB_DataObject
     public $replied_id;                      // int(4)  
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Reply',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Reply',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 26a88e3602844843c5d2598d5470b6a7d9f7ef34..10ccb92837ecc5ec50b62f9107c9df36a65bb683 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for sms_carrier
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Sms_carrier extends DB_DataObject 
+class Sms_carrier extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -17,7 +17,7 @@ class Sms_carrier extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Sms_carrier',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Sms_carrier',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 2a1037d2bc1ca292f37b38c114ebb9addd164e35..cf6a3e57eb6ad98b39e2307e821e6c716cf79dcb 100644 (file)
@@ -22,9 +22,9 @@ if (!defined('LACONICA')) { exit(1); }
 /**
  * Table Definition for subscription
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Subscription extends DB_DataObject 
+class Subscription extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -38,7 +38,7 @@ class Subscription extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Subscription',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Subscription',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index a91b19f8e7dcbb464d92a0e063d0665d90d94221..ef7ee20c06c6623127c105bbe8758be6bcad4143 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for token
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class Token extends DB_DataObject 
+class Token extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -19,7 +19,7 @@ class Token extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Token',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('Token',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
index 6430697822a542858ce67a708e1bb192f7135233..ec57e52a9721e12e4e4d6770582c3a148a8c335b 100644 (file)
@@ -27,11 +27,11 @@ define('WITHFRIENDS_CACHE_WINDOW', 61);
 /**
  * Table Definition for user
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 require_once 'Validate.php';
 require_once(INSTALLDIR.'/lib/noticewrapper.php');
 
-class User extends DB_DataObject 
+class User extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -65,7 +65,7 @@ class User extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('User',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('User',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE
@@ -109,7 +109,12 @@ class User extends DB_DataObject
                }
                $qry = 'UPDATE ' . $table . ' SET ' . $toupdate .
                  ' WHERE id = ' . $this->id;
-               return $this->query($qry);
+               $orig->decache();
+               $result = $this->query($qry);
+               if ($result) {
+                       $this->encache();
+               }
+               return $result;
        }
 
        function allowed_nickname($nickname) {
index 67f6f3b2efa592e419a68ff38bbcbacd98c99b41..b65685ce79d5b0a9207bfab4ef94b0bbbad32a76 100644 (file)
@@ -2,9 +2,9 @@
 /**
  * Table Definition for user_openid
  */
-require_once 'DB/DataObject.php';
+require_once 'classes/Memcached_DataObject.php';
 
-class User_openid extends DB_DataObject 
+class User_openid extends Memcached_DataObject 
 {
     ###START_AUTOCODE
     /* the code below is auto generated do not remove the above tag */
@@ -17,7 +17,7 @@ class User_openid extends DB_DataObject
     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 
     /* Static get */
-    function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('User_openid',$k,$v); }
+    function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('User_openid',$k,$v); }
 
     /* the code above is auto generated do not remove the tag below */
     ###END_AUTOCODE