2016-09-22 12:53:44 +02:00
< ? php
2022-01-26 07:29:37 +01:00
/* Copyright ( C ) 2015 Jean - François Ferry < jfefe @ aternatik . fr >
* Copyright ( C ) 2016 Laurent Destailleur < eldy @ users . sourceforge . net >
2022-01-26 07:31:17 +01:00
* Copyright ( C ) 2020 Thibault FOUCART < support @ ptibogxiv . net >
* Copyright ( C ) 2022 ATM Consulting < contact @ atm - consulting . fr >
* Copyright ( C ) 2022 OpenDSI < support @ open - dsi . fr >
2016-09-22 12:53:44 +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 />.
2016-09-22 12:53:44 +02:00
*/
2017-05-04 10:45:20 +02:00
use Luracast\Restler\RestException ;
require_once DOL_DOCUMENT_ROOT . '/comm/propal/class/propal.class.php' ;
2016-09-22 12:53:44 +02:00
/**
* API class for orders
*
2017-07-28 10:16:17 +02:00
* @ access protected
2016-09-22 12:53:44 +02:00
* @ class DolibarrApiAccess { @ requires user , external }
*/
class Proposals extends DolibarrApi
{
2020-10-07 15:01:28 +02:00
/**
2017-10-07 13:09:31 +02:00
* @ var array $FIELDS Mandatory fields , checked when create and update object
*/
static $FIELDS = array (
'socid'
);
/**
2017-12-28 12:43:26 +01:00
* @ var Propal $propal { @ type Propal }
2017-10-07 13:09:31 +02:00
*/
public $propal ;
/**
* Constructor
*/
2019-02-27 20:45:07 +01:00
public function __construct ()
2017-10-07 13:09:31 +02:00
{
2016-09-22 12:53:44 +02:00
global $db , $conf ;
$this -> db = $db ;
2017-10-07 13:09:31 +02:00
$this -> propal = new Propal ( $this -> db );
}
/**
* Get properties of a commercial proposal object
*
* Return an array with commercial proposal informations
*
2019-02-12 17:54:59 +01:00
* @ param int $id ID of commercial proposal
2019-02-13 16:39:17 +01:00
* @ param int $contact_list 0 : Returned array of contacts / addresses contains all properties , 1 : Return array contains just id
2017-10-07 13:09:31 +02:00
* @ return array | mixed data without useless information
2016-09-22 12:53:44 +02:00
*
2017-10-07 13:09:31 +02:00
* @ throws RestException
*/
2019-02-27 20:45:07 +01:00
public function get ( $id , $contact_list = 1 )
2017-10-07 13:09:31 +02:00
{
2020-10-07 15:01:28 +02:00
return $this -> _fetch ( $id , '' , '' , $contact_list );
}
/**
* Get properties of an proposal object by ref
*
* Return an array with proposal 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
* @ return array | mixed data without useless information
*
* @ url GET ref / { ref }
*
* @ throws RestException
*/
public function getByRef ( $ref , $contact_list = 1 )
{
return $this -> _fetch ( '' , $ref , '' , $contact_list );
}
/**
* Get properties of an proposal object by ref_ext
*
* Return an array with proposal 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
* @ return array | mixed data without useless information
*
* @ url GET ref_ext / { ref_ext }
*
* @ throws RestException
*/
public function getByRefExt ( $ref_ext , $contact_list = 1 )
{
return $this -> _fetch ( '' , '' , $ref_ext , $contact_list );
2020-03-03 13:39:22 +01:00
}
2020-10-07 15:01:28 +02:00
/**
* Get properties of an proposal object
*
* Return an array with proposal informations
*
* @ param int $id ID of order
2020-03-03 13:39:22 +01:00
* @ param string $ref Ref of object
* @ param string $ref_ext External reference of object
2020-10-07 15:01:28 +02:00
* @ param int $contact_list 0 : Returned array of contacts / addresses contains all properties , 1 : Return array contains just id
* @ return array | mixed data without useless information
*
* @ throws RestException
*/
private function _fetch ( $id , $ref = '' , $ref_ext = '' , $contact_list = 1 )
{
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> lire ) {
2016-09-22 12:53:44 +02:00
throw new RestException ( 401 );
}
2017-07-28 10:16:17 +02:00
2020-03-06 14:38:06 +01:00
$result = $this -> propal -> fetch ( $id , $ref , $ref_ext );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2017-10-07 13:09:31 +02:00
throw new RestException ( 404 , 'Commercial Proposal not found' );
}
2017-07-28 10:16:17 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2016-09-22 12:53:44 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2017-07-28 10:16:17 +02:00
2019-02-12 17:54:59 +01:00
// Add external contacts ids.
2022-05-21 15:22:08 +02:00
$tmparray = $this -> propal -> liste_contact ( - 1 , 'external' , $contact_list );
if ( is_array ( $tmparray )) {
$this -> propal -> contacts_ids = $tmparray ;
}
2017-10-07 13:09:31 +02:00
$this -> propal -> fetchObjectLinked ();
2022-05-21 15:22:08 +02:00
2016-09-22 12:53:44 +02:00
return $this -> _cleanObjectDatas ( $this -> propal );
2017-10-07 13:09:31 +02:00
}
/**
* List commercial proposals
*
* Get a list of commercial proposals
*
* @ param string $sortfield Sort field
* @ param string $sortorder Sort order
* @ param int $limit Limit for list
* @ param int $page Page number
2019-08-30 17:14:59 +02:00
* @ param string $thirdparty_ids Thirdparty ids to filter commercial proposals ( example '1' or '1,2,3' ) { @ pattern /^ [ 0 - 9 ,] * $ / i }
2017-10-07 13:09:31 +02:00
* @ param string $sqlfilters Other criteria to filter answers separated by a comma . Syntax example " (t.ref:like:'SO-%') and (t.datec:<:'20160101') "
* @ return array Array of order objects
*/
2020-10-07 15:01:28 +02:00
public function index ( $sortfield = " t.rowid " , $sortorder = 'ASC' , $limit = 100 , $page = 0 , $thirdparty_ids = '' , $sqlfilters = '' )
{
2017-10-07 13:09:31 +02:00
global $db , $conf ;
2021-04-08 19:05:28 +02:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> lire ) {
throw new RestException ( 401 );
}
2017-10-07 13:09:31 +02:00
$obj_ret = array ();
// case of external user, $thirdparty_ids param is ignored and replaced by user's socid
2019-09-06 10:53:05 +02:00
$socids = DolibarrApiAccess :: $user -> socid ? DolibarrApiAccess :: $user -> socid : $thirdparty_ids ;
2017-10-07 13:09:31 +02:00
// If the internal user must only see his customers, force searching by him
$search_sale = 0 ;
2021-02-23 18:59:19 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> societe -> client -> voir && ! $socids ) {
$search_sale = DolibarrApiAccess :: $user -> id ;
}
2017-10-07 13:09:31 +02:00
$sql = " SELECT t.rowid " ;
2021-02-23 18:59: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)
}
2020-03-12 12:45:44 +01:00
$sql .= " FROM " . MAIN_DB_PREFIX . " propal as t " ;
2017-10-07 13:09:31 +02:00
2021-02-23 18:59:19 +01:00
if (( ! DolibarrApiAccess :: $user -> rights -> societe -> client -> voir && ! $socids ) || $search_sale > 0 ) {
$sql .= " , " . MAIN_DB_PREFIX . " societe_commerciaux as sc " ; // We need this table joined to the select in order to filter by sale
}
2017-10-07 13:09:31 +02:00
2020-03-12 12:45:44 +01:00
$sql .= ' WHERE t.entity IN (' . getEntity ( 'propal' ) . ')' ;
2021-02-23 18:59:19 +01:00
if (( ! DolibarrApiAccess :: $user -> rights -> societe -> client -> voir && ! $socids ) || $search_sale > 0 ) {
$sql .= " AND t.fk_soc = sc.fk_soc " ;
}
if ( $socids ) {
2021-03-22 11:30:18 +01:00
$sql .= " AND t.fk_soc IN ( " . $this -> db -> sanitize ( $socids ) . " ) " ;
2021-02-23 18:59:19 +01:00
}
if ( $search_sale > 0 ) {
$sql .= " AND t.rowid = sc.fk_soc " ; // Join for the needed table to filter by sale
}
2017-10-07 13:09:31 +02:00
// Insert sale filter
2021-02-23 18:59:19 +01:00
if ( $search_sale > 0 ) {
2021-03-22 11:30:18 +01:00
$sql .= " AND sc.fk_user = " . (( int ) $search_sale );
2017-10-07 13:09:31 +02:00
}
// Add sql filters
2021-02-23 18:59:19 +01:00
if ( $sqlfilters ) {
2021-12-20 20:49:32 +01:00
$errormessage = '' ;
if ( ! DolibarrApi :: _checkFilters ( $sqlfilters , $errormessage )) {
throw new RestException ( 503 , 'Error when validating parameter sqlfilters -> ' . $errormessage );
2017-10-07 13:09:31 +02:00
}
2021-05-03 14:58:29 +02:00
$regexstring = '\(([^:\'\(\)]+:[^:\'\(\)]+:[^\(\)]+)\)' ;
2020-03-12 12:45:44 +01:00
$sql .= " AND ( " . preg_replace_callback ( '/' . $regexstring . '/' , 'DolibarrApi::_forge_criteria_callback' , $sqlfilters ) . " ) " ;
2017-10-07 13:09:31 +02:00
}
2020-09-19 23:30:29 +02:00
$sql .= $this -> db -> order ( $sortfield , $sortorder );
2020-03-12 12:45:44 +01:00
if ( $limit ) {
2021-02-23 18:59:19 +01:00
if ( $page < 0 ) {
2017-10-07 13:09:31 +02:00
$page = 0 ;
}
$offset = $limit * $page ;
2020-09-19 23:30:29 +02:00
$sql .= $this -> db -> plimit ( $limit + 1 , $offset );
2017-10-07 13:09:31 +02:00
}
2020-10-07 15:01:28 +02:00
dol_syslog ( " API Rest request " );
$result = $this -> db -> query ( $sql );
2017-10-07 13:09:31 +02:00
2021-02-23 18:59:19 +01:00
if ( $result ) {
2020-09-19 23:30:29 +02:00
$num = $this -> db -> num_rows ( $result );
2017-10-07 13:09:31 +02:00
$min = min ( $num , ( $limit <= 0 ? $num : $limit ));
2017-12-01 15:39:18 +01:00
$i = 0 ;
2021-02-23 18:59:19 +01:00
while ( $i < $min ) {
2020-09-19 23:30:29 +02:00
$obj = $this -> db -> fetch_object ( $result );
$proposal_static = new Propal ( $this -> db );
2020-03-12 12:45:44 +01:00
if ( $proposal_static -> fetch ( $obj -> rowid )) {
2018-05-28 09:42:24 +02:00
// Add external contacts ids
2022-05-21 15:22:08 +02:00
$tmparray = $proposal_static -> liste_contact ( - 1 , 'external' , 1 );
if ( is_array ( $tmparray )) {
$proposal_static -> contacts_ids = $tmparray ;
}
2017-11-06 11:06:31 +01:00
$obj_ret [] = $this -> _cleanObjectDatas ( $proposal_static );
2017-10-07 13:09:31 +02:00
}
$i ++ ;
}
2020-05-21 15:05:19 +02:00
} else {
2020-09-19 23:30:29 +02:00
throw new RestException ( 503 , 'Error when retrieve propal list : ' . $this -> db -> lasterror ());
2017-10-07 13:09:31 +02:00
}
2020-03-12 12:45:44 +01:00
if ( ! count ( $obj_ret )) {
2017-11-06 11:06:31 +01:00
throw new RestException ( 404 , 'No proposal found' );
2017-10-07 13:09:31 +02:00
}
2016-09-22 12:53:44 +02:00
return $obj_ret ;
2017-10-07 13:09:31 +02:00
}
/**
* Create commercial proposal object
*
* @ param array $request_data Request data
2017-12-28 12:43:26 +01:00
* @ return int ID of proposal
2017-10-07 13:09:31 +02:00
*/
2020-10-07 15:01:28 +02:00
public function post ( $request_data = null )
{
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
throw new RestException ( 401 , " Insuffisant rights " );
}
// Check mandatory fields
$result = $this -> _validate ( $request_data );
2016-09-22 12:53:44 +02:00
2020-03-12 12:45:44 +01:00
foreach ( $request_data as $field => $value ) {
2017-10-07 13:09:31 +02:00
$this -> propal -> $field = $value ;
}
/* if ( isset ( $request_data [ " lines " ])) {
2021-02-23 18:59:19 +01:00
$lines = array ();
foreach ( $request_data [ " lines " ] as $line ) {
array_push ( $lines , ( object ) $line );
}
$this -> propal -> lines = $lines ;
} */
2017-10-07 13:09:31 +02:00
if ( $this -> propal -> create ( DolibarrApiAccess :: $user ) < 0 ) {
throw new RestException ( 500 , " Error creating order " , array_merge ( array ( $this -> propal -> error ), $this -> propal -> errors ));
}
return $this -> propal -> id ;
2020-10-07 15:01:28 +02:00
}
2017-10-07 13:09:31 +02:00
/**
* Get lines of a commercial proposal
*
2022-01-26 08:50:57 +01:00
* @ param int $id Id of commercial proposal
* @ param string $sqlfilters Other criteria to filter answers separated by a comma . d is the alias for proposal lines table , p is the alias for product table . " Syntax example " ( p . ref : like : 'SO-%' ) and ( d . date_start :<: '20220101' ) "
2017-10-07 13:09:31 +02:00
*
* @ url GET { id } / lines
*
* @ return int
*/
2022-01-26 08:50:57 +01:00
public function getLines ( $id , $sqlfilters = '' )
2020-10-07 15:01:28 +02:00
{
2022-01-26 08:50:57 +01:00
$filters = " " ;
2020-10-07 15:01:28 +02:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> lire ) {
throw new RestException ( 401 );
}
2019-02-03 14:29:45 +01:00
2020-10-07 15:01:28 +02:00
$result = $this -> propal -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Commercial Proposal not found' );
}
2019-02-03 14:29:45 +01:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2020-10-07 15:01:28 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2022-01-26 08:50:57 +01:00
if ( ! empty ( $sqlfilters )) {
if ( ! DolibarrApi :: _checkFilters ( $sqlfilters )) {
throw new RestException ( 503 , 'Error when validating parameter sqlfilters ' . $sqlfilters );
}
$regexstring = '\(([^:\'\(\)]+:[^:\'\(\)]+:[^:\(\)]+)\)' ;
$filters = " AND ( " . preg_replace_callback ( '/' . $regexstring . '/' , 'DolibarrApi::_forge_criteria_callback' , $sqlfilters ) . " ) " ;
}
$this -> propal -> getLinesArray ( $filters );
2020-10-07 15:01:28 +02:00
$result = array ();
foreach ( $this -> propal -> lines as $line ) {
array_push ( $result , $this -> _cleanObjectDatas ( $line ));
}
return $result ;
2017-10-07 13:09:31 +02:00
}
/**
* Add a line to given commercial proposal
*
* @ param int $id Id of commercial proposal to update
* @ param array $request_data Commercial proposal line data
*
2022-01-26 07:29:37 +01:00
* @ url POST { id } / line
2017-10-07 13:09:31 +02:00
*
* @ return int
*/
2019-02-27 20:45:07 +01:00
public function postLine ( $id , $request_data = null )
2017-10-07 13:09:31 +02:00
{
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
2021-02-23 18:59:19 +01:00
throw new RestException ( 401 );
2017-10-06 15:01:31 +02:00
}
2017-07-28 10:16:17 +02:00
2017-10-07 13:09:31 +02:00
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2020-10-07 15:01:28 +02:00
throw new RestException ( 404 , 'Commercial Proposal not found' );
2017-10-07 13:09:31 +02:00
}
2017-07-28 10:16:17 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2017-10-06 15:01:31 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2020-10-07 15:01:28 +02:00
$request_data = ( object ) $request_data ;
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-10-07 15:01:28 +02:00
$updateRes = $this -> propal -> addline (
2021-02-23 18:59: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 ,
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 18:59:19 +01:00
$request_data -> info_bits ,
$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 -> date_start ,
$request_data -> date_end ,
$request_data -> array_options ,
$request_data -> fk_unit ,
$request_data -> origin ,
$request_data -> origin_id ,
$request_data -> multicurrency_subprice ,
$request_data -> fk_remise_except
2020-10-07 15:01:28 +02:00
);
if ( $updateRes > 0 ) {
return $updateRes ;
} else {
throw new RestException ( 400 , $this -> propal -> error );
}
}
2017-10-07 13:09:31 +02:00
2022-01-26 07:29:37 +01:00
/**
* Add lines to given commercial proposal
*
* @ param int $id Id of commercial proposal to update
* @ param array $request_data Commercial proposal line data
*
* @ url POST { id } / lines
*
* @ return int
*/
public function postLines ( $id , $request_data = null )
{
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
throw new RestException ( 401 );
}
$result = $this -> propal -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Commercial Proposal not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
$errors = [];
$this -> db -> begin ();
2022-01-26 07:35:26 +01:00
foreach ( $request_data as $TData ) {
if ( empty ( $TData [ 0 ])) $TData = array ( $TData );
2022-01-26 07:29:37 +01:00
foreach ( $TData as $lineData ) {
2022-01-26 07:35:26 +01:00
$line = ( object ) $lineData ;
2022-01-26 07:29:37 +01:00
$updateRes = $this -> propal -> addline (
$line -> desc ,
$line -> subprice ,
$line -> qty ,
$line -> tva_tx ,
$line -> localtax1_tx ,
$line -> localtax2_tx ,
$line -> fk_product ,
$line -> remise_percent ,
'HT' ,
0 ,
$line -> info_bits ,
$line -> product_type ,
$line -> rang ,
$line -> special_code ,
$line -> fk_parent_line ,
$line -> fk_fournprice ,
$line -> pa_ht ,
$line -> label ,
$line -> date_start ,
$line -> date_end ,
$line -> array_options ,
$line -> fk_unit ,
$line -> origin ,
$line -> origin_id ,
$line -> multicurrency_subprice ,
$line -> fk_remise_except
);
if ( $updateRes < 0 ) {
$errors [ 'lineLabel' ] = $line -> label ;
$errors [ 'msg' ] = $this -> propal -> errors ;
}
}
}
if ( empty ( $errors )) {
$this -> db -> commit ();
return count ( $request_data );
} else {
$this -> db -> rollback ();
throw new RestException ( 400 , implode ( " , " , $errors ));
}
}
2017-10-07 13:09:31 +02:00
/**
* Update a line of given commercial proposal
*
* @ param int $id Id of commercial proposal to update
* @ param int $lineid Id of line to update
* @ param array $request_data Commercial proposal line data
*
* @ url PUT { id } / lines / { lineid }
*
* @ return object
*/
2019-02-27 20:45:07 +01:00
public function putLine ( $id , $lineid , $request_data = null )
2017-10-07 13:09:31 +02:00
{
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
2017-10-06 15:01:31 +02:00
throw new RestException ( 401 );
}
2017-07-28 10:16:17 +02:00
2017-10-07 13:09:31 +02:00
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( $result <= 0 ) {
2017-10-07 13:09:31 +02:00
throw new RestException ( 404 , 'Proposal not found' );
}
2017-07-28 10:16:17 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2017-10-06 15:01:31 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2021-02-23 18:59:19 +01:00
}
2017-10-07 13:09:31 +02:00
2021-02-23 18:59:19 +01:00
$request_data = ( object ) $request_data ;
2017-10-07 13:09:31 +02:00
2022-08-25 14:31:47 +02:00
if ( isset ( $request_data -> desc )) {
$request_data -> desc = sanitizeVal ( $request_data -> desc , 'restricthtml' );
}
if ( isset ( $request_data -> label )) {
$request_data -> label = sanitizeVal ( $request_data -> label );
}
2021-04-25 19:21:48 +02:00
2021-02-23 18:59:19 +01:00
$propalline = new PropaleLigne ( $this -> db );
$result = $propalline -> fetch ( $lineid );
if ( $result <= 0 ) {
throw new RestException ( 404 , 'Proposal line not found' );
}
2017-10-07 13:09:31 +02:00
2020-10-07 15:01:28 +02:00
$updateRes = $this -> propal -> updateline (
$lineid ,
isset ( $request_data -> subprice ) ? $request_data -> subprice : $propalline -> subprice ,
isset ( $request_data -> qty ) ? $request_data -> qty : $propalline -> qty ,
isset ( $request_data -> remise_percent ) ? $request_data -> remise_percent : $propalline -> remise_percent ,
isset ( $request_data -> tva_tx ) ? $request_data -> tva_tx : $propalline -> tva_tx ,
isset ( $request_data -> localtax1_tx ) ? $request_data -> localtax1_tx : $propalline -> localtax1_tx ,
isset ( $request_data -> localtax2_tx ) ? $request_data -> localtax2_tx : $propalline -> localtax2_tx ,
isset ( $request_data -> desc ) ? $request_data -> desc : $propalline -> desc ,
2021-04-25 19:21:48 +02:00
isset ( $request_data -> price_base_type ) ? $request_data -> price_base_type : 'HT' ,
2020-10-07 15:01:28 +02:00
isset ( $request_data -> info_bits ) ? $request_data -> info_bits : $propalline -> info_bits ,
isset ( $request_data -> special_code ) ? $request_data -> special_code : $propalline -> special_code ,
isset ( $request_data -> fk_parent_line ) ? $request_data -> fk_parent_line : $propalline -> fk_parent_line ,
0 ,
isset ( $request_data -> fk_fournprice ) ? $request_data -> fk_fournprice : $propalline -> fk_fournprice ,
isset ( $request_data -> pa_ht ) ? $request_data -> pa_ht : $propalline -> pa_ht ,
isset ( $request_data -> label ) ? $request_data -> label : $propalline -> label ,
isset ( $request_data -> product_type ) ? $request_data -> product_type : $propalline -> product_type ,
isset ( $request_data -> date_start ) ? $request_data -> date_start : $propalline -> date_start ,
isset ( $request_data -> date_end ) ? $request_data -> date_end : $propalline -> date_end ,
isset ( $request_data -> array_options ) ? $request_data -> array_options : $propalline -> array_options ,
isset ( $request_data -> fk_unit ) ? $request_data -> fk_unit : $propalline -> fk_unit ,
2022-05-11 14:26:21 +02:00
isset ( $request_data -> multicurrency_subprice ) ? $request_data -> multicurrency_subprice : $propalline -> subprice ,
0 ,
isset ( $request_data -> rang ) ? $request_data -> rang : $propalline -> rang
2020-10-07 15:01:28 +02:00
);
if ( $updateRes > 0 ) {
$result = $this -> get ( $id );
unset ( $result -> line );
return $this -> _cleanObjectDatas ( $result );
}
return false ;
2017-10-07 13:09:31 +02:00
}
/**
* Delete a line of given commercial proposal
*
*
* @ param int $id Id of commercial proposal to update
* @ param int $lineid Id of line to delete
*
* @ url DELETE { id } / lines / { lineid }
*
* @ return int
2020-02-20 13:42:43 +01:00
*
2020-10-07 15:01:28 +02:00
* @ throws RestException 401
* @ throws RestException 404
2017-10-07 13:09:31 +02:00
*/
2020-10-07 15:01:28 +02:00
public function deleteLine ( $id , $lineid )
{
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
2020-10-07 15:01:28 +02:00
throw new RestException ( 401 );
2017-12-01 15:39:18 +01:00
}
2017-07-28 10:16:17 +02:00
2017-12-01 15:39:18 +01:00
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2017-12-01 15:39:18 +01:00
throw new RestException ( 404 , 'Proposal not found' );
}
2017-07-28 10:16:17 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2017-12-01 15:39:18 +01:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2017-10-07 14:11:01 +02:00
2017-12-21 16:50:18 +01:00
// TODO Check the lineid $lineid is a line of ojbect
2017-12-01 15:39:18 +01:00
$updateRes = $this -> propal -> deleteline ( $lineid );
if ( $updateRes > 0 ) {
return $this -> get ( $id );
2020-05-21 15:05:19 +02:00
} else {
2017-12-21 16:50:18 +01:00
throw new RestException ( 405 , $this -> propal -> error );
}
2017-10-07 13:09:31 +02:00
}
2020-10-07 15:01:28 +02:00
/**
2019-02-12 17:54:59 +01:00
* Add a contact type of given commercial proposal
*
* @ param int $id Id of commercial proposal to update
* @ param int $contactid Id of contact to add
* @ param string $type Type of the contact ( BILLING , SHIPPING , CUSTOMER )
*
* @ url POST { id } / contact / { contactid } / { type }
*
* @ return int
2020-02-20 13:42:43 +01:00
*
2020-10-07 15:01:28 +02:00
* @ throws RestException 401
* @ throws RestException 404
2019-02-12 17:54:59 +01:00
*/
2020-10-07 15:01:28 +02:00
public function postContact ( $id , $contactid , $type )
{
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
throw new RestException ( 401 );
}
2019-02-12 17:54:59 +01:00
2020-10-07 15:01:28 +02:00
$result = $this -> propal -> fetch ( $id );
2019-02-12 17:54:59 +01:00
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2019-02-12 17:54:59 +01:00
throw new RestException ( 404 , 'Proposal not found' );
}
2020-10-07 15:01:28 +02:00
if ( ! in_array ( $type , array ( 'BILLING' , 'SHIPPING' , 'CUSTOMER' ), true )) {
throw new RestException ( 500 , 'Availables types: BILLING, SHIPPING OR CUSTOMER' );
}
2019-02-12 17:54:59 +01:00
2020-10-07 15:01:28 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2019-02-12 17:54:59 +01:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2020-10-07 15:01:28 +02:00
$result = $this -> propal -> add_contact ( $contactid , $type , 'external' );
2019-02-12 17:54:59 +01:00
2020-10-07 15:01:28 +02:00
if ( ! $result ) {
throw new RestException ( 500 , 'Error when added the contact' );
}
2019-02-12 17:54:59 +01:00
2020-10-07 15:01:28 +02:00
return $this -> propal ;
}
2019-02-12 17:54:59 +01:00
2020-10-07 15:01:28 +02:00
/**
* Delete a contact type of given commercial proposal
*
* @ param int $id Id of commercial proposal to update
* @ param int $contactid Row key of the contact in the array contact_ids .
* @ param string $type Type of the contact ( BILLING , SHIPPING , CUSTOMER ) .
*
* @ url DELETE { id } / contact / { contactid } / { type }
*
* @ return int
*
* @ throws RestException 401
* @ throws RestException 404
2022-03-18 16:14:20 +01:00
* @ throws RestException 500 System error
2020-10-07 15:01:28 +02:00
*/
public function deleteContact ( $id , $contactid , $type )
{
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
throw new RestException ( 401 );
}
2019-02-12 17:54:59 +01:00
2020-10-07 15:01:28 +02:00
$result = $this -> propal -> fetch ( $id );
2019-02-12 17:54:59 +01:00
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2019-02-12 17:54:59 +01:00
throw new RestException ( 404 , 'Proposal not found' );
}
2020-10-07 15:01:28 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2019-02-12 17:54:59 +01:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2022-05-18 23:28:53 +02:00
$contacts = $this -> propal -> liste_contact ();
2019-02-12 17:54:59 +01:00
2020-10-05 12:21:54 +02:00
foreach ( $contacts as $contact ) {
if ( $contact [ 'id' ] == $contactid && $contact [ 'code' ] == $type ) {
$result = $this -> propal -> delete_contact ( $contact [ 'rowid' ]);
2019-02-12 17:54:59 +01:00
2020-10-05 12:21:54 +02:00
if ( ! $result ) {
throw new RestException ( 500 , 'Error when deleted the contact' );
}
}
}
return $this -> _cleanObjectDatas ( $this -> propal );
2020-10-07 15:01:28 +02:00
}
2019-02-12 17:54:59 +01:00
2017-10-07 13:09:31 +02:00
/**
* Update commercial proposal general fields ( won ' t touch lines of commercial proposal )
*
* @ param int $id Id of commercial proposal to update
* @ param array $request_data Datas
*
* @ return int
2020-10-07 15:01:28 +02:00
*/
public function put ( $id , $request_data = null )
{
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
throw new RestException ( 401 );
}
2017-07-28 10:16:17 +02:00
2017-10-07 13:09:31 +02:00
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2017-10-07 13:09:31 +02:00
throw new RestException ( 404 , 'Proposal not found' );
}
2017-07-28 10:16:17 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2016-09-22 12:53:44 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2019-02-27 20:45:07 +01:00
foreach ( $request_data as $field => $value ) {
2021-02-23 18:59:19 +01:00
if ( $field == 'id' ) {
continue ;
}
2017-10-07 13:09:31 +02:00
$this -> propal -> $field = $value ;
}
2017-12-19 12:37:37 +01:00
// update end of validity date
2021-02-23 18:59:19 +01:00
if ( empty ( $this -> propal -> fin_validite ) && ! empty ( $this -> propal -> duree_validite ) && ! empty ( $this -> propal -> date_creation )) {
2017-12-19 12:37:37 +01:00
$this -> propal -> fin_validite = $this -> propal -> date_creation + ( $this -> propal -> duree_validite * 24 * 3600 );
}
2021-02-23 18:59:19 +01:00
if ( ! empty ( $this -> propal -> fin_validite )) {
if ( $this -> propal -> set_echeance ( DolibarrApiAccess :: $user , $this -> propal -> fin_validite ) < 0 ) {
2017-12-19 12:37:37 +01:00
throw new RestException ( 500 , $this -> propal -> error );
}
}
2021-02-23 18:59:19 +01:00
if ( $this -> propal -> update ( DolibarrApiAccess :: $user ) > 0 ) {
2017-10-07 13:09:31 +02:00
return $this -> get ( $id );
2020-05-21 15:05:19 +02:00
} else {
2017-12-21 16:50:18 +01:00
throw new RestException ( 500 , $this -> propal -> error );
2017-12-01 15:39:18 +01:00
}
2017-10-07 13:09:31 +02:00
}
/**
* Delete commercial proposal
*
* @ param int $id Commercial proposal ID
*
* @ return array
*/
2019-02-27 20:45:07 +01:00
public function delete ( $id )
2017-10-07 13:09:31 +02:00
{
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> supprimer ) {
2016-09-22 12:53:44 +02:00
throw new RestException ( 401 );
}
2017-10-07 13:09:31 +02:00
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2017-10-07 13:09:31 +02:00
throw new RestException ( 404 , 'Commercial Proposal not found' );
}
2017-07-28 10:16:17 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2016-09-22 12:53:44 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2017-07-28 10:16:17 +02:00
2020-03-12 12:45:44 +01:00
if ( ! $this -> propal -> delete ( DolibarrApiAccess :: $user )) {
2017-10-07 13:09:31 +02:00
throw new RestException ( 500 , 'Error when delete Commercial Proposal : ' . $this -> propal -> error );
}
return array (
'success' => array (
'code' => 200 ,
'message' => 'Commercial Proposal deleted'
)
);
}
2017-12-15 16:34:30 +01:00
/**
2020-10-07 15:01:28 +02:00
* Set a proposal to draft
*
* @ param int $id Order ID
*
* @ url POST { id } / settodraft
*
* @ return array
*/
2019-02-27 20:45:07 +01:00
public function settodraft ( $id )
2017-12-15 16:34:30 +01:00
{
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
2017-12-15 16:34:30 +01:00
throw new RestException ( 401 );
}
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2017-12-15 16:34:30 +01:00
throw new RestException ( 404 , 'Proposal not found' );
}
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2017-12-15 16:34:30 +01:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2019-03-15 20:42:49 +01:00
$result = $this -> propal -> setDraft ( DolibarrApiAccess :: $user );
2017-12-15 16:34:30 +01:00
if ( $result == 0 ) {
throw new RestException ( 304 , 'Nothing done. May be object is already draft' );
}
if ( $result < 0 ) {
throw new RestException ( 500 , 'Error : ' . $this -> propal -> error );
}
2018-01-05 02:01:57 +01:00
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2017-12-15 16:34:30 +01:00
throw new RestException ( 404 , 'Proposal not found' );
}
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2017-12-15 16:34:30 +01:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
$this -> propal -> fetchObjectLinked ();
2017-12-28 12:43:26 +01:00
2017-12-15 16:34:30 +01:00
return $this -> _cleanObjectDatas ( $this -> propal );
}
2017-10-07 13:09:31 +02:00
/**
* Validate a commercial proposal
*
2017-12-28 12:43:26 +01:00
* If you get a bad value for param notrigger check that ou provide this in body
* {
* " notrigger " : 0
* }
2018-01-04 21:14:45 +01:00
*
2017-10-07 13:09:31 +02:00
* @ param int $id Commercial proposal ID
2017-12-28 12:43:26 +01:00
* @ param int $notrigger 1 = Does not execute triggers , 0 = execute triggers
2017-10-07 13:09:31 +02:00
*
* @ url POST { id } / validate
*
2020-02-20 13:42:43 +01:00
* @ throws RestException 304
2020-10-07 15:01:28 +02:00
* @ throws RestException 401
* @ throws RestException 404
2022-03-18 16:14:20 +01:00
* @ throws RestException 500 System error
2020-10-07 15:01:28 +02:00
*
* @ return array
*/
public function validate ( $id , $notrigger = 0 )
{
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
2016-09-22 12:53:44 +02:00
throw new RestException ( 401 );
}
2017-10-07 13:09:31 +02:00
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2017-10-07 13:09:31 +02:00
throw new RestException ( 404 , 'Commercial Proposal not found' );
}
2017-07-28 10:16:17 +02:00
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2016-09-22 12:53:44 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2017-07-28 10:16:17 +02:00
2017-10-07 13:09:31 +02:00
$result = $this -> propal -> valid ( DolibarrApiAccess :: $user , $notrigger );
if ( $result == 0 ) {
2017-11-14 01:26:02 +01:00
throw new RestException ( 304 , 'Error nothing done. May be object is already validated' );
2017-10-07 13:09:31 +02:00
}
if ( $result < 0 ) {
throw new RestException ( 500 , 'Error when validating Commercial Proposal: ' . $this -> propal -> error );
}
2020-10-07 15:01:28 +02:00
$result = $this -> propal -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Commercial Proposal not found' );
}
2017-12-28 12:43:26 +01:00
2020-10-07 15:01:28 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2017-12-28 12:43:26 +01:00
2020-10-07 15:01:28 +02:00
$this -> propal -> fetchObjectLinked ();
2018-01-05 02:01:57 +01:00
2020-10-07 15:01:28 +02:00
return $this -> _cleanObjectDatas ( $this -> propal );
}
2017-10-07 13:09:31 +02:00
2017-10-18 11:10:08 +02:00
/**
* Close ( Accept or refuse ) a quote / commercial proposal
*
* @ param int $id Commercial proposal ID
* @ param int $status Must be 2 ( accepted ) or 3 ( refused ) { @ min 2 }{ @ max 3 }
2017-10-18 11:23:16 +02:00
* @ param string $note_private Add this mention at end of private note
2017-10-18 11:10:08 +02:00
* @ param int $notrigger Disabled triggers
*
* @ url POST { id } / close
*
* @ return array
*/
2019-02-27 20:45:07 +01:00
public function close ( $id , $status , $note_private = '' , $notrigger = 0 )
2017-10-18 11:10:08 +02:00
{
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
2017-10-18 11:10:08 +02:00
throw new RestException ( 401 );
}
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2017-10-18 11:10:08 +02:00
throw new RestException ( 404 , 'Commercial Proposal not found' );
}
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2017-10-18 11:10:08 +02:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2021-04-13 19:38:55 +02:00
$result = $this -> propal -> closeProposal ( DolibarrApiAccess :: $user , $status , $note_private , $notrigger );
2017-10-18 11:10:08 +02:00
if ( $result == 0 ) {
2017-11-14 01:26:02 +01:00
throw new RestException ( 304 , 'Error nothing done. May be object is already closed' );
2017-10-18 11:10:08 +02:00
}
if ( $result < 0 ) {
throw new RestException ( 500 , 'Error when closing Commercial Proposal: ' . $this -> propal -> error );
}
2018-01-05 02:01:57 +01:00
$result = $this -> propal -> fetch ( $id );
2020-03-12 12:45:44 +01:00
if ( ! $result ) {
2018-01-05 02:01:57 +01:00
throw new RestException ( 404 , 'Proposal not found' );
}
2020-03-12 12:45:44 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
2018-01-05 02:01:57 +01:00
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
$this -> propal -> fetchObjectLinked ();
return $this -> _cleanObjectDatas ( $this -> propal );
2017-10-18 11:10:08 +02:00
}
2020-10-07 15:01:28 +02:00
/**
* Set a commercial proposal billed . Could be also called setbilled
*
* @ param int $id Commercial proposal ID
*
* @ url POST { id } / setinvoiced
*
* @ return array
*/
public function setinvoiced ( $id )
{
if ( ! DolibarrApiAccess :: $user -> rights -> propal -> creer ) {
throw new RestException ( 401 );
}
$result = $this -> propal -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Commercial Proposal not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
$result = $this -> propal -> classifyBilled ( DolibarrApiAccess :: $user );
if ( $result < 0 ) {
throw new RestException ( 500 , 'Error : ' . $this -> propal -> error );
}
$result = $this -> propal -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Proposal not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'propal' , $this -> propal -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
$this -> propal -> fetchObjectLinked ();
return $this -> _cleanObjectDatas ( $this -> propal );
}
2018-01-04 21:14:45 +01:00
2017-10-07 13:09:31 +02:00
/**
* Validate fields before create or update object
*
* @ param array $data Array with data to verify
* @ return array
* @ throws RestException
*/
2019-02-27 20:45:07 +01:00
private function _validate ( $data )
2017-10-07 13:09:31 +02:00
{
$propal = array ();
foreach ( Proposals :: $FIELDS as $field ) {
2021-02-23 18:59:19 +01:00
if ( ! isset ( $data [ $field ])) {
2017-10-07 13:09:31 +02:00
throw new RestException ( 400 , " $field field missing " );
2021-02-23 18:59:19 +01:00
}
2017-10-07 13:09:31 +02:00
$propal [ $field ] = $data [ $field ];
}
return $propal ;
}
2017-10-18 11:34:49 +02:00
2020-10-07 15:01:28 +02:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.PublicUnderscore
/**
* Clean sensible object datas
*
2020-10-31 18:51:30 +01:00
* @ param Object $object Object to clean
* @ return Object Object with cleaned properties
2020-10-07 15:01:28 +02:00
*/
protected function _cleanObjectDatas ( $object )
{
// phpcs:enable
$object = parent :: _cleanObjectDatas ( $object );
unset ( $object -> note );
unset ( $object -> name );
unset ( $object -> lastname );
unset ( $object -> firstname );
unset ( $object -> civility_id );
unset ( $object -> address );
return $object ;
}
2016-09-22 12:53:44 +02:00
}