mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-05 05:29:13 +01:00
store folder-hashes via state-maschine in db
This commit is contained in:
parent
ab02df94d4
commit
17e8473e6e
@ -1970,11 +1970,33 @@ class mail_zpush implements activesync_plugin_write, activesync_plugin_sendmail,
|
|||||||
|
|
||||||
private $folderHashes;
|
private $folderHashes;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Statemaschine instance used to store folders
|
||||||
|
*
|
||||||
|
* @var activesync_statemaschine
|
||||||
|
*/
|
||||||
|
private $fh_state_maschine;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* state_type (and _key) used to store folder hashes
|
||||||
|
*/
|
||||||
|
const FOLDER_STATE_TYPE = 'folder_hashes';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Read hashfile from state dir
|
* Read hashfile from state dir
|
||||||
*/
|
*/
|
||||||
private function readFolderHashes()
|
private function readFolderHashes()
|
||||||
{
|
{
|
||||||
|
if (!isset($this->fh_state_maschine))
|
||||||
|
{
|
||||||
|
$this->fh_state_maschine = new activesync_statemachine($this->backend);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
$this->folderHashes = $this->fh_state_maschine->getState(Request::GetDeviceID(),
|
||||||
|
self::FOLDER_STATE_TYPE, self::FOLDER_STATE_TYPE, 0);
|
||||||
|
}
|
||||||
|
catch (Exception $e) {
|
||||||
|
_egw_log_exception($e);
|
||||||
if ((file_exists($file = $this->hashFile()) || file_exists($file = $this->hashFile(true))) &&
|
if ((file_exists($file = $this->hashFile()) || file_exists($file = $this->hashFile(true))) &&
|
||||||
($hashes = file_get_contents($file)))
|
($hashes = file_get_contents($file)))
|
||||||
{
|
{
|
||||||
@ -1985,22 +2007,41 @@ class mail_zpush implements activesync_plugin_write, activesync_plugin_sendmail,
|
|||||||
//error_log(__METHOD__.__LINE__." error decoding with json");
|
//error_log(__METHOD__.__LINE__." error decoding with json");
|
||||||
$this->folderHashes = unserialize($hashes);
|
$this->folderHashes = unserialize($hashes);
|
||||||
}
|
}
|
||||||
|
// store folder-hashes to state
|
||||||
|
try {
|
||||||
|
$this->storeFolderHashes();
|
||||||
|
}
|
||||||
|
catch(Exception $e) {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$this->folderHashes = array();
|
$this->folderHashes = array();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Store hashfile in state dir
|
* Store hashfile via state-maschine
|
||||||
*
|
*
|
||||||
* return int|boolean false on error
|
* return int|boolean false on error
|
||||||
*/
|
*/
|
||||||
private function storeFolderHashes()
|
private function storeFolderHashes()
|
||||||
{
|
{
|
||||||
// make sure $this->folderHashes is an array otherwise json_encode may fail on decode for string,integer,float or boolean
|
if (!isset($this->fh_state_maschine))
|
||||||
return file_put_contents($this->hashFile(), json_encode((is_array($this->folderHashes)?$this->folderHashes:array($this->folderHashes))));
|
{
|
||||||
|
$this->fh_state_maschine = new activesync_statemachine($this->backend);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
$this->fh_state_maschine->setState($this->folderHashes, Request::GetDeviceID(),
|
||||||
|
self::FOLDER_STATE_TYPE, self::FOLDER_STATE_TYPE, 0);
|
||||||
|
}
|
||||||
|
catch (Exception $e) {
|
||||||
|
_egw_log_exception($e);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user