180function restrictedArea(
User $user, $features,
$object = 0, $tableandshare =
'', $feature2 =
'', $dbt_keyfield =
'fk_soc', $dbt_select =
'rowid', $isdraft = 0, $mode = 0)
190 if ($objectid ==
"-1") {
194 $objectid = preg_replace(
'/[^0-9\.\,]/',
'', (
string) $objectid);
203 $parentfortableentity =
'';
207 $originalfeatures = $features;
208 if ($features ==
'agenda') {
209 $tableandshare =
'actioncomm&societe';
210 $feature2 =
'myactions|allactions';
213 if ($features ==
'bank') {
214 $features =
'banque';
216 if ($features ==
'facturerec') {
217 $features =
'facture';
219 if ($features ==
'supplier_invoicerec') {
220 $features =
'fournisseur';
221 $feature2 =
'facture';
223 if ($features ==
'mo') {
226 if ($features ==
'member') {
227 $features =
'adherent';
229 if ($features ==
'subscription') {
230 $features =
'adherent';
231 $feature2 =
'cotisation';
233 if ($features ==
'website' && is_object(
$object) &&
$object->element ==
'websitepage') {
234 $parentfortableentity =
'fk_website@website';
236 if ($features ==
'project') {
237 $features =
'projet';
239 if ($features ==
'product') {
240 $features =
'produit';
242 if ($features ==
'productbatch') {
243 $features =
'produit';
245 if ($features ==
'tax') {
246 $feature2 =
'charges';
248 if ($features ==
'workstation') {
249 $feature2 =
'workstation';
251 if ($features ==
'fournisseur') {
252 $features =
'fournisseur';
253 if (is_object(
$object) &&
$object->element ==
'invoice_supplier') {
254 $feature2 =
'facture';
255 } elseif (is_object(
$object) &&
$object->element ==
'order_supplier') {
256 $feature2 =
'commande';
259 if ($features ==
'payment_sc') {
260 $tableandshare =
'paiementcharge';
261 $parentfortableentity =
'fk_charge@chargesociales';
266 if (in_array($features, [
'commandedet',
'propaldet',
'facturedet',
'supplier_proposaldet',
'evaluationdet',
'skilldet',
'deliverydet',
'contratdet'])) {
267 $features = substr($features, 0, -3);
268 } elseif (in_array($features, [
'stocktransferline',
'inventoryline',
'bomline',
'expensereport_det',
'facture_fourn_det'])) {
269 $features = substr($features, 0, -4);
270 } elseif ($features ==
'commandefournisseurdispatch') {
271 $features =
'commandefournisseur';
272 } elseif ($features ==
'invoice_supplier_det_rec') {
273 $features =
'invoice_supplier_rec';
275 if ($features ==
'evaluation') {
277 $feature2 =
'evaluation';
285 if (is_object(
$object) && in_array(
$object->element, array(
'project_task',
'task'))
286 && (empty($features) || in_array($features, array(
'projet',
'project')))
287 && empty($feature2)) {
288 $features =
'projet';
289 $feature2 =
'project_task';
290 if (empty($tableandshare)) {
291 $tableandshare =
'projet_task';
299 'features' => $features,
300 'feature2' => $feature2,
301 'originalfeatures' => $originalfeatures,
302 'tableandshare' => $tableandshare,
304 'objectid' => $objectid,
305 'dbt_keyfield' => $dbt_keyfield,
306 'dbt_select' => $dbt_select,
307 'idtype' => $dbt_select,
308 'isdraft' => $isdraft,
311 if (!empty($hookmanager)) {
312 $reshook = $hookmanager->executeHooks(
'restrictedArea', $parameters);
314 if (isset($hookmanager->resArray[
'result'])) {
315 if ($hookmanager->resArray[
'result'] == 0) {
329 $featuresarray = array($features);
330 if (preg_match(
'/&/', $features)) {
331 $featuresarray = explode(
"&", $features);
332 } elseif (preg_match(
'/\|/', $features)) {
333 $featuresarray = explode(
"|", $features);
337 if (!empty($feature2)) {
338 $feature2 = explode(
"|", $feature2);
346 foreach ($featuresarray as $feature) {
347 $featureforlistofmodule = $feature;
348 if ($featureforlistofmodule ==
'produit') {
349 $featureforlistofmodule =
'product';
351 if ($featureforlistofmodule ==
'supplier_proposal') {
352 $featureforlistofmodule =
'supplierproposal';
354 if (!empty($user->socid) &&
getDolGlobalString(
'MAIN_MODULES_FOR_EXTERNAL') && !in_array($featureforlistofmodule, $listofmodules)) {
360 if ($feature ==
'societe' && (empty($feature2) || !in_array(
'contact', $feature2))) {
361 if (!$user->hasRight(
'societe',
'lire') && !$user->hasRight(
'fournisseur',
'lire')) {
365 } elseif (($feature ==
'societe' && (!empty($feature2) && in_array(
'contact', $feature2))) || $feature ==
'contact') {
366 if (!$user->hasRight(
'societe',
'contact',
'lire')) {
370 } elseif ($feature ==
'produit|service') {
371 if (!$user->hasRight(
'produit',
'lire') && !$user->hasRight(
'service',
'lire')) {
375 } elseif ($feature ==
'prelevement') {
376 if (!$user->hasRight(
'prelevement',
'bons',
'lire')) {
380 } elseif ($feature ==
'cheque') {
381 if (!$user->hasRight(
'banque',
'cheque')) {
385 } elseif ($feature ==
'projet') {
386 if (!$user->hasRight(
'projet',
'lire') && !$user->hasRight(
'projet',
'all',
'lire')) {
390 } elseif ($feature ==
'payment') {
391 if (!$user->hasRight(
'facture',
'lire')) {
395 } elseif ($feature ==
'payment_supplier') {
396 if (!$user->hasRight(
'fournisseur',
'facture',
'lire')) {
400 } elseif ($feature ==
'payment_sc') {
401 if (!$user->hasRight(
'tax',
'charges',
'lire')) {
405 } elseif ($feature ==
'webhook') {
406 if (empty($user->admin)) {
410 } elseif (!empty($feature2)) {
412 foreach ($feature2 as $subfeature) {
413 if ($subfeature ==
'user' && $user->id == $objectid) {
416 if ($subfeature ==
'fiscalyear' && $user->hasRight(
'accounting',
'fiscalyear',
'write')) {
421 if (!empty($subfeature) && !$user->hasRight($feature, $subfeature,
'lire') && !$user->hasRight($feature, $subfeature,
'read')) {
423 } elseif (empty($subfeature) && !$user->hasRight($feature,
'lire') && !$user->hasRight($feature,
'read')) {
434 } elseif (!empty($feature) && ($feature !=
'user' && $feature !=
'usergroup')) {
435 if (!$user->hasRight($feature,
'lire')
436 && !$user->hasRight($feature,
'read')
437 && !$user->hasRight($feature,
'run')) {
445 if (preg_match(
'/\|/', $features) && $nbko < count($featuresarray)) {
461 $wemustcheckpermissionforcreate = (
GETPOST(
'sendit',
'alpha') ||
GETPOST(
'linkit',
'alpha') || in_array(
GETPOST(
'action',
'aZ09'), array(
'create',
'update',
'set',
'upload',
'add_element_resource',
'confirm_deletebank',
'confirm_delete_linked_resource')) ||
GETPOST(
'roworder',
'alpha', 2));
462 $wemustcheckpermissionfordeletedraft = ((
GETPOST(
"action",
"aZ09") ==
'confirm_delete' &&
GETPOST(
"confirm",
"aZ09") ==
'yes') ||
GETPOST(
"action",
"aZ09") ==
'delete');
464 if ($wemustcheckpermissionforcreate || $wemustcheckpermissionfordeletedraft) {
465 foreach ($featuresarray as $feature) {
466 if ($feature ==
'contact') {
467 if (!$user->hasRight(
'societe',
'contact',
'creer')) {
471 } elseif ($feature ==
'produit|service') {
472 if (!$user->hasRight(
'produit',
'creer') && !$user->hasRight(
'service',
'creer')) {
476 } elseif ($feature ==
'prelevement') {
477 if (!$user->hasRight(
'prelevement',
'bons',
'creer')) {
481 } elseif ($feature ==
'commande_fournisseur') {
482 if (!$user->hasRight(
'fournisseur',
'commande',
'creer') || !$user->hasRight(
'supplier_order',
'creer')) {
486 } elseif ($feature ==
'banque') {
487 if (!$user->hasRight(
'banque',
'modifier')) {
491 } elseif ($feature ==
'cheque') {
492 if (!$user->hasRight(
'banque',
'cheque')) {
496 } elseif ($feature ==
'import') {
497 if (!$user->hasRight(
'import',
'run')) {
501 } elseif ($feature ==
'ecm') {
502 if (!$user->hasRight(
'ecm',
'upload')) {
506 } elseif ($feature ==
'modulebuilder') {
507 if (!$user->hasRight(
'modulebuilder',
'run')) {
511 } elseif ($feature ==
'webhook') {
512 if (empty($user->admin)) {
516 } elseif (!empty($feature2)) {
517 foreach ($feature2 as $subfeature) {
518 if ($subfeature ==
'user' && $user->id == $objectid && $user->hasRight(
'user',
'self',
'creer')) {
521 if ($subfeature ==
'user' && $user->id == $objectid && $user->hasRight(
'user',
'self',
'password')) {
524 if ($subfeature ==
'user' && $user->id != $objectid && $user->hasRight(
'user',
'user',
'password')) {
528 if (!$user->hasRight($feature, $subfeature,
'creer')
529 && !$user->hasRight($feature, $subfeature,
'write')
530 && !$user->hasRight($feature, $subfeature,
'create')) {
539 } elseif (!empty($feature)) {
541 if (!$user->hasRight($feature,
'creer')
542 && !$user->hasRight($feature,
'write')
543 && !$user->hasRight($feature,
'create')) {
551 if (preg_match(
'/\|/', $features) && $nbko < count($featuresarray)) {
555 if ($wemustcheckpermissionforcreate && !$createok) {
567 if (
GETPOST(
'action',
'aZ09') ==
'confirm_create_user' &&
GETPOST(
"confirm",
'aZ09') ==
'yes') {
568 if (!$user->hasRight(
'user',
'user',
'creer')) {
572 if (!$createuserok) {
585 if ((
GETPOST(
"action",
"aZ09") ==
'confirm_delete' &&
GETPOST(
"confirm",
"aZ09") ==
'yes') ||
GETPOST(
"action",
"aZ09") ==
'delete') {
586 foreach ($featuresarray as $feature) {
587 if ($feature ==
'bookmark') {
588 if (!$user->hasRight(
'bookmark',
'supprimer')) {
589 if ($user->id !=
$object->fk_user || !$user->hasRight(
'bookmark',
'creer')) {
593 } elseif ($feature ==
'contact') {
594 if (!$user->hasRight(
'societe',
'contact',
'supprimer')) {
597 } elseif ($feature ==
'produit|service') {
598 if (!$user->hasRight(
'produit',
'supprimer') && !$user->hasRight(
'service',
'supprimer')) {
601 } elseif ($feature ==
'commande_fournisseur') {
602 if (!$user->hasRight(
'fournisseur',
'commande',
'supprimer')) {
605 } elseif ($feature ==
'payment_supplier') {
606 if (!$user->hasRight(
'fournisseur',
'facture',
'creer')) {
609 } elseif ($feature ==
'payment') {
610 if (!$user->hasRight(
'facture',
'paiement')) {
613 } elseif ($feature ==
'payment_sc') {
614 if (!$user->hasRight(
'tax',
'charges',
'creer')) {
617 } elseif ($feature ==
'banque') {
618 if (!$user->hasRight(
'banque',
'modifier')) {
621 } elseif ($feature ==
'cheque') {
622 if (!$user->hasRight(
'banque',
'cheque')) {
625 } elseif ($feature ==
'ecm') {
626 if (!$user->hasRight(
'ecm',
'upload')) {
629 } elseif ($feature ==
'ftp') {
630 if (!$user->hasRight(
'ftp',
'write')) {
633 } elseif ($feature ==
'salaries') {
634 if (!$user->hasRight(
'salaries',
'delete')) {
637 } elseif ($feature ==
'adherent') {
638 if (!$user->hasRight(
'adherent',
'supprimer')) {
641 } elseif ($feature ==
'paymentbybanktransfer') {
642 if (!$user->hasRight(
'paymentbybanktransfer',
'create')) {
645 } elseif ($feature ==
'prelevement') {
646 if (!$user->hasRight(
'prelevement',
'bons',
'creer')) {
649 } elseif (!empty($feature2)) {
650 foreach ($feature2 as $subfeature) {
651 if (!$user->hasRight($feature, $subfeature,
'supprimer') && !$user->hasRight($feature, $subfeature,
'delete')) {
658 } elseif (!empty($feature)) {
660 if (!$user->hasRight($feature,
'supprimer')
661 && !$user->hasRight($feature,
'delete')
662 && !$user->hasRight($feature,
'run')) {
669 if (preg_match(
'/\|/', $features) && $nbko < count($featuresarray)) {
673 if (!$deleteok && !($isdraft && $createok)) {
685 if (!empty($objectid) && $objectid > 0) {
687 $params = array(
'objectid' => $objectid,
'features' => implode(
',', $featuresarray),
'features2' => $feature2);
718function checkUserAccessToObject($user, array $featuresarray,
$object = 0, $tableandshare =
'', $feature2 =
'', $dbt_keyfield =
'', $dbt_select =
'rowid', $parenttableforentity =
'')
727 $objectid = preg_replace(
'/[^0-9\.\,]/',
'', $objectid);
734 $params = explode(
'&', $tableandshare);
735 $dbtablename = (!empty($params[0]) ? $params[0] :
'');
736 $sharedelement = (!empty($params[1]) ? $params[1] : $dbtablename);
738 foreach ($featuresarray as $feature) {
744 if ($feature ==
'societe' && !empty($feature2) && is_array($feature2) && in_array(
'contact', $feature2)) {
745 $feature =
'contact';
748 if ($feature ==
'member') {
749 $feature =
'adherent';
751 if ($feature ==
'category') {
752 $feature =
'categorie';
754 if ($feature ==
'project') {
757 if ($feature ==
'projet' && !empty($feature2) && is_array($feature2) && !empty(array_intersect(array(
'project_task',
'projet_task'), $feature2))) {
758 $feature =
'project_task';
760 if ($feature ==
'task' || $feature ==
'projet_task') {
761 $feature =
'project_task';
762 $dbtablename =
'projet_task';
764 if ($feature ==
'eventorganization') {
766 $dbtablename =
'actioncomm';
768 if ($feature ==
'payment_sc' && empty($parenttableforentity)) {
770 $parenttableforentity =
'';
771 $dbtablename =
"chargesociales";
772 $feature =
"chargesociales";
773 $objectid =
$object->fk_charge;
776 $checkonentitydone = 0;
779 $check = array(
'adherent',
'banque',
'bom',
'don',
'mrp',
'user',
'usergroup',
'payment',
'payment_supplier',
'payment_sc',
'product',
'produit',
'service',
'produit|service',
'categorie',
'resource',
'expensereport',
'holiday',
'salaries',
'website',
'recruitment',
'chargesociales',
'knowledgemanagement',
'stock');
780 $checksoc = array(
'societe');
781 $checkparentsoc = array(
'agenda',
'contact',
'contrat');
782 $checkproject = array(
'projet',
'project');
783 $checktask = array(
'projet_task',
'project_task');
784 $checkhierarchy = array(
'expensereport',
'holiday',
'hrm');
785 $checkuser = array(
'bookmark');
786 $nocheck = array(
'barcode',
'webhook');
791 if (empty($dbtablename)) {
792 $dbtablename = $feature;
793 $sharedelement = (!empty($params[1]) ? $params[1] : $dbtablename);
797 if ($dbt_select !=
'rowid' && $dbt_select !=
'id') {
798 $objectid =
"'".$objectid.
"'";
801 if (in_array($feature, $check) && $objectid > 0) {
802 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_select).
") as nb";
803 $sql .=
" FROM ".MAIN_DB_PREFIX.$db->sanitize($dbtablename).
" as dbt";
804 if (($feature ==
'user' || $feature ==
'usergroup') &&
isModEnabled(
'multicompany')) {
806 if (
$conf->entity == 1 && $user->admin && !$user->entity) {
807 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
808 $sql .=
" AND dbt.entity IS NOT NULL";
810 $sql .=
",".MAIN_DB_PREFIX.
"usergroup_user as ug";
811 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
812 $sql .=
" AND ((ug.fk_user = dbt.rowid";
813 $sql .=
" AND ug.entity IN (".getEntity(
'usergroup').
"))";
814 $sql .=
" OR dbt.entity = 0)";
817 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
818 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
822 if ($parenttableforentity && preg_match(
'/(.*)@(.*)/', $parenttableforentity, $reg)) {
823 $sql .=
", ".MAIN_DB_PREFIX.$db->sanitize($reg[2]).
" as dbtp";
824 $sql .=
" WHERE dbt.".$db->sanitize($reg[1]).
" = dbtp.rowid AND dbt.".
$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
825 $sql .=
" AND dbtp.entity IN (".getEntity($sharedelement, 1).
")";
827 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
828 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
831 $checkonentitydone = 1;
833 if (in_array($feature, $checksoc) && $objectid > 0) {
835 if ($user->socid > 0) {
836 if ($user->socid != $objectid) {
839 } elseif (
isModEnabled(
'societe') && !$user->hasRight(
'societe',
'lire') && !$user->hasRight(
'societe',
'client',
'voir')) {
840 dol_syslog(
"security.lib.php::checkUserAccessToObject Deny access due: (isModEnabled('societe') && !user->hasRight('societe', 'lire') && !user->hasRight('societe', 'client', 'voir'))", LOG_DEBUG);
842 } elseif (
isModEnabled(
"societe") && ($user->hasRight(
'societe',
'lire') && !$user->hasRight(
'societe',
'client',
'voir'))) {
844 $sql =
"SELECT COUNT(sc.fk_soc) as nb";
845 $sql .=
" FROM (".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
846 $sql .=
", ".MAIN_DB_PREFIX.
"societe as s)";
847 $sql .=
" WHERE sc.fk_soc IN (".$db->sanitize($objectid, 1).
")";
848 $sql .=
" AND (sc.fk_user = ".((int) $user->id);
850 $userschilds = $user->getAllChildIds();
851 if (!empty($userschilds)) $sql .=
" OR sc.fk_user IN (".
$db->sanitize(implode(
',', $userschilds)).
")";
854 $sql .=
" AND sc.fk_soc = s.rowid";
855 $sql .=
" AND s.entity IN (".getEntity($sharedelement, 1).
")";
858 $sql =
"SELECT COUNT(s.rowid) as nb";
859 $sql .=
" FROM ".MAIN_DB_PREFIX.
"societe as s";
860 $sql .=
" WHERE s.rowid IN (".$db->sanitize($objectid, 1).
")";
861 $sql .=
" AND s.entity IN (".getEntity($sharedelement, 1).
")";
864 $checkonentitydone = 1;
866 if (in_array($feature, $checkparentsoc) && $objectid > 0) {
868 if ($user->socid > 0) {
869 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_select).
") as nb";
870 $sql .=
" FROM ".MAIN_DB_PREFIX.$dbtablename.
" as dbt";
871 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
872 $sql .=
" AND dbt.fk_soc = ".((int) $user->socid);
873 } elseif (
isModEnabled(
"societe") && ($user->hasRight(
'societe',
'lire') && !$user->hasRight(
'societe',
'client',
'voir'))) {
875 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_select).
") as nb";
876 $sql .=
" FROM ".MAIN_DB_PREFIX.$dbtablename.
" as dbt";
877 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON dbt.fk_soc = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
878 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
879 $sql .=
" AND (dbt.fk_soc IS NULL OR sc.fk_soc IS NOT NULL)";
880 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
883 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_select).
") as nb";
884 $sql .=
" FROM ".MAIN_DB_PREFIX.$dbtablename.
" as dbt";
885 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
886 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
889 $checkonentitydone = 1;
891 if (in_array($feature, $checkproject) && $objectid > 0) {
892 if (
isModEnabled(
'project') && !$user->hasRight(
'projet',
'all',
'lire')) {
893 $projectid = $objectid;
895 include_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
897 $tmps = $projectstatic->getProjectsAuthorizedForUser($user, 0, 1, 0);
899 $tmparray = explode(
',', $tmps);
900 if (!in_array($projectid, $tmparray)) {
904 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_select).
") as nb";
905 $sql .=
" FROM ".MAIN_DB_PREFIX.$dbtablename.
" as dbt";
906 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
907 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
909 $checkonentitydone = 1;
911 if (in_array($feature, $checktask) && (
int) $objectid > 0) {
912 if (
isModEnabled(
'project') && !$user->hasRight(
'projet',
'all',
'lire')) {
914 $task->fetch((
int) $objectid);
915 $projectid = $task->fk_project;
917 include_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
919 $tmps = $projectstatic->getProjectsAuthorizedForUser($user, 0, 1, 0);
921 $tmparray = explode(
',', $tmps);
922 if (!in_array($projectid, $tmparray)) {
926 $sharedelement =
'project';
927 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_select).
") as nb";
928 $sql .=
" FROM ".MAIN_DB_PREFIX.$dbtablename.
" as dbt";
929 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
930 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
933 $checkonentitydone = 1;
937 if (!$checkonentitydone && !in_array($feature, $nocheck) && $objectid > 0) {
939 if ($user->socid > 0) {
940 if (empty($dbt_keyfield)) {
941 dol_print_error(
null,
'Param dbt_keyfield is required but not defined');
943 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_keyfield).
") as nb";
944 $sql .=
" FROM ".MAIN_DB_PREFIX.$dbtablename.
" as dbt";
945 $sql .=
" WHERE dbt.rowid IN (".$db->sanitize($objectid, 1).
")";
946 $sql .=
" AND dbt.".$db->sanitize($dbt_keyfield).
" = ".((int) $user->socid);
947 } elseif (
isModEnabled(
"societe") && !$user->hasRight(
'societe',
'client',
'voir')) {
949 if (empty($dbt_keyfield)) {
950 dol_print_error(
null,
'Param dbt_keyfield is required but not defined');
952 if ($feature !=
'ticket') {
953 $sql =
"SELECT COUNT(sc.fk_soc) as nb";
954 $sql .=
" FROM ".MAIN_DB_PREFIX.$db->sanitize($dbtablename).
" as dbt";
955 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
956 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
957 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
958 $sql .=
" AND sc.fk_soc = dbt.".$db->sanitize($dbt_keyfield);
959 $sql .=
" AND (sc.fk_user = ".((int) $user->id);
961 $userschilds = $user->getAllChildIds();
962 if (!empty($userschilds)) $sql .=
" OR sc.fk_user IN (".
$db->sanitize(implode(
',', $userschilds)).
")";
967 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_select).
") as nb";
968 $sql .=
" FROM ".MAIN_DB_PREFIX.$dbtablename.
" as dbt";
969 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON sc.fk_soc = dbt.".
$db->sanitize($dbt_keyfield).
" AND sc.fk_user = ".((int) $user->id);
970 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
971 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
972 $sql .=
" AND (sc.fk_user = ".((int) $user->id).
" OR dbt.".$dbt_keyfield.
" IS NULL OR dbt.".$dbt_keyfield.
" = 0)";
976 $sql =
"SELECT COUNT(dbt.".$db->sanitize($dbt_select).
") as nb";
977 $sql .=
" FROM ".MAIN_DB_PREFIX.$db->sanitize($dbtablename).
" as dbt";
978 $sql .=
" WHERE dbt.".$db->sanitize($dbt_select).
" IN (".
$db->sanitize($objectid, 1).
")";
979 $sql .=
" AND dbt.entity IN (".getEntity($sharedelement, 1).
")";
984 if ($feature ===
'agenda' && ((
int) $objectid) > 0) {
986 if ( !$user->hasRight(
'agenda',
'allactions',
'read')) {
987 require_once DOL_DOCUMENT_ROOT.
'/comm/action/class/actioncomm.class.php';
989 $action->fetch((
int) $objectid);
990 if ($action->authorid != $user->id && $action->userownerid != $user->id && !(array_key_exists($user->id, $action->userassigned))) {
998 if (in_array($feature, $checkhierarchy) && is_object(
$object) && $objectid > 0) {
999 $childids = $user->getAllChildIds(1);
1001 if ($feature ==
'holiday') {
1002 $useridtocheck =
$object->fk_user;
1003 if (!$user->hasRight(
'holiday',
'readall') && !in_array($useridtocheck, $childids) && !in_array(
$object->fk_validator, $childids)) {
1007 if ($feature ==
'expensereport') {
1008 $useridtocheck =
$object->fk_user_author;
1009 if (!$user->hasRight(
'expensereport',
'readall')) {
1010 if (!in_array($useridtocheck, $childids)) {
1015 if ($feature ==
'hrm' && in_array(
'evaluation', $feature2)) {
1016 $useridtocheck =
$object->fk_user;
1018 if ($user->hasRight(
'hrm',
'evaluation',
'readall')) {
1022 if (!$user->hasRight(
'hrm',
'evaluation',
'read')) {
1027 return in_array($useridtocheck, $childids);
1033 if (in_array($feature, $checkuser) && is_object(
$object) && $objectid > 0) {
1034 $useridtocheck =
$object->fk_user;
1035 if (!empty($useridtocheck) && $useridtocheck > 0 && $useridtocheck != $user->id && empty($user->admin)) {
1041 $resql =
$db->query($sql);
1043 $obj =
$db->fetch_object($resql);
1044 if (!$obj || $obj->nb < count(explode(
',', $objectid))) {
1048 dol_syslog(
"Bad forged sql in security.lib.php::checkUserAccessToObject", LOG_WARNING);
1054 dol_syslog(
"security.lib.php::checkUserAccessToObject::return True", LOG_DEBUG);
if(!defined( 'NOREQUIREMENU')) if(!empty(GETPOST('seteventmessages', 'alpha'))) if(!function_exists("llxHeader")) top_httphead($contenttype='text/html', $forcenocache=0)
Show HTTP header.