2015-05-05 03:44:46 +02:00
< ? php
/* Copyright ( C ) 2015 Jean - François Ferry < jfefe @ aternatik . fr >
2016-09-26 02:18:11 +02:00
* Copyright ( C ) 2016 Laurent Destailleur < eldy @ users . sourceforge . net >
2015-05-05 03:44:46 +02:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
2019-09-23 21:55:30 +02:00
* along with this program . If not , see < https :// www . gnu . org / licenses />.
2015-05-05 03:44:46 +02:00
*/
2019-03-06 18:04:36 +01:00
use Luracast\Restler\RestException ;
2015-05-05 03:44:46 +02:00
2023-09-26 18:04:48 +02:00
require_once DOL_DOCUMENT_ROOT . '/commande/class/commande.class.php' ;
2015-05-05 03:44:46 +02:00
/**
2016-06-15 00:52:09 +02:00
* API class for orders
2015-05-05 03:44:46 +02:00
*
2016-09-26 09:34:51 +02:00
* @ access protected
2015-05-05 03:44:46 +02:00
* @ class DolibarrApiAccess { @ requires user , external }
*/
2016-06-15 00:52:09 +02:00
class Orders extends DolibarrApi
2015-05-06 00:55:42 +02:00
{
2020-09-08 21:27:28 +02:00
/**
* @ var array $FIELDS Mandatory fields , checked when create and update object
*/
2023-12-04 12:01:45 +01:00
public static $FIELDS = array (
2020-09-08 21:27:28 +02:00
'socid' ,
'date'
);
/**
* @ var Commande $commande { @ type Commande }
*/
public $commande ;
/**
* Constructor
*/
public function __construct ()
{
global $db , $conf ;
$this -> db = $db ;
$this -> commande = new Commande ( $this -> db );
}
/**
* Get properties of an order object by id
*
* Return an array with order informations
*
* @ param int $id ID of order
* @ param int $contact_list 0 : Returned array of contacts / addresses contains all properties , 1 : Return array contains just id
2023-09-26 18:43:25 +02:00
* @ return array | mixed data without useless information
2020-09-08 21:27:28 +02:00
*
2023-09-26 18:43:25 +02:00
* @ throws RestException
2020-09-08 21:27:28 +02:00
*/
public function get ( $id , $contact_list = 1 )
{
return $this -> _fetch ( $id , '' , '' , $contact_list );
}
/**
* Get properties of an order object by ref
*
* Return an array with order informations
*
* @ param string $ref Ref of object
* @ param int $contact_list 0 : Returned array of contacts / addresses contains all properties , 1 : Return array contains just id
2023-09-26 18:43:25 +02:00
* @ return array | mixed data without useless information
2020-09-08 21:27:28 +02:00
*
* @ url GET ref / { ref }
*
2023-09-26 18:43:25 +02:00
* @ throws RestException
2020-09-08 21:27:28 +02:00
*/
public function getByRef ( $ref , $contact_list = 1 )
{
return $this -> _fetch ( '' , $ref , '' , $contact_list );
}
/**
* Get properties of an order object by ref_ext
*
* Return an array with order informations
*
* @ param string $ref_ext External reference of object
* @ param int $contact_list 0 : Returned array of contacts / addresses contains all properties , 1 : Return array contains just id
2023-09-26 18:43:25 +02:00
* @ return array | mixed data without useless information
2020-09-08 21:27:28 +02:00
*
* @ url GET ref_ext / { ref_ext }
*
2023-09-26 18:43:25 +02:00
* @ throws RestException
2020-09-08 21:27:28 +02:00
*/
public function getByRefExt ( $ref_ext , $contact_list = 1 )
{
return $this -> _fetch ( '' , '' , $ref_ext , $contact_list );
}
/**
* Get properties of an order object
*
* Return an array with order informations
*
2023-09-26 18:43:25 +02:00
* @ param int $id ID of order
2019-10-19 23:42:55 +02:00
* @ param string $ref Ref of object
* @ param string $ref_ext External reference of object
2023-09-26 18:43:25 +02:00
* @ param int $contact_list 0 : Returned array of contacts / addresses contains all properties , 1 : Return array contains just id
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
2023-09-26 18:43:25 +02:00
* @ throws RestException
2020-09-08 21:27:28 +02:00
*/
private function _fetch ( $id , $ref = '' , $ref_ext = '' , $contact_list = 1 )
{
2023-06-19 23:27:24 +02:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'commande' , 'lire' )) {
2020-09-08 21:27:28 +02:00
throw new RestException ( 401 );
}
$result = $this -> commande -> fetch ( $id , $ref , $ref_ext );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
// Add external contacts ids
2022-05-21 15:22:08 +02:00
$tmparray = $this -> commande -> liste_contact ( - 1 , 'external' , $contact_list );
if ( is_array ( $tmparray )) {
$this -> commande -> contacts_ids = $tmparray ;
}
2020-09-08 21:27:28 +02:00
$this -> commande -> fetchObjectLinked ();
2022-03-29 10:32:14 +02:00
// Add online_payment_url, cf #20477
2023-09-26 18:04:48 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/payments.lib.php' ;
2022-03-29 10:32:14 +02:00
$this -> commande -> online_payment_url = getOnlinePaymentUrl ( 0 , 'order' , $this -> commande -> ref );
2020-09-08 21:27:28 +02:00
return $this -> _cleanObjectDatas ( $this -> commande );
}
/**
* List orders
*
* Get a list of orders
*
2023-09-26 18:43:25 +02:00
* @ param string $sortfield Sort field
* @ param string $sortorder Sort order
* @ param int $limit Limit for list
* @ param int $page Page number
* @ param string $thirdparty_ids Thirdparty ids to filter orders of ( example '1' or '1,2,3' ) { @ pattern /^ [ 0 - 9 ,] * $ / i }
2020-09-08 21:27:28 +02:00
* @ param string $sqlfilters Other criteria to filter answers separated by a comma . Syntax example " (t.ref:like:'SO-%') and (t.date_creation:<:'20160101') "
2023-11-16 15:05:32 +01:00
* @ param string $sqlfilterlines Other criteria to filter answers separated by a comma . Syntax example " (tl.fk_product:=:'17') and (tl.price:<:'250') "
2023-09-26 18:04:48 +02:00
* @ param string $properties Restrict the data returned to theses properties . Ignored if empty . Comma separated list of properties names
2020-09-08 21:27:28 +02:00
* @ return array Array of order objects
*
* @ throws RestException 404 Not found
* @ throws RestException 503 Error
*/
2023-11-17 18:24:53 +01:00
public function index ( $sortfield = " t.rowid " , $sortorder = 'ASC' , $limit = 100 , $page = 0 , $thirdparty_ids = '' , $sqlfilters = '' , $sqlfilterlines = '' , $properties = '' )
2020-09-08 21:27:28 +02:00
{
2023-06-19 23:27:24 +02:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'commande' , 'lire' )) {
2021-04-08 19:05:28 +02:00
throw new RestException ( 401 );
}
2020-09-08 21:27:28 +02:00
$obj_ret = array ();
// case of external user, $thirdparty_ids param is ignored and replaced by user's socid
$socids = DolibarrApiAccess :: $user -> socid ? DolibarrApiAccess :: $user -> socid : $thirdparty_ids ;
// If the internal user must only see his customers, force searching by him
$search_sale = 0 ;
2021-02-23 20:46:19 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> societe -> client -> voir && ! $socids ) {
$search_sale = DolibarrApiAccess :: $user -> id ;
}
2020-09-08 21:27:28 +02:00
$sql = " SELECT t.rowid " ;
2021-02-23 20:46:19 +01:00
if (( ! DolibarrApiAccess :: $user -> rights -> societe -> client -> voir && ! $socids ) || $search_sale > 0 ) {
$sql .= " , sc.fk_soc, sc.fk_user " ; // We need these fields in order to filter by sale (including the case where the user can only see his prospects)
}
2023-09-26 18:04:48 +02:00
$sql .= " FROM " . MAIN_DB_PREFIX . " commande AS t LEFT JOIN " . MAIN_DB_PREFIX . " commande_extrafields AS ef ON (ef.fk_object = t.rowid) " ; // Modification VMR Global Solutions to include extrafields as search parameters in the API GET call, so we will be able to filter on extrafields
2020-09-08 21:27:28 +02:00
2021-02-23 20:46:19 +01:00
if (( ! DolibarrApiAccess :: $user -> rights -> societe -> client -> voir && ! $socids ) || $search_sale > 0 ) {
2023-09-26 18:04:48 +02:00
$sql .= " , " . MAIN_DB_PREFIX . " societe_commerciaux as sc " ; // We need this table joined to the select in order to filter by sale
2021-02-23 20:46:19 +01:00
}
2020-09-08 21:27:28 +02:00
2023-09-26 18:04:48 +02:00
$sql .= ' WHERE t.entity IN (' . getEntity ( 'commande' ) . ')' ;
2021-02-23 20:46:19 +01:00
if (( ! DolibarrApiAccess :: $user -> rights -> societe -> client -> voir && ! $socids ) || $search_sale > 0 ) {
$sql .= " AND t.fk_soc = sc.fk_soc " ;
}
if ( $socids ) {
2023-09-26 18:04:48 +02:00
$sql .= " AND t.fk_soc IN ( " . $this -> db -> sanitize ( $socids ) . " ) " ;
2021-02-23 20:46:19 +01:00
}
if ( $search_sale > 0 ) {
$sql .= " AND t.rowid = sc.fk_soc " ; // Join for the needed table to filter by sale
}
2020-09-08 21:27:28 +02:00
// Insert sale filter
2021-02-23 20:46:19 +01:00
if ( $search_sale > 0 ) {
2023-09-26 18:04:48 +02:00
$sql .= " AND sc.fk_user = " . (( int ) $search_sale );
2020-09-08 21:27:28 +02:00
}
// Add sql filters
2021-02-23 20:46:19 +01:00
if ( $sqlfilters ) {
2021-12-20 20:49:32 +01:00
$errormessage = '' ;
2023-02-25 19:48:33 +01:00
$sql .= forgeSQLFromUniversalSearchCriteria ( $sqlfilters , $errormessage );
if ( $errormessage ) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 400 , 'Error when validating parameter sqlfilters -> ' . $errormessage );
2020-09-08 21:27:28 +02:00
}
}
2023-11-16 15:05:32 +01:00
// Add sql filters for lines
if ( $sqlfilterlines ) {
$errormessage = '' ;
$sql .= " AND EXISTS (SELECT tl.rowid FROM " . MAIN_DB_PREFIX . " commandedet AS tl WHERE tl.fk_commande = t.rowid " ;
$sql .= forgeSQLFromUniversalSearchCriteria ( $sqlfilterlines , $errormessage );
$sql .= " ) " ;
if ( $errormessage ) {
throw new RestException ( 400 , 'Error when validating parameter sqlfilterlines -> ' . $errormessage );
}
}
2020-09-19 23:30:29 +02:00
$sql .= $this -> db -> order ( $sortfield , $sortorder );
2020-09-08 21:27:28 +02:00
if ( $limit ) {
2021-02-23 20:46:19 +01:00
if ( $page < 0 ) {
2020-09-08 21:27:28 +02:00
$page = 0 ;
}
$offset = $limit * $page ;
2020-09-19 23:30:29 +02:00
$sql .= $this -> db -> plimit ( $limit + 1 , $offset );
2020-09-08 21:27:28 +02:00
}
dol_syslog ( " API Rest request " );
2020-09-19 23:30:29 +02:00
$result = $this -> db -> query ( $sql );
2020-09-08 21:27:28 +02:00
2021-02-23 20:46:19 +01:00
if ( $result ) {
2020-09-19 23:30:29 +02:00
$num = $this -> db -> num_rows ( $result );
2020-09-08 21:27:28 +02:00
$min = min ( $num , ( $limit <= 0 ? $num : $limit ));
$i = 0 ;
2021-02-23 20:46:19 +01:00
while ( $i < $min ) {
2020-09-19 23:30:29 +02:00
$obj = $this -> db -> fetch_object ( $result );
$commande_static = new Commande ( $this -> db );
2020-09-08 21:27:28 +02:00
if ( $commande_static -> fetch ( $obj -> rowid )) {
// Add external contacts ids
2022-05-21 15:22:08 +02:00
$tmparray = $commande_static -> liste_contact ( - 1 , 'external' , 1 );
if ( is_array ( $tmparray )) {
$commande_static -> contacts_ids = $tmparray ;
}
2022-03-29 09:48:18 +02:00
// Add online_payment_url, cf #20477
2023-09-26 18:04:48 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/payments.lib.php' ;
2022-03-29 09:48:18 +02:00
$commande_static -> online_payment_url = getOnlinePaymentUrl ( 0 , 'order' , $commande_static -> ref );
2023-09-26 18:04:48 +02:00
$obj_ret [] = $this -> _filterObjectProperties ( $this -> _cleanObjectDatas ( $commande_static ), $properties );
2020-09-08 21:27:28 +02:00
}
$i ++ ;
}
} else {
2023-09-26 18:04:48 +02:00
throw new RestException ( 503 , 'Error when retrieve commande list : ' . $this -> db -> lasterror ());
2020-09-08 21:27:28 +02:00
}
2023-12-31 14:11:05 +01:00
2015-05-05 03:44:46 +02:00
return $obj_ret ;
2020-09-08 21:27:28 +02:00
}
/**
* Create a sale order
*
* Exemple : { " socid " : 2 , " date " : 1595196000 , " type " : 0 , " lines " : [{ " fk_product " : 2 , " qty " : 1 }] }
*
* @ param array $request_data Request data
* @ return int ID of order
*/
public function post ( $request_data = null )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
2018-08-09 11:31:48 +02:00
throw new RestException ( 401 , " Insuffisant rights " );
2020-09-08 21:27:28 +02:00
}
// Check mandatory fields
$result = $this -> _validate ( $request_data );
foreach ( $request_data as $field => $value ) {
2023-12-15 12:15:33 +01:00
if ( $field === 'caller' ) {
// Add a mention of caller so on trigger called after action, we can filter to avoid a loop if we try to sync back again whith the caller
$this -> commande -> context [ 'caller' ] = $request_data [ 'caller' ];
continue ;
}
2020-09-08 21:27:28 +02:00
$this -> commande -> $field = $value ;
}
/* if ( isset ( $request_data [ " lines " ])) {
2021-02-23 20:46:19 +01:00
$lines = array ();
foreach ( $request_data [ " lines " ] as $line ) {
array_push ( $lines , ( object ) $line );
}
$this -> commande -> lines = $lines ;
} */
2017-10-19 19:06:48 +02:00
2020-09-08 21:27:28 +02:00
if ( $this -> commande -> create ( DolibarrApiAccess :: $user ) < 0 ) {
throw new RestException ( 500 , " Error creating order " , array_merge ( array ( $this -> commande -> error ), $this -> commande -> errors ));
}
2024-03-31 19:17:58 +02:00
return (( int ) $this -> commande -> id );
2020-09-08 21:27:28 +02:00
}
/**
* Get lines of an order
*
* @ param int $id Id of order
*
* @ url GET { id } / lines
*
2023-01-04 11:36:46 +01:00
* @ return array
2020-09-08 21:27:28 +02:00
*/
public function getLines ( $id )
{
2023-06-19 23:27:24 +02:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'commande' , 'lire' )) {
2018-08-09 11:31:48 +02:00
throw new RestException ( 401 );
}
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
2018-08-09 11:31:48 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
$this -> commande -> getLinesArray ();
$result = array ();
foreach ( $this -> commande -> lines as $line ) {
array_push ( $result , $this -> _cleanObjectDatas ( $line ));
}
return $result ;
}
/**
* Add a line to given order
*
* @ param int $id Id of order to update
* @ param array $request_data OrderLine data
*
* @ url POST { id } / lines
*
* @ return int
*/
public function postLine ( $id , $request_data = null )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
2018-08-09 11:31:48 +02:00
throw new RestException ( 401 );
}
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
2018-08-09 11:31:48 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
2021-04-25 19:21:48 +02:00
2018-08-09 11:31:48 +02:00
$request_data = ( object ) $request_data ;
2021-04-25 19:21:48 +02:00
2022-03-30 12:16:17 +02:00
$request_data -> desc = sanitizeVal ( $request_data -> desc , 'restricthtml' );
$request_data -> label = sanitizeVal ( $request_data -> label );
2021-04-25 19:21:48 +02:00
2020-09-08 21:27:28 +02:00
$updateRes = $this -> commande -> addline (
2021-02-23 20:46:19 +01:00
$request_data -> desc ,
$request_data -> subprice ,
$request_data -> qty ,
$request_data -> tva_tx ,
$request_data -> localtax1_tx ,
$request_data -> localtax2_tx ,
$request_data -> fk_product ,
$request_data -> remise_percent ,
$request_data -> info_bits ,
$request_data -> fk_remise_except ,
2021-04-25 19:21:48 +02:00
$request_data -> price_base_type ? $request_data -> price_base_type : 'HT' ,
$request_data -> subprice ,
2021-02-23 20:46:19 +01:00
$request_data -> date_start ,
$request_data -> date_end ,
$request_data -> product_type ,
$request_data -> rang ,
$request_data -> special_code ,
$request_data -> fk_parent_line ,
$request_data -> fk_fournprice ,
$request_data -> pa_ht ,
$request_data -> label ,
$request_data -> array_options ,
$request_data -> fk_unit ,
$request_data -> origin ,
$request_data -> origin_id ,
$request_data -> multicurrency_subprice ,
$request_data -> ref_ext
2020-09-08 21:27:28 +02:00
);
if ( $updateRes > 0 ) {
return $updateRes ;
} else {
throw new RestException ( 400 , $this -> commande -> error );
}
}
/**
* Update a line to given order
*
2023-09-26 18:43:25 +02:00
* @ param int $id Id of order to update
* @ param int $lineid Id of line to update
* @ param array $request_data OrderLine data
2023-01-04 11:36:46 +01:00
* @ return Object | false Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
* @ url PUT { id } / lines / { lineid }
*/
public function putLine ( $id , $lineid , $request_data = null )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
2018-08-09 11:31:48 +02:00
throw new RestException ( 401 );
}
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
2018-08-09 11:31:48 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
2021-04-25 19:21:48 +02:00
2018-08-09 11:31:48 +02:00
$request_data = ( object ) $request_data ;
2021-04-25 19:21:48 +02:00
2022-03-30 12:16:17 +02:00
$request_data -> desc = sanitizeVal ( $request_data -> desc , 'restricthtml' );
$request_data -> label = sanitizeVal ( $request_data -> label );
2021-04-25 19:21:48 +02:00
2020-09-08 21:27:28 +02:00
$updateRes = $this -> commande -> updateline (
$lineid ,
$request_data -> desc ,
$request_data -> subprice ,
$request_data -> qty ,
$request_data -> remise_percent ,
$request_data -> tva_tx ,
$request_data -> localtax1_tx ,
$request_data -> localtax2_tx ,
2021-04-25 19:21:48 +02:00
$request_data -> price_base_type ? $request_data -> price_base_type : 'HT' ,
2020-09-08 21:27:28 +02:00
$request_data -> info_bits ,
$request_data -> date_start ,
$request_data -> date_end ,
$request_data -> product_type ,
$request_data -> fk_parent_line ,
2020-09-04 21:25:20 +02:00
0 ,
2020-09-08 21:27:28 +02:00
$request_data -> fk_fournprice ,
$request_data -> pa_ht ,
$request_data -> label ,
$request_data -> special_code ,
$request_data -> array_options ,
$request_data -> fk_unit ,
2021-02-23 20:46:19 +01:00
$request_data -> multicurrency_subprice ,
2020-09-08 21:27:28 +02:00
0 ,
2022-05-11 14:26:21 +02:00
$request_data -> ref_ext ,
$request_data -> rang
2020-09-08 21:27:28 +02:00
);
if ( $updateRes > 0 ) {
$result = $this -> get ( $id );
unset ( $result -> line );
return $this -> _cleanObjectDatas ( $result );
}
return false ;
}
/**
2023-01-04 11:36:46 +01:00
* Delete a line of a given order
2020-09-08 21:27:28 +02:00
*
2023-09-26 18:43:25 +02:00
* @ param int $id Id of order to update
* @ param int $lineid Id of line to delete
2023-01-04 11:36:46 +01:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
* @ url DELETE { id } / lines / { lineid }
*
* @ throws RestException 401
* @ throws RestException 404
*/
public function deleteLine ( $id , $lineid )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
2018-08-09 11:31:48 +02:00
throw new RestException ( 401 );
}
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
2018-08-09 11:31:48 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
2023-01-04 11:36:46 +01:00
$updateRes = $this -> commande -> deleteline ( DolibarrApiAccess :: $user , $lineid , $id );
2020-09-08 21:27:28 +02:00
if ( $updateRes > 0 ) {
return $this -> get ( $id );
} else {
throw new RestException ( 405 , $this -> commande -> error );
}
}
/**
* Get contacts of given order
*
* Return an array with contact informations
*
2023-09-26 18:43:25 +02:00
* @ param int $id ID of order
* @ param string $type Type of the contact ( BILLING , SHIPPING , CUSTOMER )
2023-01-04 11:36:46 +01:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
* @ url GET { id } / contacts
*
2023-09-26 18:43:25 +02:00
* @ throws RestException
2020-09-08 21:27:28 +02:00
*/
public function getContacts ( $id , $type = '' )
{
2023-06-19 23:27:24 +02:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'commande' , 'lire' )) {
2020-09-08 21:27:28 +02:00
throw new RestException ( 401 );
}
$result = $this -> commande -> fetch ( $id );
2020-09-14 04:30:04 +02:00
if ( ! $result ) {
2020-09-08 21:27:28 +02:00
throw new RestException ( 404 , 'Order not found' );
}
2020-09-14 04:30:04 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
$contacts = $this -> commande -> liste_contact ( - 1 , 'external' , 0 , $type );
return $this -> _cleanObjectDatas ( $contacts );
}
/**
2019-02-14 00:36:35 +01:00
* Add a contact type of given order
*
* @ param int $id Id of order to update
* @ param int $contactid Id of contact to add
* @ param string $type Type of the contact ( BILLING , SHIPPING , CUSTOMER )
2023-01-04 11:36:46 +01:00
* @ return array
2019-02-14 00:36:35 +01:00
*
* @ url POST { id } / contact / { contactid } / { type }
*
2020-09-08 21:27:28 +02:00
* @ throws RestException 401
* @ throws RestException 404
2019-02-14 00:36:35 +01:00
*/
2020-09-08 21:27:28 +02:00
public function postContact ( $id , $contactid , $type )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
2019-06-16 14:18:26 +02:00
throw new RestException ( 401 );
2019-02-14 00:36:35 +01:00
}
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
2019-02-14 00:36:35 +01:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2019-02-14 00:36:35 +01:00
}
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> add_contact ( $contactid , $type , 'external' );
2019-02-14 00:36:35 +01:00
2020-09-08 21:27:28 +02:00
if ( $result < 0 ) {
throw new RestException ( 500 , 'Error when added the contact' );
}
2019-02-14 00:36:35 +01:00
2020-09-08 21:27:28 +02:00
if ( $result == 0 ) {
throw new RestException ( 304 , 'contact already added' );
}
2020-09-04 12:36:03 +02:00
2020-09-08 21:27:28 +02:00
return array (
'success' => array (
'code' => 200 ,
'message' => 'Contact linked to the order'
)
);
}
2019-02-14 00:36:35 +01:00
2020-09-08 21:27:28 +02:00
/**
2020-09-04 12:36:03 +02:00
* Unlink a contact type of given order
2019-02-14 00:36:35 +01:00
*
2019-02-14 00:42:00 +01:00
* @ param int $id Id of order to update
2020-10-04 23:30:41 +02:00
* @ param int $contactid Id of contact
2020-09-19 22:35:33 +02:00
* @ param string $type Type of the contact ( BILLING , SHIPPING , CUSTOMER ) .
2019-02-14 00:36:35 +01:00
*
2020-09-28 16:57:30 +02:00
* @ url DELETE { id } / contact / { contactid } / { type }
2019-02-14 00:36:35 +01:00
*
2023-01-04 11:36:46 +01:00
* @ return array
2020-02-20 13:42:43 +01:00
*
2020-09-08 21:27:28 +02:00
* @ throws RestException 401
* @ throws RestException 404
2022-03-18 16:14:20 +01:00
* @ throws RestException 500 System error
2019-02-14 00:36:35 +01:00
*/
2020-09-28 16:57:30 +02:00
public function deleteContact ( $id , $contactid , $type )
2020-09-08 21:27:28 +02:00
{
2020-09-14 04:30:04 +02:00
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
2019-06-16 14:18:26 +02:00
throw new RestException ( 401 );
}
2019-02-14 00:36:35 +01:00
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
2020-09-14 04:30:04 +02:00
if ( ! $result ) {
2020-09-08 21:27:28 +02:00
throw new RestException ( 404 , 'Order not found' );
}
2019-02-14 00:36:35 +01:00
2020-09-14 04:30:04 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2019-02-14 00:36:35 +01:00
}
2023-12-04 12:01:45 +01:00
$contacts = $this -> commande -> liste_contact ();
2020-09-08 21:27:28 +02:00
2020-09-19 22:35:33 +02:00
foreach ( $contacts as $contact ) {
2020-10-07 15:01:28 +02:00
if ( $contact [ 'id' ] == $contactid && $contact [ 'code' ] == $type ) {
$result = $this -> commande -> delete_contact ( $contact [ 'rowid' ]);
2020-09-19 22:35:33 +02:00
2020-10-07 15:01:28 +02:00
if ( ! $result ) {
throw new RestException ( 500 , 'Error when deleted the contact' );
}
}
2020-09-08 21:27:28 +02:00
}
return array (
'success' => array (
'code' => 200 ,
'message' => 'Contact unlinked from order'
)
);
}
/**
* Update order general fields ( won ' t touch lines of order )
*
2023-09-26 18:43:25 +02:00
* @ param int $id Id of order to update
* @ param array $request_data Datas
2023-01-04 11:36:46 +01:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*/
public function put ( $id , $request_data = null )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
2018-08-09 11:31:48 +02:00
throw new RestException ( 401 );
}
2016-09-26 09:34:51 +02:00
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
2016-09-26 09:34:51 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2015-05-05 03:44:46 +02:00
}
2020-09-08 21:27:28 +02:00
foreach ( $request_data as $field => $value ) {
2021-02-23 20:46:19 +01:00
if ( $field == 'id' ) {
continue ;
}
2023-12-15 12:15:33 +01:00
if ( $field === 'caller' ) {
// Add a mention of caller so on trigger called after action, we can filter to avoid a loop if we try to sync back again whith the caller
$this -> commande -> context [ 'caller' ] = $request_data [ 'caller' ];
continue ;
}
2025-01-16 10:37:29 +01:00
if ( $field == 'array_options' && is_array ( $value )) {
foreach ( $value as $index => $val ) {
$this -> commande -> array_options [ $index ] = $this -> _checkValForAPI ( $field , $val , $this -> commande );
}
continue ;
}
2025-01-20 12:28:49 +01:00
$this -> commande -> $field = $this -> _checkValForAPI ( $field , $value , $this -> commande );
2020-09-08 21:27:28 +02:00
}
2016-09-26 09:34:51 +02:00
2017-12-01 15:39:18 +01:00
// Update availability
if ( ! empty ( $this -> commande -> availability_id )) {
2021-02-23 20:46:19 +01:00
if ( $this -> commande -> availability ( $this -> commande -> availability_id ) < 0 ) {
throw new RestException ( 400 , 'Error while updating availability' );
}
2017-12-01 15:39:18 +01:00
}
2017-12-19 14:16:51 +01:00
2021-02-23 20:46:19 +01:00
if ( $this -> commande -> update ( DolibarrApiAccess :: $user ) > 0 ) {
2020-09-08 21:27:28 +02:00
return $this -> get ( $id );
} else {
throw new RestException ( 500 , $this -> commande -> error );
}
}
/**
* Delete order
*
* @ param int $id Order ID
* @ return array
*/
public function delete ( $id )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> supprimer ) {
2015-05-05 03:44:46 +02:00
throw new RestException ( 401 );
}
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
2016-09-26 09:34:51 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2015-05-05 03:44:46 +02:00
}
2016-09-26 09:34:51 +02:00
2020-09-08 21:27:28 +02:00
if ( ! $this -> commande -> delete ( DolibarrApiAccess :: $user )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 500 , 'Error when deleting order : ' . $this -> commande -> error );
2020-09-08 21:27:28 +02:00
}
2016-09-26 09:34:51 +02:00
2020-09-08 21:27:28 +02:00
return array (
'success' => array (
'code' => 200 ,
'message' => 'Order deleted'
)
);
}
2016-09-26 09:34:51 +02:00
2020-09-08 21:27:28 +02:00
/**
* Validate an order
*
2018-02-03 20:58:26 +01:00
* If you get a bad value for param notrigger check , provide this in body
2020-09-08 21:27:28 +02:00
* {
* " idwarehouse " : 0 ,
* " notrigger " : 0
* }
*
* @ param int $id Order ID
* @ param int $idwarehouse Warehouse ID
* @ param int $notrigger 1 = Does not execute triggers , 0 = execute triggers
2023-02-20 02:33:44 +01:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
* @ url POST { id } / validate
*
2020-02-20 13:42:43 +01:00
* @ throws RestException 304
2020-09-08 21:27:28 +02:00
* @ throws RestException 401
* @ throws RestException 404
2022-03-18 16:14:20 +01:00
* @ throws RestException 500 System error
2020-09-08 21:27:28 +02:00
*
*/
public function validate ( $id , $idwarehouse = 0 , $notrigger = 0 )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
2015-05-05 03:44:46 +02:00
throw new RestException ( 401 );
}
2020-09-08 21:27:28 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
2016-09-26 09:34:51 +02:00
2021-08-29 22:08:43 +02:00
$result = $this -> commande -> fetch_thirdparty (); // do not check result, as failure is not fatal (used only for mail notification substitutes)
2021-08-29 22:14:19 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2015-05-05 03:44:46 +02:00
}
2016-09-26 09:34:51 +02:00
2016-09-22 12:53:44 +02:00
$result = $this -> commande -> valid ( DolibarrApiAccess :: $user , $idwarehouse , $notrigger );
if ( $result == 0 ) {
2020-09-08 21:27:28 +02:00
throw new RestException ( 304 , 'Error nothing done. May be object is already validated' );
}
if ( $result < 0 ) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 500 , 'Error when validating Order: ' . $this -> commande -> error );
2020-09-08 21:27:28 +02:00
}
$result = $this -> commande -> fetch ( $id );
$this -> commande -> fetchObjectLinked ();
2022-03-29 09:48:18 +02:00
//fix #20477 : add online_payment_url
2023-09-26 18:04:48 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/payments.lib.php' ;
2022-03-29 09:48:18 +02:00
$this -> commande -> online_payment_url = getOnlinePaymentUrl ( 0 , 'order' , $this -> commande -> ref );
2020-09-08 21:27:28 +02:00
return $this -> _cleanObjectDatas ( $this -> commande );
}
/**
* Tag the order as validated ( opened )
*
* Function used when order is reopend after being closed .
*
* @ param int $id Id of the order
*
* @ url POST { id } / reopen
*
* @ return int
*
* @ throws RestException 304
* @ throws RestException 400
* @ throws RestException 401
* @ throws RestException 404
* @ throws RestException 405
*/
public function reopen ( $id )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
throw new RestException ( 401 );
}
if ( empty ( $id )) {
throw new RestException ( 400 , 'Order ID is mandatory' );
}
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
$result = $this -> commande -> set_reopen ( DolibarrApiAccess :: $user );
if ( $result < 0 ) {
throw new RestException ( 405 , $this -> commande -> error );
} elseif ( $result == 0 ) {
throw new RestException ( 304 );
}
return $result ;
}
/**
* Classify the order as invoiced . Could be also called setbilled
*
2023-09-26 18:43:25 +02:00
* @ param int $id Id of the order
2023-01-04 11:36:46 +01:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
* @ url POST { id } / setinvoiced
*
* @ throws RestException 400
* @ throws RestException 401
* @ throws RestException 404
* @ throws RestException 405
*/
public function setinvoiced ( $id )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
throw new RestException ( 401 );
}
if ( empty ( $id )) {
throw new RestException ( 400 , 'Order ID is mandatory' );
}
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
$result = $this -> commande -> classifyBilled ( DolibarrApiAccess :: $user );
if ( $result < 0 ) {
throw new RestException ( 400 , $this -> commande -> error );
}
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
$this -> commande -> fetchObjectLinked ();
return $this -> _cleanObjectDatas ( $this -> commande );
}
/**
* Close an order ( Classify it as " Delivered " )
*
* @ param int $id Order ID
* @ param int $notrigger Disabled triggers
2023-01-04 11:36:46 +01:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
* @ url POST { id } / close
*/
public function close ( $id , $notrigger = 0 )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
throw new RestException ( 401 );
}
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
$result = $this -> commande -> cloture ( DolibarrApiAccess :: $user , $notrigger );
if ( $result == 0 ) {
throw new RestException ( 304 , 'Error nothing done. May be object is already closed' );
2016-09-22 12:53:44 +02:00
}
if ( $result < 0 ) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 500 , 'Error when closing Order: ' . $this -> commande -> error );
2020-09-08 21:27:28 +02:00
}
2017-11-10 16:22:20 +01:00
2017-11-14 01:29:28 +01:00
$result = $this -> commande -> fetch ( $id );
2020-09-08 21:27:28 +02:00
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
$this -> commande -> fetchObjectLinked ();
return $this -> _cleanObjectDatas ( $this -> commande );
}
/**
* Set an order to draft
*
* @ param int $id Order ID
2023-09-26 18:43:25 +02:00
* @ param int $idwarehouse Warehouse ID to use for stock change ( Used only if option STOCK_CALCULATE_ON_VALIDATE_ORDER is on )
2023-01-04 11:36:46 +01:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
* @ url POST { id } / settodraft
*/
public function settodraft ( $id , $idwarehouse = - 1 )
{
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
throw new RestException ( 401 );
}
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
$result = $this -> commande -> setDraft ( DolibarrApiAccess :: $user , $idwarehouse );
if ( $result == 0 ) {
throw new RestException ( 304 , 'Nothing done. May be object is already closed' );
}
if ( $result < 0 ) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 500 , 'Error when closing Order: ' . $this -> commande -> error );
2020-09-08 21:27:28 +02:00
}
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'commande' , $this -> commande -> id )) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-08 21:27:28 +02:00
}
$this -> commande -> fetchObjectLinked ();
return $this -> _cleanObjectDatas ( $this -> commande );
}
/**
* Create an order using an existing proposal .
*
* @ param int $proposalid Id of the proposal
2023-01-04 11:36:46 +01:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*
* @ url POST / createfromproposal / { proposalid }
*
* @ throws RestException 400
* @ throws RestException 401
* @ throws RestException 404
* @ throws RestException 405
*/
public function createOrderFromProposal ( $proposalid )
{
2023-09-26 18:04:48 +02:00
require_once DOL_DOCUMENT_ROOT . '/comm/propal/class/propal.class.php' ;
2020-09-08 21:27:28 +02:00
2023-06-19 23:27:24 +02:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'propal' , 'lire' )) {
2020-09-08 21:27:28 +02:00
throw new RestException ( 401 );
}
if ( ! DolibarrApiAccess :: $user -> rights -> commande -> creer ) {
throw new RestException ( 401 );
}
if ( empty ( $proposalid )) {
throw new RestException ( 400 , 'Proposal ID is mandatory' );
}
$propal = new Propal ( $this -> db );
$result = $propal -> fetch ( $proposalid );
if ( ! $result ) {
throw new RestException ( 404 , 'Proposal not found' );
}
$result = $this -> commande -> createFromProposal ( $propal , DolibarrApiAccess :: $user );
if ( $result < 0 ) {
throw new RestException ( 405 , $this -> commande -> error );
}
$this -> commande -> fetchObjectLinked ();
return $this -> _cleanObjectDatas ( $this -> commande );
}
2021-08-26 17:03:00 +02:00
2021-08-26 12:35:31 +02:00
/**
* Get the shipments of an order
*
* @ param int $id Id of the order
*
* @ url GET { id } / shipment
*
2021-08-28 14:42:31 +02:00
* @ return array
*
2021-08-26 12:35:31 +02:00
* @ throws RestException 401
* @ throws RestException 404
2022-03-18 16:14:20 +01:00
* @ throws RestException 500 System error
2021-08-26 12:35:31 +02:00
*/
2021-08-28 14:42:31 +02:00
public function getOrderShipments ( $id )
2021-08-26 12:35:31 +02:00
{
2023-09-26 18:04:48 +02:00
require_once DOL_DOCUMENT_ROOT . '/expedition/class/expedition.class.php' ;
2021-08-26 12:35:31 +02:00
if ( ! DolibarrApiAccess :: $user -> rights -> expedition -> lire ) {
throw new RestException ( 401 );
}
2021-10-23 11:10:58 +02:00
$obj_ret = array ();
2021-08-27 10:40:33 +02:00
$sql = " SELECT e.rowid " ;
2023-09-26 18:04:48 +02:00
$sql .= " FROM " . MAIN_DB_PREFIX . " expedition as e " ;
$sql .= " JOIN " . MAIN_DB_PREFIX . " expeditiondet as edet " ;
2021-08-27 10:40:33 +02:00
$sql .= " ON e.rowid = edet.fk_expedition " ;
2023-09-26 18:04:48 +02:00
$sql .= " JOIN " . MAIN_DB_PREFIX . " commandedet as cdet " ;
2021-08-27 10:40:33 +02:00
$sql .= " ON edet.fk_origin_line = cdet.rowid " ;
2023-09-26 18:04:48 +02:00
$sql .= " JOIN " . MAIN_DB_PREFIX . " commande as c " ;
2021-08-27 10:40:33 +02:00
$sql .= " ON cdet.fk_commande = c.rowid " ;
2023-09-26 18:04:48 +02:00
$sql .= " WHERE c.rowid = " . (( int ) $id );
2021-08-27 10:40:33 +02:00
$sql .= " GROUP BY e.rowid " ;
$sql .= $this -> db -> order ( " e.rowid " , " ASC " );
2021-08-26 12:35:31 +02:00
dol_syslog ( " API Rest request " );
$result = $this -> db -> query ( $sql );
2020-09-08 21:27:28 +02:00
2021-08-26 12:35:31 +02:00
if ( $result ) {
$num = $this -> db -> num_rows ( $result );
if ( $num <= 0 ) {
throw new RestException ( 404 , 'Shipments not found ' );
}
$i = 0 ;
while ( $i < $num ) {
$obj = $this -> db -> fetch_object ( $result );
$shipment_static = new Expedition ( $this -> db );
if ( $shipment_static -> fetch ( $obj -> rowid )) {
$obj_ret [] = $this -> _cleanObjectDatas ( $shipment_static );
}
$i ++ ;
}
} else {
2023-09-26 18:04:48 +02:00
throw new RestException ( 500 , 'Error when retrieve shipment list : ' . $this -> db -> lasterror ());
2021-08-26 12:35:31 +02:00
}
return $obj_ret ;
}
2020-09-08 21:27:28 +02:00
2021-08-26 17:03:00 +02:00
/**
2021-08-28 17:35:42 +02:00
* Create the shipment of an order
2021-08-26 17:03:00 +02:00
*
* @ param int $id Id of the order
* @ param int $warehouse_id Id of a warehouse
*
* @ url POST { id } / shipment / { warehouse_id }
*
2021-08-28 14:44:13 +02:00
* @ return int
*
2021-08-26 17:03:00 +02:00
* @ throws RestException 401
* @ throws RestException 404
2022-03-18 16:14:20 +01:00
* @ throws RestException 500 System error
2021-08-26 17:03:00 +02:00
*/
2021-08-28 14:43:17 +02:00
public function createOrderShipment ( $id , $warehouse_id )
2021-08-26 17:03:00 +02:00
{
2023-09-26 18:04:48 +02:00
require_once DOL_DOCUMENT_ROOT . '/expedition/class/expedition.class.php' ;
2021-08-26 17:03:00 +02:00
if ( ! DolibarrApiAccess :: $user -> rights -> expedition -> creer ) {
throw new RestException ( 401 );
}
2021-08-27 10:45:04 +02:00
if ( $warehouse_id <= 0 ) {
throw new RestException ( 404 , 'Warehouse not found' );
}
2021-08-26 17:03:00 +02:00
$result = $this -> commande -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Order not found' );
}
$shipment = new Expedition ( $this -> db );
$shipment -> socid = $this -> commande -> socid ;
2023-02-08 13:34:18 +01:00
$shipment -> origin_id = $this -> commande -> id ;
2021-08-26 17:03:00 +02:00
$result = $shipment -> create ( DolibarrApiAccess :: $user );
if ( $result <= 0 ) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 500 , 'Error on creating expedition :' . $this -> db -> lasterror ());
2021-08-26 17:03:00 +02:00
}
foreach ( $this -> commande -> lines as $line ) {
$result = $shipment -> create_line ( $warehouse_id , $line -> id , $line -> qty );
if ( $result <= 0 ) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 500 , 'Error on creating expedition lines:' . $this -> db -> lasterror ());
2021-08-26 17:03:00 +02:00
}
}
return $shipment -> id ;
}
2020-09-08 21:27:28 +02:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.PublicUnderscore
/**
* Clean sensible object datas
*
2023-08-03 09:32:43 +02:00
* @ param Object $object Object to clean
2023-09-26 18:04:48 +02:00
* @ return Object Object with cleaned properties
2020-09-08 21:27:28 +02:00
*/
2023-09-26 18:04:48 +02:00
protected function _cleanObjectDatas ( $object )
2020-09-08 21:27:28 +02:00
{
// phpcs:enable
$object = parent :: _cleanObjectDatas ( $object );
unset ( $object -> note );
unset ( $object -> address );
unset ( $object -> barcode_type );
unset ( $object -> barcode_type_code );
unset ( $object -> barcode_type_label );
unset ( $object -> barcode_type_coder );
2023-09-26 18:04:48 +02:00
return $object ;
2020-09-08 21:27:28 +02:00
}
/**
* Validate fields before create or update object
*
* @ param array $data Array with data to verify
* @ return array
* @ throws RestException
*/
private function _validate ( $data )
{
$commande = array ();
foreach ( Orders :: $FIELDS as $field ) {
2021-02-23 20:46:19 +01:00
if ( ! isset ( $data [ $field ])) {
2023-09-26 18:04:48 +02:00
throw new RestException ( 400 , $field . " field missing " );
2021-02-23 20:46:19 +01:00
}
2020-09-08 21:27:28 +02:00
$commande [ $field ] = $data [ $field ];
}
return $commande ;
}
2015-05-05 03:44:46 +02:00
}