/** * Met à jour le stock de l'article passé en paramètre * lorsqu'un client finalise sa commande * * @param Article $article * @param int $qteCommande * @throws ErrorSQLException */ public static function updateQteStock(Article $article, $qteCommande) { $conn = MConnexion::getBdd(); try { $conn->beginTransaction(); $req = $conn->prepare('UPDATE article SET qteStock = ? WHERE numArt = ?'); $qte = $article->getQteStock() - $qteCommande < 0 ? 0 : $article->getQteStock() - $qteCommande; $req->execute([$qte, $article->getNumArt()]); $conn->commit(); $conn = null; } catch (PDOException $e) { $conn->rollBack(); throw new ErrorSQLException($e->getMessage()); } }
/** * Ajoute un article au panier ou augmente de 1 sa quantité s'il est déjà dans le panier * * @param Article $unProduit * @param int $qte * * @throws InvalidArgumentException */ public function ajouterUnProduit(Article $unProduit, $qte) { if ($this->collProduit->cleExiste($unProduit->getNumArt())) { $produitPanier = $this->collProduit->getElement($unProduit->getNumArt()); if ($unProduit->getQte() + $produitPanier->getQte() > $unProduit->getQteStock()) { throw new InvalidArgumentException('Quantité en stock insuffisante'); } $this->augmenterQuantiteProduit($unProduit->getNumArt(), $qte); } else { $this->collProduit->ajouter($unProduit, $unProduit->getNumArt()); } }