diff --git a/phpgwapi/inc/class.contenthistory.inc.php b/phpgwapi/inc/class.contenthistory.inc.php index 85a1dcb9ea..7b8338af7a 100644 --- a/phpgwapi/inc/class.contenthistory.inc.php +++ b/phpgwapi/inc/class.contenthistory.inc.php @@ -1,199 +1,173 @@ db = $GLOBALS['egw']->db; + } + + /** + * mark mapping as expired + * + * mark a mapping from externel to internal id as expired, when + * a egw entry gets deleted + * + * @param string $_appName the appname example: infolog_notes + * @param int $_id the internal egwapp content id + * @return bool + */ + function expireMapping($_appName, $_id) + { + return !!$this->db->update('egw_contentmap',array ( + 'map_expired' => 1, + ),array ( + 'map_guid' => $GLOBALS['egw']->common->generate_uid($_appName, $_id), + ),__LINE__,__FILE__); + } /** - * class to maintain history of content - * - * This class contains all logic of the egw content history. - * @package phpgwapi - * @author Lars Kneschke - * @version 1.35 - * @copyright Lars Kneschke 2005 - * @license http://opensource.org/licenses/gpl-license.php GPL - */ - class contenthistory + * get the timestamp for action + * + * find which content changed since $_ts for application $_appName + * + * @param string$_appName the appname example: infolog_notes + * @param string $_action can be modify, add or delete + * @param string $_ts timestamp where to start searching from + * @return array containing the global UID's + */ + function getHistory($_appName, $_action, $_ts) { - /** - * @var db-object $this->db - */ - var $db; - - function contenthistory() + $where = array('sync_appname' => $_appName); + + switch($_action) { - $this->db = clone($GLOBALS['egw']->db); - $this->db->set_app('phpgwapi'); - $this->table = 'egw_api_content_history'; + case 'modify': + $where[] = "sync_modified > '".$this->db->to_timestamp($_ts)."' AND sync_deleted IS NULL"; + break; + case 'delete': + $where[] = "sync_deleted > '".$this->db->to_timestamp($_ts)."'"; + break; + case 'add': + $where[] = "sync_added > '".$this->db->to_timestamp($_ts)."' AND sync_deleted IS NULL AND sync_modified IS NULL"; + break; + default: + // no valid $_action set + return array(); + } + $guidList = array(); + foreach($this->db->select(self::TABLE,'sync_guid',$where,__LINE__,__FILE__) as $row) + { + $guidList[] = $row['sync_guid']; } - /** - * mark mapping as expired - * - * mark a mapping from externel to internal id as expired, when - * a egw entry gets deleted - * - * @param $_appName string the appname example: infolog_notes - * @param $_id int the internal egwapp content id - * @return bool - */ - function expireMapping($_appName, $_id) - { - $where = array ( - 'map_guid' => $GLOBALS['egw']->common->generate_uid($_appName, $_id), - ); - - $newData = array ( - 'map_expired' => 1, - ); - - if(!$this->db->update('egw_contentmap',$newData,$where,__LINE__,__FILE__)) - return FALSE; - else - return TRUE; - } - - /** - * get the timestamp for action - * - * find which content changed since $_ts for application $_appName - * - * @param $_appName string the appname example: infolog_notes - * @param $_action string can be modify, add or delete - * @param $_ts string timestamp where to start searching from - * @return array containing the global UID's - */ - function getHistory($_appName, $_action, $_ts) - { - $query = "select sync_guid from egw_api_content_history where sync_appname = '".$this->db->db_addslashes($_appName)."' and "; - - switch($_action) - { - case 'modify': - $query .= "sync_modified > '".$this->db->to_timestamp($_ts)."' and sync_deleted is null"; - break; - case 'delete': - $query .= "sync_deleted > '".$this->db->to_timestamp($_ts)."'"; - break; - case 'add': - $query .= "sync_added > '".$this->db->to_timestamp($_ts)."' and sync_deleted is null and sync_modified is null"; - break; - default: - // no valid $_action set - return array(); - break; - } - #Horde::logMessage("SymcML: egwcontactssync $query", __FILE__, __LINE__, PEAR_LOG_DEBUG); - $this->db->query($query, __LINE__, __FILE__); - - $guidList = array(); - - while($this->db->next_record()) - { - $guidList[] = $this->db->f('sync_guid'); - } - - return $guidList; - } - - /** - * when got a entry last added/modified/deleted - * - * @param $_guid string the global uid of the entry - * @param $_action string can be add, delete or modify - * @return string the last timestamp - */ - function getTSforAction($_guid, $_action) - { - $where = array ( - 'sync_guid' => $_guid, - ); - - $this->db->select($this->table,array('sync_added','sync_modified','sync_deleted'),$where,__LINE__,__FILE__); - if($this->db->next_record()) - { - switch($_action) - { - case 'add': - return $this->db->from_timestamp($this->db->f('sync_added')); - break; - case 'delete': - return $this->db->from_timestamp($this->db->f('sync_deleted')); - break; - case 'modify': - return $this->db->from_timestamp($this->db->f('sync_modified')); - break; - default: - return false; - } - } - - return false; - } - - /** - * update a timestamp for action - * - * @param $_appName string the appname example: infolog_notes - * @param $_id int the app internal content id - * @param $_action string can be modify, add or delete - * @param $_ts string timestamp where to start searching from - * @return boolean returns allways true - */ - function updateTimeStamp($_appName, $_id, $_action, $_ts) - { - $_ts = $this->db->to_timestamp($_ts); - - $newData = array ( - 'sync_appname' => $_appName, - 'sync_contentid' => $_id, - 'sync_added' => $_ts, - 'sync_guid' => $GLOBALS['egw']->common->generate_uid($_appName, $_id), - 'sync_changedby' => $GLOBALS['egw_info']['user']['account_id'], - ); - - switch($_action) - { - case 'add': - $this->db->insert($this->table,$newData,array(),__LINE__,__FILE__); - break; - - case 'modify': - case 'delete': - // first check that this entry got ever added to database already - $where = array ( - 'sync_appname' => $_appName, - 'sync_contentid' => $_id, - ); - - $this->db->select($this->table,'sync_contentid',$where,__LINE__,__FILE__); - if(!$this->db->next_record()) - { - $this->db->insert($this->table,$newData,array(),__LINE__,__FILE__); - } - - #$this->db->select($this->table,'sync_added',$where,__LINE__,__FILE__); - #$this->db->next_record(); - #$syncAdded = $this->db->f('sync_added'); - - // now update the time stamp - $newData = array ( - 'sync_changedby' => $GLOBALS['egw_info']['user']['account_id'], - $_action == 'modify' ? 'sync_modified' : 'sync_deleted' => $_ts , - # 'sync_added' => $syncAdded, - ); - $this->db->update($this->table, $newData, $where,__LINE__,__FILE__); - break; - } - - return true; - } + return $guidList; } -?> + + /** + * when got a entry last added/modified/deleted + * + * @param $_guid string the global uid of the entry + * @param $_action string can be add, delete or modify + * @return string the last timestamp + */ + function getTSforAction($_guid, $_action) + { + switch($_action) + { + case 'add': + $col = 'sync_added'; + break; + case 'delete': + $col = 'sync_deleted'; + break; + case 'modify': + $col = 'sync_modified'; + break; + default: + return false; + } + $where = array ( + 'sync_guid' => $_guid, + ); + + if (($ts = $this->db->select(self::TABLE,$col,$where,__LINE__,__FILE__)->fetchSingle())) + { + $ts = $this->db->from_timestamp($ts); + } + return $ts; + } + + /** + * update a timestamp for action + * + * @param string $_appName the appname example: infolog_notes + * @param int $_id the app internal content id + * @param string $_action can be modify, add or delete + * @param string $_ts timestamp where to start searching from + * @return boolean returns allways true + */ + function updateTimeStamp($_appName, $_id, $_action, $_ts) + { + $newData = array ( + 'sync_appname' => $_appName, + 'sync_contentid' => $_id, + 'sync_added' => $this->db->to_timestamp($_ts), + 'sync_guid' => $GLOBALS['egw']->common->generate_uid($_appName, $_id), + 'sync_changedby' => $GLOBALS['egw_info']['user']['account_id'], + ); + + switch($_action) + { + case 'add': + $this->db->insert(self::TABLE,$newData,array(),__LINE__,__FILE__); + break; + + case 'modify': + case 'delete': + // first check that this entry got ever added to database already + $where = array ( + 'sync_appname' => $_appName, + 'sync_contentid' => $_id, + ); + + if (!$this->db->select(self::TABLE,'sync_contentid',$where,__LINE__,__FILE__)->fetchSingle()) + { + $this->db->insert(self::TABLE,$newData,array(),__LINE__,__FILE__); + } + + // now update the time stamp + $newData = array ( + 'sync_changedby' => $GLOBALS['egw_info']['user']['account_id'], + $_action == 'modify' ? 'sync_modified' : 'sync_deleted' => $_ts , + ); + $this->db->update(self::TABLE, $newData, $where,__LINE__,__FILE__); + break; + } + return true; + } +}