* @copyright Since 2007 PrestaShop SA and Contributors * @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) */ /** * StockManagerInterface : defines a way to manage stock. * * @since 1.5.0 */ interface StockManagerInterface { /** * Checks if the StockManager is available. * * @return bool */ public static function isAvailable(); /** * For a given product, adds a given quantity. * * @param int $id_product * @param int $id_product_attribute * @param Warehouse $warehouse * @param int $quantity * @param int|null $id_stock_movement_reason * @param float $price_te * @param bool $is_usable * @param int $id_supply_order optionnal * * @return bool */ public function addProduct($id_product, $id_product_attribute, Warehouse $warehouse, $quantity, $id_stock_movement_reason, $price_te, $is_usable = true, $id_supply_order = null); /** * For a given product, removes a given quantity. * * @param int $id_product * @param int $id_product_attribute * @param Warehouse $warehouse * @param int $quantity * @param int $id_stock_movement_reason * @param bool $is_usable * @param int $id_order Optionnal * * @return array - empty if an error occurred | details of removed products quantities with corresponding prices otherwise */ public function removeProduct($id_product, $id_product_attribute, Warehouse $warehouse, $quantity, $id_stock_movement_reason, $is_usable = true, $id_order = null); /** * For a given product, returns its physical quantity * If the given product has combinations and $id_product_attribute is null, returns the sum for all combinations. * * @param int $id_product * @param int $id_product_attribute * @param array|int $ids_warehouse optional * @param bool $usable false default - in this case we retrieve all physical quantities, otherwise we retrieve physical quantities flagged as usable * * @return int */ public function getProductPhysicalQuantities($id_product, $id_product_attribute, $ids_warehouse = null, $usable = false); /** * For a given product, returns its real quantity * If the given product has combinations and $id_product_attribute is null, returns the sum for all combinations * Real quantity : (physical_qty + supply_orders_qty - client_orders_qty) * If $usable is defined, real quantity: usable_qty + supply_orders_qty - client_orders_qty. * * @param int $id_product * @param int $id_product_attribute * @param array|int $ids_warehouse optional * @param bool $usable false by default * * @return int */ public function getProductRealQuantities($id_product, $id_product_attribute, $ids_warehouse = null, $usable = false); /** * For a given product, transfers quantities between two warehouses * By default, it manages usable quantities * It is also possible to transfer a usable quantity from warehouse 1 in an unusable quantity to warehouse 2 * It is also possible to transfer a usable quantity from warehouse 1 in an unusable quantity to warehouse 1. * * @param int $id_product * @param int $id_product_attribute * @param int $quantity * @param int $warehouse_from * @param int $warehouse_to * @param bool $usable_from Optional, true by default * @param bool $usable_to Optional, true by default * * @return bool */ public function transferBetweenWarehouses($id_product, $id_product_attribute, $quantity, $warehouse_from, $warehouse_to, $usable_from = true, $usable_to = true); /** * For a given product, returns the time left before being out of stock. * By default, for the given product, it will use sum(quantities removed in all warehouses). * * @param int $id_product * @param int $id_product_attribute * @param int $coverage * @param int $id_warehouse Optional * * @return int time */ public function getProductCoverage($id_product, $id_product_attribute, $coverage, $id_warehouse = null); }