forked from Wavyzz/dolibarr
use cache
This commit is contained in:
@@ -304,16 +304,45 @@ function societe_prepare_head(Societe $object)
|
||||
$head[$h][0] = DOL_URL_ROOT.'/societe/agenda.php?socid='.$object->id;
|
||||
$head[$h][1] = $langs->trans("Events");
|
||||
if (!empty($conf->agenda->enabled) && (!empty($user->rights->agenda->myactions->read) || !empty($user->rights->agenda->allactions->read))) {
|
||||
$nbEvent = 0;
|
||||
$sql = "SELECT COUNT(id) as nb";
|
||||
$sql .= " FROM ".MAIN_DB_PREFIX."actioncomm";
|
||||
$sql .= " WHERE fk_soc = ".$object->id;
|
||||
$resql = $db->query($sql);
|
||||
if ($resql) {
|
||||
$obj = $db->fetch_object($resql);
|
||||
$nbEvent = $obj->nb;
|
||||
} else {
|
||||
dol_print_error($db);
|
||||
// Enable caching of count actioncomm
|
||||
$usecachekey = '';
|
||||
$found = false;
|
||||
if (!empty($conf->memcached->enabled) && !empty($conf->global->MEMCACHED_SERVER)) {
|
||||
// Using a memcached/memcache server
|
||||
$usecachekey = 'count_event_'.$object->id;
|
||||
} elseif (isset($conf->global->MAIN_OPTIMIZE_SPEED) && ($conf->global->MAIN_OPTIMIZE_SPEED & 0x02)) {
|
||||
// Using cache with shmop
|
||||
$usecachekey = 'count_event_'.$object->id;
|
||||
}
|
||||
if ($usecachekey) {
|
||||
require_once DOL_DOCUMENT_ROOT.'/core/lib/memory.lib.php';
|
||||
$dataretrieved = dol_getcache($usecachekey);
|
||||
if (is_array($dataretrieved) && count($dataretrieved)) {
|
||||
$nbEvent = $dataretrieved[$usecachekey];
|
||||
$found = true;
|
||||
}
|
||||
}
|
||||
if (!$found) {
|
||||
$nbEvent = 0;
|
||||
$sql = "SELECT COUNT(id) as nb";
|
||||
$sql .= " FROM ".MAIN_DB_PREFIX."actioncomm";
|
||||
$sql .= " WHERE fk_soc = ".$object->id;
|
||||
$resql = $db->query($sql);
|
||||
if ($resql) {
|
||||
$obj = $db->fetch_object($resql);
|
||||
$nbEvent = $obj->nb;
|
||||
} else {
|
||||
dol_syslog('Failed to count actioncomm '.$db->lasterror(), LOG_ERR);
|
||||
}
|
||||
if ($usecachekey) {
|
||||
$datatocache = array();
|
||||
$datatocache[$usecachekey] = $nbEvent;
|
||||
$ressetcache = dol_setcache($usecachekey, $datatocache);
|
||||
if ($ressetcache < 0) {
|
||||
$error = 'Failed to set cache for usecachekey='.$usecachekey.' result='.$ressetcache;
|
||||
dol_syslog($error, LOG_ERR);
|
||||
}
|
||||
}
|
||||
}
|
||||
$head[$h][1] .= '/';
|
||||
$head[$h][1] .= $langs->trans("Agenda");
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
<?php
|
||||
/* Copyright (C) 2009-2010 Laurent Destailleur <eldy@users.sourceforge.net>
|
||||
* Copyright (C) 2021 Frédéric France <frederic.france@netlogic.fr>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
@@ -23,11 +24,34 @@
|
||||
|
||||
global $shmkeys, $shmoffset;
|
||||
|
||||
$shmkeys = array('main'=>1, 'admin'=>2, 'dict'=>3, 'companies'=>4, 'suppliers'=>5, 'products'=>6,
|
||||
'commercial'=>7, 'compta'=>8, 'projects'=>9, 'cashdesk'=>10, 'agenda'=>11, 'bills'=>12,
|
||||
'propal'=>13, 'boxes'=>14, 'banks'=>15, 'other'=>16, 'errors'=>17, 'members'=>18, 'ecm'=>19,
|
||||
'orders'=>20, 'users'=>21, 'help'=>22, 'stocks'=>23, 'interventions'=>24,
|
||||
'donations'=>25, 'contracts'=>26);
|
||||
$shmkeys = array(
|
||||
'main' => 1,
|
||||
'admin' => 2,
|
||||
'dict' => 3,
|
||||
'companies' => 4,
|
||||
'suppliers' => 5,
|
||||
'products' => 6,
|
||||
'commercial' => 7,
|
||||
'compta' => 8,
|
||||
'projects' => 9,
|
||||
'cashdesk' => 10,
|
||||
'agenda' => 11,
|
||||
'bills' => 12,
|
||||
'propal' => 13,
|
||||
'boxes' => 14,
|
||||
'banks' => 15,
|
||||
'other' => 16,
|
||||
'errors' => 17,
|
||||
'members' => 18,
|
||||
'ecm' => 19,
|
||||
'orders' => 20,
|
||||
'users' => 21,
|
||||
'help' => 22,
|
||||
'stocks' => 23,
|
||||
'interventions' => 24,
|
||||
'donations' => 25,
|
||||
'contracts' => 26,
|
||||
);
|
||||
$shmoffset = 1000; // Max number of entries found into a language file. If too low, some entries will be overwritten.
|
||||
|
||||
|
||||
@@ -44,51 +68,45 @@ function dol_setcache($memoryid, $data)
|
||||
global $conf;
|
||||
$result = 0;
|
||||
|
||||
// Using a memcached server
|
||||
if (!empty($conf->memcached->enabled) && class_exists('Memcached'))
|
||||
{
|
||||
if (!empty($conf->memcached->enabled) && class_exists('Memcached')) {
|
||||
// Using a memcached server
|
||||
global $dolmemcache;
|
||||
if (empty($dolmemcache) || !is_object($dolmemcache))
|
||||
{
|
||||
$dolmemcache = new Memcached();
|
||||
$tmparray = explode(':', $conf->global->MEMCACHED_SERVER);
|
||||
$result = $dolmemcache->addServer($tmparray[0], $tmparray[1] ? $tmparray[1] : 11211);
|
||||
if (!$result) return -1;
|
||||
}
|
||||
if (empty($dolmemcache) || !is_object($dolmemcache)) {
|
||||
$dolmemcache = new Memcached();
|
||||
$tmparray = explode(':', $conf->global->MEMCACHED_SERVER);
|
||||
$result = $dolmemcache->addServer($tmparray[0], $tmparray[1] ? $tmparray[1] : 11211);
|
||||
if (!$result) return -1;
|
||||
}
|
||||
|
||||
$memoryid = session_name().'_'.$memoryid;
|
||||
$memoryid = session_name() . '_' . $memoryid;
|
||||
//$dolmemcache->setOption(Memcached::OPT_COMPRESSION, false);
|
||||
$dolmemcache->add($memoryid, $data); // This fails if key already exists
|
||||
$rescode = $dolmemcache->getResultCode();
|
||||
if ($rescode == 0)
|
||||
{
|
||||
if ($rescode == 0) {
|
||||
return count($data);
|
||||
} else {
|
||||
return -$rescode;
|
||||
}
|
||||
} elseif (!empty($conf->memcached->enabled) && class_exists('Memcache'))
|
||||
{
|
||||
} elseif (!empty($conf->memcached->enabled) && class_exists('Memcache')) {
|
||||
// Using a memcache server
|
||||
global $dolmemcache;
|
||||
if (empty($dolmemcache) || !is_object($dolmemcache))
|
||||
{
|
||||
$dolmemcache = new Memcache();
|
||||
$tmparray = explode(':', $conf->global->MEMCACHED_SERVER);
|
||||
$result = $dolmemcache->addServer($tmparray[0], $tmparray[1] ? $tmparray[1] : 11211);
|
||||
if (!$result) return -1;
|
||||
}
|
||||
if (empty($dolmemcache) || !is_object($dolmemcache)) {
|
||||
$dolmemcache = new Memcache();
|
||||
$tmparray = explode(':', $conf->global->MEMCACHED_SERVER);
|
||||
$result = $dolmemcache->addServer($tmparray[0], $tmparray[1] ? $tmparray[1] : 11211);
|
||||
if (!$result) return -1;
|
||||
}
|
||||
|
||||
$memoryid = session_name().'_'.$memoryid;
|
||||
$memoryid = session_name() . '_' . $memoryid;
|
||||
//$dolmemcache->setOption(Memcached::OPT_COMPRESSION, false);
|
||||
$result = $dolmemcache->add($memoryid, $data); // This fails if key already exists
|
||||
if ($result)
|
||||
{
|
||||
if ($result) {
|
||||
return count($data);
|
||||
} else {
|
||||
return -1;
|
||||
}
|
||||
} // Using shmop
|
||||
elseif (isset($conf->global->MAIN_OPTIMIZE_SPEED) && ($conf->global->MAIN_OPTIMIZE_SPEED & 0x02))
|
||||
{
|
||||
} elseif (isset($conf->global->MAIN_OPTIMIZE_SPEED) && ($conf->global->MAIN_OPTIMIZE_SPEED & 0x02)) {
|
||||
// Using shmop
|
||||
$result = dol_setshmop($memoryid, $data);
|
||||
}
|
||||
|
||||
@@ -106,55 +124,48 @@ function dol_getcache($memoryid)
|
||||
global $conf;
|
||||
|
||||
// Using a memcached server
|
||||
if (!empty($conf->memcached->enabled) && class_exists('Memcached'))
|
||||
{
|
||||
if (!empty($conf->memcached->enabled) && class_exists('Memcached')) {
|
||||
global $m;
|
||||
if (empty($m) || !is_object($m))
|
||||
{
|
||||
if (empty($m) || !is_object($m)) {
|
||||
$m = new Memcached();
|
||||
$tmparray = explode(':', $conf->global->MEMCACHED_SERVER);
|
||||
$result = $m->addServer($tmparray[0], $tmparray[1] ? $tmparray[1] : 11211);
|
||||
if (!$result) return -1;
|
||||
}
|
||||
$tmparray = explode(':', $conf->global->MEMCACHED_SERVER);
|
||||
$result = $m->addServer($tmparray[0], $tmparray[1] ? $tmparray[1] : 11211);
|
||||
if (!$result) return -1;
|
||||
}
|
||||
|
||||
$memoryid = session_name().'_'.$memoryid;
|
||||
$memoryid = session_name() . '_' . $memoryid;
|
||||
//$m->setOption(Memcached::OPT_COMPRESSION, false);
|
||||
//print "Get memoryid=".$memoryid;
|
||||
$data = $m->get($memoryid);
|
||||
$rescode = $m->getResultCode();
|
||||
//print "memoryid=".$memoryid." - rescode=".$rescode." - data=".count($data)."\n<br>";
|
||||
//var_dump($data);
|
||||
if ($rescode == 0)
|
||||
{
|
||||
if ($rescode == 0) {
|
||||
return $data;
|
||||
} else {
|
||||
return -$rescode;
|
||||
}
|
||||
} elseif (!empty($conf->memcached->enabled) && class_exists('Memcache'))
|
||||
{
|
||||
} elseif (!empty($conf->memcached->enabled) && class_exists('Memcache')) {
|
||||
global $m;
|
||||
if (empty($m) || !is_object($m))
|
||||
{
|
||||
$m = new Memcache();
|
||||
$tmparray = explode(':', $conf->global->MEMCACHED_SERVER);
|
||||
$result = $m->addServer($tmparray[0], $tmparray[1] ? $tmparray[1] : 11211);
|
||||
if (!$result) return -1;
|
||||
}
|
||||
if (empty($m) || !is_object($m)) {
|
||||
$m = new Memcache();
|
||||
$tmparray = explode(':', $conf->global->MEMCACHED_SERVER);
|
||||
$result = $m->addServer($tmparray[0], $tmparray[1] ? $tmparray[1] : 11211);
|
||||
if (!$result) return -1;
|
||||
}
|
||||
|
||||
$memoryid = session_name().'_'.$memoryid;
|
||||
$memoryid = session_name() . '_' . $memoryid;
|
||||
//$m->setOption(Memcached::OPT_COMPRESSION, false);
|
||||
$data = $m->get($memoryid);
|
||||
//print "memoryid=".$memoryid." - rescode=".$rescode." - data=".count($data)."\n<br>";
|
||||
//var_dump($data);
|
||||
if ($data)
|
||||
{
|
||||
if ($data) {
|
||||
return $data;
|
||||
} else {
|
||||
return -1;
|
||||
}
|
||||
} // Using shmop
|
||||
elseif (isset($conf->global->MAIN_OPTIMIZE_SPEED) && ($conf->global->MAIN_OPTIMIZE_SPEED & 0x02))
|
||||
{
|
||||
} elseif (isset($conf->global->MAIN_OPTIMIZE_SPEED) && ($conf->global->MAIN_OPTIMIZE_SPEED & 0x02)) {
|
||||
// Using shmop
|
||||
$data = dol_getshmop($memoryid);
|
||||
return $data;
|
||||
}
|
||||
@@ -173,7 +184,9 @@ function dol_getcache($memoryid)
|
||||
function dol_getshmopaddress($memoryid)
|
||||
{
|
||||
global $shmkeys, $shmoffset;
|
||||
if (empty($shmkeys[$memoryid])) return 0;
|
||||
if (empty($shmkeys[$memoryid])) {
|
||||
return 0;
|
||||
}
|
||||
return $shmkeys[$memoryid] + $shmoffset;
|
||||
}
|
||||
|
||||
@@ -187,10 +200,11 @@ function dol_listshmop()
|
||||
global $shmkeys, $shmoffset;
|
||||
|
||||
$resarray = array();
|
||||
foreach ($shmkeys as $key => $val)
|
||||
{
|
||||
foreach ($shmkeys as $key => $val) {
|
||||
$result = dol_getshmop($key);
|
||||
if (!is_numeric($result) || $result > 0) $resarray[$key] = $result;
|
||||
if (!is_numeric($result) || $result > 0) {
|
||||
$resarray[$key] = $result;
|
||||
}
|
||||
}
|
||||
return $resarray;
|
||||
}
|
||||
@@ -213,18 +227,16 @@ function dol_setshmop($memoryid, $data)
|
||||
$size = strlen($newdata);
|
||||
//print 'dol_setshmop memoryid='.$memoryid." shmkey=".$shmkey." newdata=".$size."bytes<br>\n";
|
||||
$handle = shmop_open($shmkey, 'c', 0644, 6 + $size);
|
||||
if ($handle)
|
||||
{
|
||||
if ($handle) {
|
||||
$shm_bytes_written1 = shmop_write($handle, str_pad($size, 6), 0);
|
||||
$shm_bytes_written2 = shmop_write($handle, $newdata, 6);
|
||||
if (($shm_bytes_written1 + $shm_bytes_written2) != (6 + dol_strlen($newdata)))
|
||||
{
|
||||
print "Couldn't write the entire length of data\n";
|
||||
if (($shm_bytes_written1 + $shm_bytes_written2) != (6 + dol_strlen($newdata))) {
|
||||
print "Couldn't write the entire length of data\n";
|
||||
}
|
||||
shmop_close($handle);
|
||||
return ($shm_bytes_written1 + $shm_bytes_written2);
|
||||
} else {
|
||||
print 'Error in shmop_open for memoryid='.$memoryid.' shmkey='.$shmkey.' 6+size=6+'.$size;
|
||||
print 'Error in shmop_open for memoryid=' . $memoryid . ' shmkey=' . $shmkey . ' 6+size=6+' . $size;
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
@@ -243,8 +255,7 @@ function dol_getshmop($memoryid)
|
||||
$shmkey = dol_getshmopaddress($memoryid);
|
||||
//print 'dol_getshmop memoryid='.$memoryid." shmkey=".$shmkey."<br>\n";
|
||||
$handle = @shmop_open($shmkey, 'a', 0, 0);
|
||||
if ($handle)
|
||||
{
|
||||
if ($handle) {
|
||||
$size = trim(shmop_read($handle, 0, 6));
|
||||
if ($size) $data = unserialize(shmop_read($handle, 6, $size));
|
||||
else return -1;
|
||||
|
||||
Reference in New Issue
Block a user