41 private $nbupdated = 0;
43 private $nbdeleted = 0;
45 private $errorCount = 0;
47 private $errorMessages = array();
66 $prefix = $this->db->prefix();
68 $arrayofpolicies = array(
70 'tiers_client' => array(
71 'group' =>
'ThirdParty',
72 'label_key' =>
'DATAPOLICY_TIERS_CLIENT',
73 'picto' =>
img_picto(
'',
'company',
'class="pictofixedwidth"'),
75 'const_anonymize' =>
'DATAPOLICY_TIERS_CLIENT_ANONYMIZE_DELAY',
76 'sql_template' =>
"SELECT s.rowid FROM ".$prefix.
"societe as s WHERE s.entity = __ENTITY__ AND s.client = ".
Societe::CUSTOMER.
" AND s.fournisseur = 0 AND s.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_soc = s.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
78 'file' => DOL_DOCUMENT_ROOT .
'/societe/class/societe.class.php',
79 'anonymize_fields' => array(
'name' =>
'MAKEANONYMOUS',
'name_alias' =>
'MAKEANONYMOUS',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'url' =>
'---',
'fax' =>
'---',
'siret' =>
'---',
'siren' =>
'---',
'ape' =>
'---',
'idprof4' =>
'---',
'idprof5' =>
'---',
'idprof6' =>
'---',
'tva_intra' =>
'---',
'capital' => 0,
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
80 'call_params' => array(
81 'delete' => array(
'id',
'user'),
82 'update' => array(
'id',
'user')
85 'tiers_prospect' => array(
86 'group' =>
'ThirdParty',
87 'label_key' =>
'DATAPOLICY_TIERS_PROSPECT',
88 'picto' =>
img_picto(
'',
'company',
'class="pictofixedwidth"'),
90 'const_anonymize' =>
'DATAPOLICY_TIERS_PROSPECT_ANONYMIZE_DELAY',
91 'sql_template' =>
"SELECT s.rowid FROM ".$prefix.
"societe as s WHERE s.entity = __ENTITY__ AND s.client = ".
Societe::PROSPECT.
" AND s.fournisseur = 0 AND s.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_soc = s.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
93 'file' => DOL_DOCUMENT_ROOT .
'/societe/class/societe.class.php',
94 'anonymize_fields' => array(
'name' =>
'MAKEANONYMOUS',
'name_alias' =>
'MAKEANONYMOUS',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'url' =>
'---',
'fax' =>
'---',
'siret' =>
'---',
'siren' =>
'---',
'ape' =>
'---',
'idprof4' =>
'---',
'idprof5' =>
'---',
'idprof6' =>
'---',
'tva_intra' =>
'---',
'capital' => 0,
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
95 'call_params' => array(
96 'delete' => array(
'id',
'user'),
97 'update' => array(
'id',
'user')
100 'tiers_prospect_client' => array(
101 'group' =>
'ThirdParty',
102 'label_key' =>
'DATAPOLICY_TIERS_PROSPECT_CLIENT',
103 'picto' =>
img_picto(
'',
'company',
'class="pictofixedwidth"'),
104 'const_delete' =>
'',
105 'const_anonymize' =>
'DATAPOLICY_TIERS_PROSPECT_CLIENT_ANONYMIZE_DELAY',
106 'sql_template' =>
"SELECT s.rowid FROM ".$prefix.
"societe as s WHERE s.entity = __ENTITY__ AND s.client = ".
Societe::CUSTOMER_AND_PROSPECT.
" AND s.fournisseur = 0 AND s.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_soc = s.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
107 'class' =>
'Societe',
108 'file' => DOL_DOCUMENT_ROOT .
'/societe/class/societe.class.php',
109 'anonymize_fields' => array(
'name' =>
'MAKEANONYMOUS',
'name_alias' =>
'MAKEANONYMOUS',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'url' =>
'---',
'fax' =>
'---',
'siret' =>
'---',
'siren' =>
'---',
'ape' =>
'---',
'idprof4' =>
'---',
'idprof5' =>
'---',
'idprof6' =>
'---',
'tva_intra' =>
'---',
'capital' => 0,
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
110 'call_params' => array(
111 'delete' => array(
'id',
'user'),
112 'update' => array(
'id',
'user')
115 'tiers_niprosp_niclient' => array(
116 'group' =>
'ThirdParty',
117 'label_key' =>
'DATAPOLICY_TIERS_NIPROSPECT_NICLIENT',
118 'picto' =>
img_picto(
'',
'company',
'class="pictofixedwidth"'),
119 'const_delete' =>
'DATAPOLICY_TIERS_NIPROSPECT_NICLIENT_DELETE_DELAY',
120 'const_anonymize' =>
'DATAPOLICY_TIERS_NIPROSPECT_NICLIENT_ANONYMIZE_DELAY',
121 'sql_template' =>
"SELECT s.rowid FROM ".$prefix.
"societe as s WHERE s.entity = __ENTITY__ AND s.client = ".
Societe::NO_CUSTOMER.
" AND s.fournisseur = 0 AND s.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_soc = s.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
122 'sql_template_delete' =>
"SELECT s.rowid FROM ".$prefix.
"societe as s WHERE s.entity = __ENTITY__ AND s.client = ".
Societe::NO_CUSTOMER.
" AND s.fournisseur = 0 AND s.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_soc = s.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
123 'class' =>
'Societe',
124 'file' => DOL_DOCUMENT_ROOT .
'/societe/class/societe.class.php',
125 'anonymize_fields' => array(
'name' =>
'MAKEANONYMOUS',
'name_alias' =>
'MAKEANONYMOUS',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'url' =>
'---',
'fax' =>
'---',
'siret' =>
'---',
'siren' =>
'---',
'ape' =>
'---',
'idprof4' =>
'---',
'idprof5' =>
'---',
'idprof6' =>
'---',
'tva_intra' =>
'---',
'capital' => 0,
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
126 'call_params' => array(
127 'delete' => array(
'id',
'user'),
128 'update' => array(
'id',
'user')
131 'tiers_fournisseur' => array(
132 'group' =>
'ThirdParty',
133 'label_key' =>
'DATAPOLICY_TIERS_FOURNISSEUR',
134 'picto' =>
img_picto(
'',
'supplier',
'class="pictofixedwidth"'),
135 'const_delete' =>
'',
136 'const_anonymize' =>
'DATAPOLICY_TIERS_FOURNISSEUR_ANONYMIZE_DELAY',
141 'sql_template' =>
"SELECT s.rowid FROM ".$prefix.
"societe as s WHERE s.entity = __ENTITY__ AND s.fournisseur = 1 AND s.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_soc = s.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture_fourn as f WHERE f.fk_soc = s.rowid)",
142 'class' =>
'Societe',
143 'file' => DOL_DOCUMENT_ROOT .
'/societe/class/societe.class.php',
144 'anonymize_fields' => array(
'name' =>
'MAKEANONYMOUS',
'name_alias' =>
'MAKEANONYMOUS',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'url' =>
'---',
'fax' =>
'---',
'siret' =>
'---',
'siren' =>
'---',
'ape' =>
'---',
'idprof4' =>
'---',
'idprof5' =>
'---',
'idprof6' =>
'---',
'tva_intra' =>
'---',
'capital' => 0,
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
145 'call_params' => array(
146 'delete' => array(
'id',
'user'),
147 'update' => array(
'id',
'user')
151 'contact_client' => array(
152 'group' =>
'Contact',
153 'label_key' =>
'DATAPOLICY_CONTACT_CLIENT',
154 'picto' =>
img_picto(
'',
'contact',
'class="pictofixedwidth"'),
155 'const_delete' =>
'',
156 'const_anonymize' =>
'DATAPOLICY_CONTACT_CLIENT_ANONYMIZE_DELAY',
157 'sql_template' =>
"SELECT c.rowid FROM ".$prefix.
"socpeople as c INNER JOIN ".$prefix.
"societe as s ON s.rowid = c.fk_soc WHERE c.entity = __ENTITY__ AND c.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND s.client = ".
Societe::CUSTOMER.
" AND s.fournisseur = 0 AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_contact = c.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
158 'class' =>
'Contact',
159 'file' => DOL_DOCUMENT_ROOT .
'/contact/class/contact.class.php',
160 'anonymize_fields' => array(
'lastname' =>
'MAKEANONYMOUS',
'firstname' =>
'MAKEANONYMOUS',
'poste' =>
'---',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone_pro' =>
'---',
'phone_perso' =>
'---',
'phone_mobile' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'photo' =>
'',
'url' =>
'---',
'fax' =>
'---',
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
161 'call_params' => array(
162 'delete' => array(
'user'),
163 'update' => array(
'id',
'user')
166 'contact_prospect' => array(
167 'group' =>
'Contact',
168 'label_key' =>
'DATAPOLICY_CONTACT_PROSPECT',
169 'picto' =>
img_picto(
'',
'contact',
'class="pictofixedwidth"'),
170 'const_delete' =>
'',
171 'const_anonymize' =>
'DATAPOLICY_CONTACT_PROSPECT_ANONYMIZE_DELAY',
172 'sql_template' =>
"SELECT c.rowid FROM ".$prefix.
"socpeople as c INNER JOIN ".$prefix.
"societe as s ON s.rowid = c.fk_soc WHERE c.entity = __ENTITY__ AND c.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND s.client = ".
Societe::PROSPECT.
" AND s.fournisseur = 0 AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_contact = c.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
173 'class' =>
'Contact',
174 'file' => DOL_DOCUMENT_ROOT .
'/contact/class/contact.class.php',
175 'anonymize_fields' => array(
'lastname' =>
'MAKEANONYMOUS',
'firstname' =>
'MAKEANONYMOUS',
'poste' =>
'---',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone_pro' =>
'---',
'phone_perso' =>
'---',
'phone_mobile' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'photo' =>
'',
'url' =>
'---',
'fax' =>
'---',
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
176 'call_params' => array(
177 'delete' => array(
'user'),
178 'update' => array(
'id',
'user')
181 'contact_prospect_client' => array(
182 'group' =>
'Contact',
183 'label_key' =>
'DATAPOLICY_CONTACT_PROSPECT_CLIENT',
184 'picto' =>
img_picto(
'',
'contact',
'class="pictofixedwidth"'),
185 'const_delete' =>
'',
186 'const_anonymize' =>
'DATAPOLICY_CONTACT_PROSPECT_CLIENT_ANONYMIZE_DELAY',
187 'sql_template' =>
"SELECT c.rowid FROM ".$prefix.
"socpeople as c INNER JOIN ".$prefix.
"societe as s ON s.rowid = c.fk_soc WHERE c.entity = __ENTITY__ AND c.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND s.client = ".
Societe::CUSTOMER_AND_PROSPECT.
" AND s.fournisseur = 0 AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_contact = c.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
188 'class' =>
'Contact',
189 'file' => DOL_DOCUMENT_ROOT .
'/contact/class/contact.class.php',
190 'anonymize_fields' => array(
'lastname' =>
'MAKEANONYMOUS',
'firstname' =>
'MAKEANONYMOUS',
'poste' =>
'---',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone_pro' =>
'---',
'phone_perso' =>
'---',
'phone_mobile' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'photo' =>
'',
'url' =>
'---',
'fax' =>
'---',
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
191 'call_params' => array(
192 'delete' => array(
'user'),
193 'update' => array(
'id',
'user')
196 'contact_niprosp_niclient' => array(
197 'group' =>
'Contact',
198 'label_key' =>
'DATAPOLICY_CONTACT_NIPROSPECT_NICLIENT',
199 'picto' =>
img_picto(
'',
'contact',
'class="pictofixedwidth"'),
200 'const_delete' =>
'',
201 'const_anonymize' =>
'DATAPOLICY_CONTACT_NIPROSPECT_NICLIENT_ANONYMIZE_DELAY',
202 'sql_template' =>
"SELECT c.rowid FROM ".$prefix.
"socpeople as c INNER JOIN ".$prefix.
"societe as s ON s.rowid = c.fk_soc WHERE c.entity = __ENTITY__ AND c.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND s.client = ".
Societe::NO_CUSTOMER.
" AND s.fournisseur = 0 AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_contact = c.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture as f WHERE f.fk_soc = s.rowid)",
203 'class' =>
'Contact',
204 'file' => DOL_DOCUMENT_ROOT .
'/contact/class/contact.class.php',
205 'anonymize_fields' => array(
'lastname' =>
'MAKEANONYMOUS',
'firstname' =>
'MAKEANONYMOUS',
'poste' =>
'---',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone_pro' =>
'---',
'phone_perso' =>
'---',
'phone_mobile' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'photo' =>
'',
'url' =>
'---',
'fax' =>
'---',
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
206 'call_params' => array(
207 'delete' => array(
'user'),
208 'update' => array(
'id',
'user')
211 'contact_fournisseur' => array(
212 'group' =>
'Contact',
213 'label_key' =>
'DATAPOLICY_CONTACT_FOURNISSEUR',
214 'picto' =>
img_picto(
'',
'contact',
'class="pictofixedwidth"'),
215 'const_delete' =>
'',
216 'const_anonymize' =>
'DATAPOLICY_CONTACT_FOURNISSEUR_ANONYMIZE_DELAY',
219 'sql_template' =>
"SELECT c.rowid FROM ".$prefix.
"socpeople as c INNER JOIN ".$prefix.
"societe as s ON s.rowid = c.fk_soc WHERE c.entity = __ENTITY__ AND c.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND s.fournisseur = 1 AND NOT EXISTS (SELECT a.id FROM ".$prefix.
"actioncomm as a WHERE a.fk_contact = c.rowid AND a.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)) AND NOT EXISTS (SELECT f.rowid FROM ".$prefix.
"facture_fourn as f WHERE f.fk_soc = s.rowid)",
220 'class' =>
'Contact',
221 'file' => DOL_DOCUMENT_ROOT .
'/contact/class/contact.class.php',
222 'anonymize_fields' => array(
'lastname' =>
'MAKEANONYMOUS',
'firstname' =>
'MAKEANONYMOUS',
'poste' =>
'---',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone_pro' =>
'---',
'phone_perso' =>
'---',
'phone_mobile' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'photo' =>
'',
'url' =>
'---',
'fax' =>
'---',
'socialnetworks' => [],
'geolat' => 0,
'geolong' => 0,
'ip' =>
'0.0.0.0'),
223 'call_params' => array(
224 'delete' => array(
'user'),
225 'update' => array(
'id',
'user')
231 $sqltemplate =
"SELECT a.rowid FROM ".$prefix.
"adherent as a WHERE a.entity = __ENTITY__ AND a.datefin < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH)";
232 $sqltemplate .=
" AND NOT EXISTS (SELECT ac.id FROM ".$prefix.
"actioncomm as ac WHERE ac.fk_element = a.rowid AND ac.elementtype = 'member' AND ac.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH))";
233 $sqltemplate .=
" AND NOT EXISTS (SELECT s.rowid FROM ".$prefix.
"subscription as s WHERE s.fk_adherent = a.rowid AND s.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH))";
235 $arrayofpolicies[
'adherent'] = array(
237 'label_key' =>
'DATAPOLICY_ADHERENT',
238 'picto' =>
img_picto(
'',
'member',
'class="pictofixedwidth"'),
239 'const_delete' =>
'',
240 'const_anonymize' =>
'DATAPOLICY_ADHERENT_ANONYMIZE_DELAY',
241 'sql_template' => $sqltemplate,
242 'class' =>
'Adherent',
243 'file' => DOL_DOCUMENT_ROOT .
'/adherents/class/adherent.class.php',
244 'anonymize_fields' => array(
'lastname' =>
'MAKEANONYMOUS',
'firstname' =>
'MAKEANONYMOUS',
'societe' =>
'---',
'address' =>
'---',
'town' =>
'---',
'zip' =>
'---',
'phone' =>
'---',
'phone_perso' =>
'---',
'phone_mobile' =>
'---',
'email' =>
'anonymous+__ID__@example.com',
'birth' =>
dol_mktime(0, 0, 0, 1, 1, 1900),
'photo' =>
'',
'url' =>
'---',
'fax' =>
'---',
'socialnetworks' => [],
'ip' =>
'0.0.0.0',
'note_private' =>
'---',
'note_public' =>
'---',
'statut' => 0),
245 'call_params' => array(
246 'delete' => array(
'user'),
247 'update' => array(
'user')
254 $arrayofpolicies[
'recruitment_candidature'] = array(
255 'group' =>
'Recruitment',
256 'label_key' =>
'DATAPOLICY_RECRUITMENT_CANDIDATURE',
257 'picto' =>
img_picto(
'',
'recruitmentcandidature',
'class="pictofixedwidth"'),
258 'const_delete' =>
'DATAPOLICY_RECRUITMENT_CANDIDATURE_DELETE_DELAY',
259 'const_anonymize' =>
'',
260 'sql_template_delete' =>
"SELECT c.rowid FROM ".$prefix.
"recruitment_recruitmentcandidature as c WHERE c.entity = __ENTITY__ AND c.tms < DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH) AND NOT EXISTS (SELECT ac.id FROM ".$prefix.
"actioncomm as ac WHERE ac.elementtype = 'recruitmentcandidature@recruitment' AND ac.fk_element = c.rowid AND ac.tms > DATE_SUB(__NOW__, INTERVAL __DELAY__ MONTH))",
261 'class' =>
'RecruitmentCandidature',
262 'file' => DOL_DOCUMENT_ROOT .
'/recruitment/class/recruitmentcandidature.class.php',
263 'anonymize_fields' => array(),
264 'call_params' => array(
265 'delete' => array(
'user'),
266 'update' => array(
'user')
274 return $arrayofpolicies;
288 $this->nbupdated = 0;
289 $this->nbdeleted = 0;
290 $this->errorCount = 0;
291 $this->errorMessages = array();
294 $processedIds = array();
296 $objectInstances = array();
304 foreach ($dataPolicies as $policy) {
306 if (! isset($objectInstances[$policy[
'class']])) {
307 require_once $policy[
'file'];
308 $classtoinit = $policy[
'class'];
309 $objectInstances[$policy[
'class']] =
new $classtoinit($this->db);
311 $object = $objectInstances[$policy[
'class']];
318 $this->_processPolicyAction($policy,
'delete',
$object, $processedIds,
$conf, $user);
320 $this->_processPolicyAction($policy,
'anonymize',
$object, $processedIds,
$conf, $user);
324 if (! $this->errorCount) {
326 $this->output = $this->nbupdated .
' record(s) anonymized, ' . $this->nbdeleted .
' record(s) deleted.';
328 $this->db->rollback();
329 $this->error = implode(
"\n", $this->errorMessages);
332 return $this->errorCount ? 1 : 0;
347 private function _processPolicyAction($policy, $action,
$object, &$processedIds,
$conf, $user)
349 $constName = $policy[
'const_' . $action] ??
null;
357 $sqlPlaceholders = array(
358 '__ENTITY__' => (
string)
$conf->entity,
359 '__DELAY__' => (
string) $delay,
360 '__NOW__' =>
"'" . $this->db->idate(
dol_now()) .
"'"
362 $sql = str_replace(array_keys($sqlPlaceholders), array_values($sqlPlaceholders), $policy[
'sql_template'.($action ==
'delete' ?
'_delete' :
'')]);
364 $resql = $this->db->query($sql);
368 $this->errorMessages[] =
'Error executing ' . $action .
' query for policy ' . $constName .
': ' . $this->db->lasterror();
374 $handlerMethod =
'_handle' . ucfirst($action);
377 while ($obj = $this->db->fetch_object($resql)) {
378 if (in_array($obj->rowid, $processedIds) || ! method_exists($this, $handlerMethod)) {
389 if ($action ===
'delete' && !empty(
$object->childtables) && method_exists(
$object,
'isObjectUsed') &&
$object->isObjectUsed() != 0) {
394 $result = $this->$handlerMethod(
$object, $user, $policy);
398 $processedIds[] = $obj->rowid;
414 return $object->delete(...$callArgs);
427 foreach ($policy[
'anonymize_fields'] as $field => $val) {
428 if ($val ==
'MAKEANONYMOUS') {
434 $newval = str_replace(
'__ID__',
$object->id ? (
string)
$object->id :
'0', $val);
444 $result =
$object->update(...$callArgs);
465 if (empty(
$object->table_element)) {
470 $sql =
"SELECT ef.name, ef.type";
471 $sql .=
" FROM " . $this->db->prefix() .
"extrafields as ef";
472 $sql .=
" WHERE ef.elementtype = '" . $this->db->escape(
$object->table_element) .
"'";
473 $sql .=
" AND ef.personal_data = 1";
474 $sql .=
" AND ef.entity IN (0, " . (int) (isset($GLOBALS[
'conf']) ? $GLOBALS[
'conf']->entity : 1) .
")";
476 $resql = $this->db->query($sql);
480 $this->errorMessages[] =
'Error fetching personal extra fields for ' .
$object->table_element .
': ' . $this->db->lasterror();
484 while ($efObj = $this->db->fetch_object($resql)) {
485 $fieldName = $efObj->name;
486 $fieldType = $efObj->type;
489 $optionKey =
'options_' . $fieldName;
491 if (!isset(
$object->array_options[$optionKey])) {
495 if (empty(
$object->array_options[$optionKey])) {
499 if (in_array($fieldType, array(
'multiselect',
'checkbox'))) {
500 $object->array_options[$optionKey] = array();
501 } elseif (in_array($fieldType, array(
'boolean',
'radio'))) {
502 $object->array_options[$optionKey] =
'0';
503 } elseif (in_array($fieldType, array(
'date',
'datetime',
'timestamp'))) {
505 } elseif (in_array($fieldType, array(
'int',
'double',
'price',
'stars'))) {
506 $object->array_options[$optionKey] = 0;
508 $object->array_options[$optionKey] =
'---';
524 $availableArgs = array(
529 $paramConfig = $policy[
'call_params'][$method] ?? [];
536 static function (
string $paramName) use ($availableArgs) {
537 return $availableArgs[$paramName];
555 $this->errorMessages[] =
'Failed to ' . $action .
' record ID ' .
$object->id .
' from class ' . get_class(
$object) .
'. Error: ' .
$object->errorsToString();
557 if ($action ===
'delete') {
559 } elseif ($action ===
'anonymize') {
if(! $sortfield) if(! $sortorder) $object
getDataPolicies()
Defines and returns the centralized data policy configuration.
_recordActionResult($result, $object, $action)
Records the result of an action, updating counters and error messages.
cleanDataForDataPolicy()
Main cron task execution method.
_anonymizeExtraFields($object)
Anonymizes extra fields flagged as personal data (personal_data = 1) for a given object.
_buildCallArguments($object, $user, $policy, $method)
Builds the dynamic argument list for method calls based on policy configuration.
_handleAnonymize($object, $user, $policy)
Handles the specific logic for anonymizing an object.
_handleDelete($object, $user, $policy)
Handles the specific logic for deleting an object.
__construct(DoliDB $db)
Constructor.
Class to manage Dolibarr database access.
const PROSPECT
Third party type is a prospect.
const CUSTOMER_AND_PROSPECT
Third party type is a customer and a prospect.
const CUSTOMER
Third party type is a customer.
const NO_CUSTOMER
Third party type is no customer.
dol_now($mode='gmt')
Return date for now.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
isModEnabled($module)
Is Dolibarr module enabled.