2018-01-27 18:59:07 +01:00
< ? php
/* Copyright ( C ) 2015 Jean - François Ferry < jfefe @ aternatik . fr >
* Copyright ( C ) 2016 Laurent Destailleur < eldy @ users . sourceforge . net >
*
* 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 />.
2018-01-27 18:59:07 +01:00
*/
2023-03-12 13:55:33 +01:00
/**
* \file htdocs / fichinter / class / api_interventions . class . php
* \ingroup fichinter
* \brief File of API to manage intervention
*/
use Luracast\Restler\RestException ;
require_once DOL_DOCUMENT_ROOT . '/fichinter/class/fichinter.class.php' ;
2018-01-27 18:59:07 +01:00
/**
2020-04-12 16:36:25 +02:00
* API class for Interventions
2018-01-27 18:59:07 +01:00
*
* @ access protected
* @ class DolibarrApiAccess { @ requires user , external }
*/
2018-02-03 20:58:26 +01:00
class Interventions extends DolibarrApi
2018-01-27 18:59:07 +01:00
{
2020-10-31 14:32:18 +01:00
/**
* @ var array $FIELDS Mandatory fields , checked when create and update object
*/
2021-02-25 23:00:32 +01:00
public static $FIELDS = array (
2020-10-31 14:32:18 +01:00
'socid' ,
'fk_project' ,
'description' ,
);
/**
* @ var array $FIELDS Mandatory fields , checked when create and update object
*/
2021-02-25 23:00:32 +01:00
public static $FIELDSLINE = array (
2020-10-31 14:32:18 +01:00
'description' ,
'date' ,
'duree' ,
);
/**
2023-11-26 15:52:05 +01:00
* @ var Fichinter $fichinter { @ type fichinter }
2020-10-31 14:32:18 +01:00
*/
public $fichinter ;
/**
* Constructor
*/
public function __construct ()
{
global $db , $conf ;
$this -> db = $db ;
$this -> fichinter = new Fichinter ( $this -> db );
}
/**
* Get properties of a Expense Report object
* Return an array with Expense Report information
*
* @ param int $id ID of Expense Report
2023-09-26 18:43:25 +02:00
* @ return Object Object with cleaned properties
2020-10-31 14:32:18 +01:00
*
2023-09-26 18:43:25 +02:00
* @ throws RestException
2020-10-31 14:32:18 +01:00
*/
public function get ( $id )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'ficheinter' , 'lire' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2020-10-31 14:32:18 +01:00
}
$result = $this -> fichinter -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Intervention not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'fichinter' , $this -> fichinter -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
$this -> fichinter -> fetchObjectLinked ();
return $this -> _cleanObjectDatas ( $this -> fichinter );
}
/**
* List of interventions
* Return a list of interventions
*
2024-02-01 19:16:58 +01: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 }
* @ param string $sqlfilters Other criteria to filter answers separated by a comma . Syntax example " (t.ref:like:'SO-%') and (t.date_creation:<:'20160101') "
* @ param string $properties Restrict the data returned to these properties . Ignored if empty . Comma separated list of properties names
* @ return array Array of order objects
2020-10-31 14:32:18 +01:00
*
* @ throws RestException
*/
2023-09-26 18:04:48 +02:00
public function index ( $sortfield = " t.rowid " , $sortorder = 'ASC' , $limit = 100 , $page = 0 , $thirdparty_ids = '' , $sqlfilters = '' , $properties = '' )
2020-10-31 14:32:18 +01:00
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'ficheinter' , 'lire' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2021-04-08 19:05:28 +02:00
}
2020-10-31 14:32:18 +01: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 ;
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'societe' , 'client' , 'voir' ) && ! $socids ) {
2021-02-25 23:00:32 +01:00
$search_sale = DolibarrApiAccess :: $user -> id ;
}
2020-10-31 14:32:18 +01:00
$sql = " SELECT t.rowid " ;
2023-04-28 09:31:33 +02:00
$sql .= " FROM " . MAIN_DB_PREFIX . " fichinter AS t LEFT JOIN " . MAIN_DB_PREFIX . " fichinter_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-10-31 14:32:18 +01:00
$sql .= ' WHERE t.entity IN (' . getEntity ( 'intervention' ) . ')' ;
2021-02-25 23:00:32 +01:00
if ( $socids ) {
2021-03-22 11:30:18 +01:00
$sql .= " AND t.fk_soc IN ( " . $this -> db -> sanitize ( $socids ) . " ) " ;
2021-02-25 23:00:32 +01:00
}
2024-01-09 10:44:50 +01:00
// Search on sale representative
if ( $search_sale && $search_sale != '-1' ) {
if ( $search_sale == - 2 ) {
$sql .= " AND NOT EXISTS (SELECT sc.fk_soc FROM " . MAIN_DB_PREFIX . " societe_commerciaux as sc WHERE sc.fk_soc = t.fk_soc) " ;
} elseif ( $search_sale > 0 ) {
$sql .= " AND EXISTS (SELECT sc.fk_soc FROM " . MAIN_DB_PREFIX . " societe_commerciaux as sc WHERE sc.fk_soc = t.fk_soc AND sc.fk_user = " . (( int ) $search_sale ) . " ) " ;
}
2020-10-31 14:32:18 +01:00
}
// Add sql filters
2021-02-25 23:00:32 +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 ) {
throw new RestException ( 400 , 'Error when validating parameter sqlfilters -> ' . $errormessage );
2020-10-31 14:32:18 +01:00
}
}
$sql .= $this -> db -> order ( $sortfield , $sortorder );
if ( $limit ) {
2021-02-25 23:00:32 +01:00
if ( $page < 0 ) {
2020-10-31 14:32:18 +01:00
$page = 0 ;
}
$offset = $limit * $page ;
$sql .= $this -> db -> plimit ( $limit + 1 , $offset );
}
dol_syslog ( " API Rest request " );
$result = $this -> db -> query ( $sql );
2021-02-25 23:00:32 +01:00
if ( $result ) {
2020-10-31 14:32:18 +01:00
$num = $this -> db -> num_rows ( $result );
$min = min ( $num , ( $limit <= 0 ? $num : $limit ));
$i = 0 ;
2021-02-25 23:00:32 +01:00
while ( $i < $min ) {
2020-10-31 14:32:18 +01:00
$obj = $this -> db -> fetch_object ( $result );
$fichinter_static = new Fichinter ( $this -> db );
if ( $fichinter_static -> fetch ( $obj -> rowid )) {
2023-09-26 18:04:48 +02:00
$obj_ret [] = $this -> _filterObjectProperties ( $this -> _cleanObjectDatas ( $fichinter_static ), $properties );
2020-10-31 14:32:18 +01:00
}
$i ++ ;
}
} else {
throw new RestException ( 503 , 'Error when retrieve intervention list : ' . $this -> db -> lasterror ());
}
2023-12-31 14:11:05 +01:00
2020-10-31 14:32:18 +01:00
return $obj_ret ;
}
/**
* Create intervention object
*
* @ param array $request_data Request data
* @ return int ID of intervention
*/
public function post ( $request_data = null )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'ficheinter' , 'creer' )) {
2020-10-31 14:32:18 +01:00
throw new RestException ( 401 , " Insuffisant rights " );
}
// 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' ) {
2024-01-13 19:48:41 +01:00
// 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 with the caller
2023-12-15 12:15:33 +01:00
$this -> fichinter -> context [ 'caller' ] = $request_data [ 'caller' ];
continue ;
}
2020-10-31 14:32:18 +01:00
$this -> fichinter -> $field = $value ;
}
if ( $this -> fichinter -> create ( DolibarrApiAccess :: $user ) < 0 ) {
throw new RestException ( 500 , " Error creating intervention " , array_merge ( array ( $this -> fichinter -> error ), $this -> fichinter -> errors ));
}
return $this -> fichinter -> id ;
}
/**
* Get lines of an intervention
*
* @ param int $id Id of intervention
*
* @ url GET { id } / lines
*
* @ return int
*/
/* TODO
2021-02-25 23:00:32 +01:00
public function getLines ( $id )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'ficheinter' , 'lire' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2021-02-25 23:00:32 +01:00
}
$result = $this -> fichinter -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Intervention not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'fichinter' , $this -> fichinter -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
$this -> fichinter -> getLinesArray ();
$result = array ();
foreach ( $this -> fichinter -> lines as $line ) {
array_push ( $result , $this -> _cleanObjectDatas ( $line ));
}
return $result ;
}
*/
2018-02-03 20:58:26 +01:00
2020-10-31 18:51:30 +01:00
/**
2023-12-15 12:15:33 +01:00
* Add a line to a given intervention
2020-10-31 18:51:30 +01:00
*
2023-09-26 18:43:25 +02:00
* @ param int $id Id of intervention to update
2020-10-31 18:51:30 +01:00
* @ param array $request_data Request data
*
* @ url POST { id } / lines
*
* @ return int
*/
public function postLine ( $id , $request_data = null )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'ficheinter' , 'creer' )) {
2020-10-31 18:51:30 +01:00
throw new RestException ( 401 , " Insuffisant rights " );
}
// Check mandatory fields
$result = $this -> _validateLine ( $request_data );
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
foreach ( $request_data as $field => $value ) {
2023-12-15 12:15:33 +01:00
if ( $field === 'caller' ) {
2024-01-13 19:48:41 +01:00
// 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 with the caller
2023-12-15 12:15:33 +01:00
$this -> fichinter -> context [ 'caller' ] = $request_data [ 'caller' ];
continue ;
}
2020-10-31 18:51:30 +01:00
$this -> fichinter -> $field = $value ;
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
if ( ! $result ) {
throw new RestException ( 404 , 'Intervention not found' );
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'fichinter' , $this -> fichinter -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
$updateRes = $this -> fichinter -> addLine (
2021-02-25 23:00:32 +01:00
DolibarrApiAccess :: $user ,
$id ,
$this -> fichinter -> description ,
$this -> fichinter -> date ,
$this -> fichinter -> duree
2020-10-31 18:51:30 +01:00
);
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
if ( $updateRes > 0 ) {
return $updateRes ;
} else {
throw new RestException ( 400 , $this -> fichinter -> error );
}
}
2019-02-25 20:35:59 +01:00
2020-10-31 18:51:30 +01:00
/**
* Delete order
*
* @ param int $id Order ID
* @ return array
*/
public function delete ( $id )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'ficheinter' , 'supprimer' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2020-10-31 18:51:30 +01:00
}
$result = $this -> fichinter -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Intervention not found' );
}
2019-02-25 20:35:59 +01:00
2020-10-31 18:51:30 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'fichinter' , $this -> fichinter -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2019-02-25 20:35:59 +01:00
2020-10-31 18:51:30 +01:00
if ( ! $this -> fichinter -> delete ( DolibarrApiAccess :: $user )) {
throw new RestException ( 500 , 'Error when delete intervention : ' . $this -> fichinter -> error );
}
2018-02-05 20:19:00 +01:00
2020-10-31 18:51:30 +01:00
return array (
'success' => array (
'code' => 200 ,
'message' => 'Intervention deleted'
)
);
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
/**
* Validate an intervention
*
* If you get a bad value for param notrigger check , provide this in body
* {
* " notrigger " : 0
* }
*
2023-09-26 18:43:25 +02:00
* @ param int $id Intervention ID
* @ param int $notrigger 1 = Does not execute triggers , 0 = execute triggers
2020-10-31 18:51:30 +01:00
*
* @ url POST { id } / validate
*
2023-01-23 16:31:14 +01:00
* @ return Object
2020-10-31 18:51:30 +01:00
*/
public function validate ( $id , $notrigger = 0 )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'ficheinter' , 'creer' )) {
2020-10-31 18:51:30 +01:00
throw new RestException ( 401 , " Insuffisant rights " );
}
$result = $this -> fichinter -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Intervention not found' );
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'fichinter' , $this -> fichinter -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
$result = $this -> fichinter -> setValid ( DolibarrApiAccess :: $user , $notrigger );
if ( $result == 0 ) {
throw new RestException ( 304 , 'Error nothing done. May be object is already validated' );
}
if ( $result < 0 ) {
2023-11-26 15:52:05 +01:00
throw new RestException ( 500 , 'Error when validating Intervention: ' . $this -> fichinter -> error );
2020-10-31 18:51:30 +01:00
}
2018-02-03 20:58:26 +01:00
2020-10-31 18:51:30 +01:00
$this -> fichinter -> fetchObjectLinked ();
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
return $this -> _cleanObjectDatas ( $this -> fichinter );
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
/**
* Close an intervention
*
2023-09-26 18:43:25 +02:00
* @ param int $id Intervention ID
2020-10-31 18:51:30 +01:00
*
* @ url POST { id } / close
*
2023-01-23 16:31:14 +01:00
* @ return Object
2020-10-31 18:51:30 +01:00
*/
public function closeFichinter ( $id )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'ficheinter' , 'creer' )) {
2020-10-31 18:51:30 +01:00
throw new RestException ( 401 , " Insuffisant rights " );
}
$result = $this -> fichinter -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Intervention not found' );
}
2018-02-03 20:58:26 +01:00
2020-10-31 18:51:30 +01:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'fichinter' , $this -> fichinter -> id )) {
throw new RestException ( 401 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
$result = $this -> fichinter -> setStatut ( 3 );
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
if ( $result == 0 ) {
throw new RestException ( 304 , 'Error nothing done. May be object is already closed' );
}
if ( $result < 0 ) {
throw new RestException ( 500 , 'Error when closing Intervention: ' . $this -> fichinter -> error );
}
2018-02-03 20:58:26 +01:00
2020-10-31 18:51:30 +01:00
$this -> fichinter -> fetchObjectLinked ();
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
return $this -> _cleanObjectDatas ( $this -> fichinter );
}
2018-01-27 18:59:07 +01:00
2020-10-31 18:51:30 +01:00
/**
* Validate fields before create or update object
*
* @ param array $data Data to validate
* @ return array
*
* @ throws RestException
*/
private function _validate ( $data )
{
$fichinter = array ();
foreach ( Interventions :: $FIELDS as $field ) {
2021-02-25 23:00:32 +01:00
if ( ! isset ( $data [ $field ])) {
2020-10-31 18:51:30 +01:00
throw new RestException ( 400 , " $field field missing " );
2021-02-25 23:00:32 +01:00
}
2020-10-31 18:51:30 +01:00
$fichinter [ $field ] = $data [ $field ];
}
return $fichinter ;
}
2018-02-03 20:58:26 +01:00
2020-10-31 18:51:30 +01:00
// phpcs:disable PEAR.NamingConventions.ValidFunctionName.PublicUnderscore
/**
* Clean sensible object datas
*
* @ param Object $object Object to clean
* @ return Object Object with cleaned properties
*/
protected function _cleanObjectDatas ( $object )
{
// phpcs:enable
$object = parent :: _cleanObjectDatas ( $object );
2018-02-03 20:58:26 +01:00
2023-11-24 10:10:24 +01:00
unset ( $object -> labelStatus );
unset ( $object -> labelStatusShort );
2018-02-03 20:58:26 +01:00
2020-10-31 18:51:30 +01:00
return $object ;
}
/**
* Validate fields before create or update object
*
* @ param array $data Data to validate
* @ return array
*
* @ throws RestException
*/
private function _validateLine ( $data )
{
$fichinter = array ();
foreach ( Interventions :: $FIELDSLINE as $field ) {
2021-02-25 23:00:32 +01:00
if ( ! isset ( $data [ $field ])) {
2020-10-31 18:51:30 +01:00
throw new RestException ( 400 , " $field field missing " );
2021-02-25 23:00:32 +01:00
}
2020-10-31 18:51:30 +01:00
$fichinter [ $field ] = $data [ $field ];
}
return $fichinter ;
}
2018-01-27 18:59:07 +01:00
}