/** * Rend un élément inaccessible (en BDD, ne comporte pas d'action sur le serveur de fichier). * @author Alban Truc * @param MongoId|string $idElement * @param MongoId|string $idUser * @param bool $returnImpactedElements si TRUE, retourne les éléments impactés par l'action * @since 31/05/2014 * @return array|Element */ function disableHandler($idElement, $idUser, $returnImpactedElements = FALSE) { $idElement = new MongoId($idElement); $idUser = new MongoId($idUser); // 11 correspond au droit de lecture et écriture $hasRight = actionAllowed($idElement, $idUser, array('11')); if (!is_array($hasRight)) { if ($hasRight === TRUE) { //récupère l'élément $elementPdoManager = new ElementPdoManager(); $element = $elementPdoManager->findById($idElement); if ($element instanceof Element) { if ($element->getState() == 1) { //récupère le code du refElement de notre élément $refElementPdoManager = new RefElementPdoManager(); $fieldsToReturn = array('code' => TRUE, 'extension' => TRUE); $refElement = $refElementPdoManager->findById($element->getRefElement(), $fieldsToReturn); if (!array_key_exists('error', $refElement)) { //File Server -- 13/06/2014 if (preg_match('/^4/', $refElement['code']) || preg_match('/^9/', $refElement['code'])) { // dossier ou non reconnu, pas d'extension à rajouter $elementName = $element->getName(); } else { $elementName = $element->getName() . $refElement['extension']; } $FSdisableResult = moveToTrash($idUser, $element->getServerPath(), $elementName); if (!is_bool($FSdisableResult) || $FSdisableResult != TRUE) { return $FSdisableResult; } //-- Fin File Server //si le code commence par un 4 (les codes de dossier commencent par un 4) et n'est pas 4002 (dossier vide) if (preg_match('/^4/', $refElement['code']) && $refElement['code'] != '4002') { $serverPath = $element->getServerPath() . $element->getName() . '/'; //notre criteria inclut tous les éléments se trouvant dans le dossier et ses dossiers enfants $elementCriteria = array('state' => (int) 1, 'idOwner' => $idUser, '$or' => array(array('_id' => $idElement), array('serverPath' => new MongoRegex("/^{$serverPath}/i")))); } else { $elementCriteria = array('_id' => $idElement, 'state' => (int) 1); } //pour mettre à jour tous les documents et pas uniquement le premier répondant au critère $options = array('multiple' => TRUE); //désactivation de l'élément et suppression du lien de téléchargement $elementUpdate = array('$set' => array('state' => (int) 0, 'downloadLink' => '')); /* * obligatoirement à récupérer avant la mise à jour, sinon aucun document ne devrait être trouvé * en cas de réussite de cette mise à jour. On ne peut pas non plus faire le même critère avec à la * place un état de 0 parce qu'il se peut qu'il y ait déjà des éléments désactivés en base. * L'id est récupérer pour le critère de mise à jour des droits et le size pour la déduction du * stockage occupé par les éléments (mise à jour du storage du compte utilisateur). */ $impactedElements = $elementPdoManager->find($elementCriteria, array('_id' => TRUE, 'size' => TRUE)); //var_dump($impactedElements); exit(); $elementUpdateResult = $elementPdoManager->update($elementCriteria, $elementUpdate, $options); if (!is_array($elementUpdateResult)) { if ($elementUpdateResult === TRUE) { $updateFolderStatus = updateFolderStatus($element->getServerPath(), $idUser); if (is_bool($updateFolderStatus) && $updateFolderStatus === TRUE) { //séparation en deux tableaux $idImpactedElements = array(); $sizeImpactedElements = array(); foreach ($impactedElements as $impactedElement) { //création d'un tableau contenant uniquement les id des éléments impactés if (isset($impactedElement['_id'])) { $idImpactedElements[] = $impactedElement['_id']; } //création d'un tableau contenant uniquement la taille de chaque élément impacté if (isset($impactedElement['size'])) { $sizeImpactedElements[] = $impactedElement['size']; } } //var_dump($sizeImpactedElements); //désactivation des droits sur ces éléments $rightUpdate = array('$set' => array('state' => (int) 0)); $rightPdoManager = new RightPdoManager(); foreach ($idImpactedElements as $id) { $rightCriteria = array('state' => (int) 1, 'idElement' => $id); //l'opération n'étant pas bloquante, on ne se soucie pour l'instant pas d'un potentiel échec $rightPdoManager->update($rightCriteria, $rightUpdate, $options); } //déduction du stockage occupé par ces éléments dans la collection account $totalSize = array_sum($sizeImpactedElements); //http://www.php.net/manual/function.array-sum.php //var_dump($totalSize); exit(); $accountPdoManager = new AccountPdoManager(); $accountCriteria = array('state' => (int) 1, 'idUser' => $idUser); $accountUpdate = array('$inc' => array('storage' => -$totalSize)); $accountUpdateResult = $accountPdoManager->update($accountCriteria, $accountUpdate); if (!is_array($accountUpdateResult)) { if ($accountUpdateResult === TRUE) { if ($returnImpactedElements === TRUE) { return $idImpactedElements; } else { return TRUE; } } else { return array('error' => 'Did not manage to update the storage value.'); } } else { return $accountUpdateResult; } } else { return $updateFolderStatus; } } else { return array('error' => 'Did not manage to update all elements. The elements that we couldn\'t updates are in this array at the index \'notUpdated\'', 'notUpdated' => $elementPdoManager->find($elementCriteria, array('_id' => TRUE))); } } else { return $elementUpdateResult; } //message d'erreur } else { return $refElement; } //message d'erreur } else { return array('error' => 'Element already inactivated'); } } else { return $element; } //message d'erreur } else { return array('error' => 'Access denied'); } } else { return $hasRight; } }
/** * Permet de désactiver les droits d'un élément pour un user, gestion récursive pour les dossiers. * @author Harry Bellod * @param $idElement | id de l'élément qu'on veut désactiver * @param $idUser | id de l'utilisateur concerné * @param $idOwner | id du propriétaire de l'élément * @since 14/06/2014 * @return bool | array contenant un message d'erreur */ function disableShareRights($idElement, $idUser, $idOwner) { $elementManager = new ElementPdoManager(); $refElementManager = new RefElementPdoManager(); $rightPdoManager = new RightPdoManager(); $element = $elementManager->findById($idElement); $refElement = $refElementManager->findById($element->getRefElement()); $idRefElement = $refElement->getId(); /** @var $isFolder => bool, true si l'élément est bien un dossier, sinon false */ $isFolder = isFolder($idRefElement); if (is_bool($isFolder) && $isFolder == TRUE) { $serverPath = $element->getServerPath() . $element->getName() . '/'; //récupération des éléments contenus dans le dossier $seekElementsInFolder = array('state' => (int) 1, 'serverPath' => new MongoRegex("/^{$serverPath}/i"), 'idOwner' => new MongoId($idOwner)); //liste des éléments contenus dans le dossier $elementsInFolder = $elementManager->find($seekElementsInFolder); foreach ($elementsInFolder as $subElement) { $rightCriteria = array('state' => (int) 1, 'idElement' => new MongoId($subElement->getId()), 'idUser' => new MongoId($idUser)); $rightUpdate = array('$set' => array('state' => (int) 0)); //pour chaque élément on désactive le droit qui lui était affecté $disableElementsInFolder = $rightPdoManager->update($rightCriteria, $rightUpdate); if (is_bool($disableElementsInFolder) && $disableElementsInFolder != TRUE) { return array('error' => 'No match found.'); } } } $rightCriteria = array('state' => (int) 1, 'idElement' => new MongoId($idElement), 'idUser' => new MongoId($idUser)); $rightUpdate = array('$set' => array('state' => (int) 0)); //désactivation de l'élément parent $disableParent = $rightPdoManager->update($rightCriteria, $rightUpdate); if (is_bool($disableParent) && $disableParent != TRUE) { return array('error' => 'No match found.'); } }