actions_fetchobject.inc.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. <?php
  2. /* Copyright (C) 2014-2017 Laurent Destailleur <eldy@users.sourceforge.net>
  3. * Copyright (C) 2015 Frederic France <frederic.france@free.fr>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 3 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program. If not, see <https://www.gnu.org/licenses/>.
  17. * or see https://www.gnu.org/
  18. */
  19. /**
  20. * \file htdocs/core/actions_fetchobject.inc.php
  21. * \brief Code for actions on fetching object page
  22. */
  23. // $action must be defined
  24. // $object must be defined (object is loaded in this file with fetch)
  25. // $cancel must be defined
  26. // $id or $ref must be defined (object is loaded in this file with fetch)
  27. if (($id > 0 || (!empty($ref) && !in_array($action, array('create', 'createtask', 'add')))) && (empty($cancel) || $id > 0)) {
  28. if (($id > 0 && is_numeric($id)) || !empty($ref)) { // To discard case when id is list of ids like '1,2,3...'
  29. if ($object->element == 'usergroup') {
  30. $ret = $object->fetch($id, (empty($ref)? '' : $ref), true); // to load $object->members
  31. } else {
  32. $ret = $object->fetch($id, (empty($ref)? '' : $ref));
  33. }
  34. if ($ret > 0) {
  35. $object->fetch_thirdparty();
  36. $id = $object->id;
  37. } else {
  38. if (empty($object->error) && !count($object->errors)) {
  39. if ($ret < 0) { // if $ret == 0, it means not found.
  40. setEventMessages('Fetch on object (type '.get_class($object).') return an error without filling $object->error nor $object->errors', null, 'errors');
  41. }
  42. } else {
  43. setEventMessages($object->error, $object->errors, 'errors');
  44. }
  45. $action = '';
  46. }
  47. }
  48. }