public function deleteAll($conditions, $cascade = true, $callbacks = false)
 {
     $x = $this->find("all", array("contain" => false, "fields" => array('image'), "conditions" => $conditions));
     foreach ($x as $v) {
         $pth = ltrim($v[$this->alias]['image'], "https://www.pickmeals.com/");
         unlink(str_replace("-0-", "-1-", $pth));
         unlink(str_replace("-0-", "-2-", $pth));
         unlink($pth);
     }
     parent::deleteAll($conditions, $cascade, $callbacks);
 }
Example #2
0
 /**
  * Recover a corrupted tree
  *
  * The mode parameter is used to specify the source of info that is valid/correct. The opposite source of data
  * will be populated based upon that source of info. E.g. if the MPTT fields are corrupt or empty, with the $mode
  * 'parent' the values of the parent_id field will be used to populate the left and right fields. The missingParentAction
  * parameter only applies to "parent" mode and determines what to do if the parent field contains an id that is not present.
  *
  * @todo Could be written to be faster, *maybe*. Ideally using a subquery and putting all the logic burden on the DB.
  * @param AppModel $Model Model instance
  * @param string $mode parent or tree
  * @param mixed $missingParentAction 'return' to do nothing and return, 'delete' to
  * delete, or the id of the parent to set as the parent_id
  * @return boolean true on success, false on failure
  * @access public
  * @link http://book.cakephp.org/view/1628/Recover
  */
 function recover(&$Model, $mode = 'parent', $missingParentAction = null)
 {
     if (is_array($mode)) {
         extract(array_merge(array('mode' => 'parent'), $mode));
     }
     extract($this->settings[$Model->alias]);
     $Model->recursive = $recursive;
     if ($mode == 'parent') {
         $Model->bindModel(array('belongsTo' => array('VerifyParent' => array('className' => $Model->alias, 'foreignKey' => $parent, 'fields' => array($Model->primaryKey, $left, $right, $parent)))));
         $missingParents = $Model->find('list', array('recursive' => 0, 'conditions' => array($scope, array('NOT' => array($Model->escapeField($parent) => null), $Model->VerifyParent->escapeField() => null))));
         $Model->unbindModel(array('belongsTo' => array('VerifyParent')));
         if ($missingParents) {
             if ($missingParentAction == 'return') {
                 foreach ($missingParents as $id => $display) {
                     $this->errors[] = 'cannot find the parent for ' . $Model->alias . ' with id ' . $id . '(' . $display . ')';
                 }
                 return false;
             } elseif ($missingParentAction == 'delete') {
                 $Model->deleteAll(array($Model->primaryKey => array_flip($missingParents)));
             } else {
                 $Model->updateAll(array($parent => $missingParentAction), array($Model->escapeField($Model->primaryKey) => array_flip($missingParents)));
             }
         }
         $count = 1;
         foreach ($Model->find('all', array('conditions' => $scope, 'fields' => array($Model->primaryKey), 'order' => $left)) as $array) {
             $Model->id = $array[$Model->alias][$Model->primaryKey];
             $lft = $count++;
             $rght = $count++;
             $Model->save(array($left => $lft, $right => $rght), array('callbacks' => false));
         }
         foreach ($Model->find('all', array('conditions' => $scope, 'fields' => array($Model->primaryKey, $parent), 'order' => $left)) as $array) {
             $Model->create();
             $Model->id = $array[$Model->alias][$Model->primaryKey];
             $this->_setParent($Model, $array[$Model->alias][$parent]);
         }
     } else {
         $db =& ConnectionManager::getDataSource($Model->useDbConfig);
         foreach ($Model->find('all', array('conditions' => $scope, 'fields' => array($Model->primaryKey, $parent), 'order' => $left)) as $array) {
             $path = $this->getpath($Model, $array[$Model->alias][$Model->primaryKey]);
             if ($path == null || count($path) < 2) {
                 $parentId = null;
             } else {
                 $parentId = $path[count($path) - 2][$Model->alias][$Model->primaryKey];
             }
             $Model->updateAll(array($parent => $db->value($parentId, $parent)), array($Model->escapeField() => $array[$Model->alias][$Model->primaryKey]));
         }
     }
     return true;
 }
Example #3
0
 /**
  * Before delete method. Called before all deletes
  *
  * Will delete the current node and all children using the deleteAll method and sync the table
  *
  * @param AppModel $model
  * @return boolean true to continue, false to abort the delete
  */
 function beforeDelete(&$model)
 {
     extract($this->settings[$model->alias]);
     if (!$enabled) {
         return true;
     }
     list($name, $data) = array($model->alias, $model->read());
     $data = $data[$name];
     if (!$data[$right] || !$data[$left]) {
         return true;
     }
     $diff = $data[$right] - $data[$left] + 1;
     if ($diff > 2) {
         $constraint = $scope . ' AND ' . $model->escapeField($left) . ' BETWEEN ' . ($data[$left] + 1) . ' AND ' . ($data[$right] - 1);
         $model->deleteAll($constraint);
     }
     $this->__sync($model, $diff, '-', '> ' . $data[$right]);
     return true;
 }
Example #4
0
 /**
  * Before delete method. Called before all deletes
  *
  * Will delete the current node and all children using the deleteAll method and sync the table
  *
  * @since 1.2
  * @param AppModel $model
  * @return boolean True to continue, false to abort the delete
  */
 function beforeDelete(&$model)
 {
     extract($this->settings[$model->name]);
     list($name, $data) = array($model->name, $model->read());
     $data = $data[$name];
     // If there is no tree data, skip.
     if (!$data[$right] || !$data[$left]) {
         return true;
     }
     $diff = $data[$right] - $data[$left] + 1;
     // Temporarily not an array
     $constraint = $scope . ' AND ' . $left . ' BETWEEN ' . $data[$left] . ' AND ' . $data[$right];
     $model->deleteAll($constraint);
     $this->__sync($model, $diff, '-', '> ' . $data[$right], $scope);
 }
 function deleteAll($conditions, $cascade = true, $callbacks = true)
 {
     parent::deleteAll($conditions, $cascade, $callbacks);
 }