⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.1
Server IP:
185.238.29.86
Server:
Linux server2 6.8.12-6-pve #1 SMP PREEMPT_DYNAMIC PMX 6.8.12-6 (2024-12-19T19:05Z) x86_64
Server Software:
nginx/1.18.0
PHP Version:
8.1.31
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
var
/
www
/
olasjoys
/
classes
/
stock
/
View File Name :
StockManagerInterface.php
<?php /** * Copyright since 2007 PrestaShop SA and Contributors * PrestaShop is an International Registered Trademark & Property of PrestaShop SA * * NOTICE OF LICENSE * * This source file is subject to the Open Software License (OSL 3.0) * that is bundled with this package in the file LICENSE.md. * It is also available through the world-wide-web at this URL: * https://opensource.org/licenses/OSL-3.0 * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to license@prestashop.com so we can send you a copy immediately. * * DISCLAIMER * * Do not edit or add to this file if you wish to upgrade PrestaShop to newer * versions in the future. If you wish to customize PrestaShop for your * needs please refer to https://devdocs.prestashop.com/ for more information. * * @author PrestaShop SA and Contributors <contact@prestashop.com> * @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 StockManagerInterface */ 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 $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); }