Beispiel #1
0
 /**
  * Run the default json controller
  *
  * @param $parameters Parameters
  * @param $form array
  * @param $files array
  * @param $class_name string
  * @return string
  */
 public function run(Parameters $parameters, $form, $files, $class_name)
 {
     $parameters = $parameters->getObjects();
     // read all objects corresponding to class name
     if (!$parameters) {
         return json_encode(Dao::readAll(Names::setToClass($class_name, false), [Dao::sort()]));
     }
     // read object
     $first_parameter = reset($parameters);
     if (is_object($first_parameter)) {
         return json_encode($first_parameter);
     }
     // search objects for autocomplete combo pull-down list
     if (isset($parameters['term'])) {
         $element_class_name = Names::setToClass($class_name, false);
         $search = null;
         if (!empty($parameters['term'])) {
             $search = (new Search_Array_Builder())->buildMultiple(new Reflection_Class($element_class_name), $parameters['term'], '', '%');
         }
         if (isset($parameters['filters']) && $parameters['filters']) {
             if (!(is_object($search) && $search->isAnd())) {
                 $search = Dao\Func::andOp($search ? [$search] : []);
             }
             foreach ($parameters['filters'] as $filter_name => $filter_value) {
                 $search->arguments[$filter_name] = $filter_value[0] == '!' ? Dao\Func::notEqual(substr($filter_value, 1)) : $filter_value;
             }
             if (count($search->arguments) == 1) {
                 reset($search->arguments);
                 $search = [key($search->arguments) => current($search->arguments)];
             }
         }
         $objects = [];
         // first object only
         if (isset($parameters['first']) && $parameters['first']) {
             $objects = Dao::search($search, $element_class_name, [Dao::sort(), Dao::limit(1)]);
             $source_object = $objects ? reset($objects) : Builder::create($element_class_name);
             return json_encode(new Autocomplete_Entry(Dao::getObjectIdentifier($source_object), strval($source_object)));
         } else {
             $search_options = [Dao::sort()];
             if (isset($parameters['limit'])) {
                 $search_options[] = Dao::limit($parameters['limit']);
             }
             foreach (Dao::search($search, $element_class_name, $search_options) as $source_object) {
                 $objects[] = new Autocomplete_Entry(Dao::getObjectIdentifier($source_object), strval($source_object));
             }
             return json_encode($objects);
         }
     } elseif (isset($parameters['id'])) {
         $element_class_name = Names::setToClass($class_name);
         $source_object = Dao::read($parameters['id'], $element_class_name);
         return json_encode(new Autocomplete_Entry(Dao::getObjectIdentifier($source_object), strval($source_object)));
     }
     return '';
 }
Beispiel #2
0
 /**
  * Search one object from data source
  *
  * Same as search(), but expected result is one object only.
  * It is highly recommended to use this search with primary keys properties values searches.
  * If several result exist, only one will be taken, the first on the list (may be random).
  *
  * @param $what       object|array source object for filter, only set properties will be used for
  *        search
  * @param $class_name string must be set if is not a filter array
  * @return object|null the found object, or null if no object was found
  */
 public function searchOne($what, $class_name = null)
 {
     $result = $this->search($what, $class_name, [Dao::limit(1)]);
     return $result ? reset($result) : null;
 }
 /**
  * If plugin is activated, limits result count of Mysql::search()
  *
  * This results on an incomplete object, but the object is used for editing form only so we don't
  * care.
  *
  * @param $options Option[] some options for advanced search
  */
 public function beforeMysqlLinkSearch(&$options)
 {
     if ($this->in_multiple === 'search') {
         if (is_object($options)) {
             $options = [$options];
         }
         $options[] = Dao::limit(10);
         $options[] = $this->count = new Count();
         $this->in_multiple = 'build';
     }
 }