2016-11-19 16:08:27 +01:00
< ? php
/* Copyright ( C ) 2015 Jean - François Ferry < jfefe @ aternatik . fr >
* Copyright ( C ) 2016 Laurent Destailleur < eldy @ users . sourceforge . net >
2024-12-31 16:25:57 +01:00
* Copyright ( C ) 2024 Frédéric France < frederic . france @ free . fr >
2016-11-19 16:08:27 +01: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-11-19 16:08:27 +01:00
*/
2023-05-16 22:14:06 +02:00
use Luracast\Restler\RestException ;
require_once DOL_DOCUMENT_ROOT . '/projet/class/task.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/lib/date.lib.php' ;
2016-11-19 16:08:27 +01:00
2017-10-16 17:56:59 +02:00
2016-11-19 16:08:27 +01:00
/**
* API class for projects
*
* @ access protected
* @ class DolibarrApiAccess { @ requires user , external }
*/
class Tasks extends DolibarrApi
{
2020-09-07 10:18:17 +02:00
/**
* @ var array $FIELDS Mandatory fields , checked when create and update object
*/
2021-02-26 18:49:22 +01:00
public static $FIELDS = array (
2020-09-07 10:18:17 +02:00
'ref' ,
'label' ,
2020-08-19 11:24:32 +02:00
'fk_project'
2020-09-07 10:18:17 +02:00
);
/**
* @ var Task $task { @ type Task }
*/
public $task ;
/**
* Constructor
*/
public function __construct ()
{
global $db , $conf ;
$this -> db = $db ;
$this -> task = new Task ( $this -> db );
}
/**
* Get properties of a task object
2016-11-19 16:08:27 +01:00
*
2024-01-12 17:55:52 +01:00
* Return an array with task information
2020-09-07 10:18:17 +02:00
*
* @ param int $id ID of task
2022-01-28 22:59:32 +01:00
* @ param int $includetimespent 0 = Return only task . 1 = Include a summary of time spent , 2 = Include details of time spent lines
2023-09-26 18:43:25 +02:00
* @ return array | mixed data without useless information
2020-09-07 10:18:17 +02:00
*
2023-09-26 18:43:25 +02:00
* @ throws RestException
2020-09-07 10:18:17 +02:00
*/
public function get ( $id , $includetimespent = 0 )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'lire' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2016-11-19 16:08:27 +01:00
}
2020-09-07 10:18:17 +02:00
$result = $this -> task -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Task not found' );
}
2016-11-19 16:08:27 +01:00
2020-04-10 10:59:32 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'task' , $this -> task -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2016-11-19 16:08:27 +01:00
}
2021-02-26 18:49:22 +01:00
if ( $includetimespent == 1 ) {
2020-09-07 10:18:17 +02:00
$timespent = $this -> task -> getSummaryOfTimeSpent ( 0 );
2016-11-19 16:08:27 +01:00
}
2022-01-28 22:59:32 +01:00
if ( $includetimespent == 2 ) {
2022-01-28 23:03:08 +01:00
$timespent = $this -> task -> fetchTimeSpentOnTask ();
2016-11-19 16:08:27 +01:00
}
2017-10-16 17:56:59 +02:00
2016-11-19 16:08:27 +01:00
return $this -> _cleanObjectDatas ( $this -> task );
2020-09-07 10:18:17 +02:00
}
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
/**
* List tasks
*
* Get a list of tasks
*
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
2020-09-07 10:18:17 +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') "
2024-01-12 17:55:52 +01:00
* @ param string $properties Restrict the data returned to these properties . Ignored if empty . Comma separated list of properties names
2020-09-07 10:18:17 +02:00
* @ return array Array of project objects
*/
2023-09-26 18:04:48 +02:00
public function index ( $sortfield = " t.rowid " , $sortorder = 'ASC' , $limit = 100 , $page = 0 , $sqlfilters = '' , $properties = '' )
2020-09-07 10:18:17 +02:00
{
global $db , $conf ;
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'lire' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2021-04-08 19:05:28 +02:00
}
2020-09-07 10:18:17 +02:00
$obj_ret = array ();
// case of external user, $thirdparty_ids param is ignored and replaced by user's socid
2024-01-09 10:44:50 +01:00
$socids = DolibarrApiAccess :: $user -> socid ? DolibarrApiAccess :: $user -> socid : 0 ;
2020-09-07 10:18:17 +02:00
// 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-26 18:49:22 +01:00
$search_sale = DolibarrApiAccess :: $user -> id ;
}
2020-09-07 10:18:17 +02:00
$sql = " SELECT t.rowid " ;
2024-01-09 10:44:50 +01:00
$sql .= " FROM " . MAIN_DB_PREFIX . " projet_task AS t " ;
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " projet_task_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
$sql .= " INNER JOIN " . MAIN_DB_PREFIX . " projet AS p ON p.rowid = t.fk_projet " ;
2020-09-07 10:18:17 +02:00
$sql .= ' WHERE t.entity IN (' . getEntity ( 'project' ) . ')' ;
2021-02-26 18:49:22 +01:00
if ( $socids ) {
2021-03-22 11:30:18 +01:00
$sql .= " AND t.fk_soc IN ( " . $this -> db -> sanitize ( $socids ) . " ) " ;
2021-02-26 18:49:22 +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 = p.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 = p.fk_soc AND sc.fk_user = " . (( int ) $search_sale ) . " ) " ;
}
2020-09-07 10:18:17 +02:00
}
// Add sql filters
2021-02-26 18:49:22 +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-09-07 10:18:17 +02:00
}
}
2017-10-16 17:56:59 +02:00
2020-09-19 23:30:29 +02:00
$sql .= $this -> db -> order ( $sortfield , $sortorder );
2020-09-07 10:18:17 +02:00
if ( $limit ) {
2021-02-26 18:49:22 +01:00
if ( $page < 0 ) {
2020-09-07 10:18:17 +02:00
$page = 0 ;
}
$offset = $limit * $page ;
2016-11-19 16:08:27 +01:00
2020-09-19 23:30:29 +02:00
$sql .= $this -> db -> plimit ( $limit + 1 , $offset );
2020-09-07 10:18:17 +02:00
}
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
dol_syslog ( " API Rest request " );
2020-09-19 23:30:29 +02:00
$result = $this -> db -> query ( $sql );
2016-11-19 16:08:27 +01:00
2021-02-26 18:49:22 +01:00
if ( $result ) {
2020-09-19 23:30:29 +02:00
$num = $this -> db -> num_rows ( $result );
2020-09-07 10:18:17 +02:00
$min = min ( $num , ( $limit <= 0 ? $num : $limit ));
$i = 0 ;
2021-02-26 18:49:22 +01:00
while ( $i < $min ) {
2020-09-19 23:30:29 +02:00
$obj = $this -> db -> fetch_object ( $result );
$task_static = new Task ( $this -> db );
2020-09-07 10:18:17 +02:00
if ( $task_static -> fetch ( $obj -> rowid )) {
2023-09-26 18:04:48 +02:00
$obj_ret [] = $this -> _filterObjectProperties ( $this -> _cleanObjectDatas ( $task_static ), $properties );
2020-09-07 10:18:17 +02:00
}
$i ++ ;
}
} else {
2020-09-19 23:30:29 +02:00
throw new RestException ( 503 , 'Error when retrieve task list : ' . $this -> db -> lasterror ());
2020-09-07 10:18:17 +02:00
}
2023-12-31 14:05:21 +01:00
2016-11-19 16:08:27 +01:00
return $obj_ret ;
2020-09-07 10:18:17 +02:00
}
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
/**
* Create task object
*
* @ param array $request_data Request data
* @ return int ID of project
*/
public function post ( $request_data = null )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'creer' )) {
2024-04-07 14:59:25 +02:00
throw new RestException ( 403 , " Insuffisant rights " );
2020-09-07 10:18:17 +02:00
}
// Check mandatory fields
$result = $this -> _validate ( $request_data );
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
foreach ( $request_data as $field => $value ) {
2023-12-15 12:15:33 +01:00
if ( $field === 'caller' ) {
2024-01-12 17:55:52 +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
2024-04-02 12:28:55 +02:00
$this -> task -> context [ 'caller' ] = sanitizeVal ( $request_data [ 'caller' ], 'aZ09' );
2023-12-15 12:15:33 +01:00
continue ;
}
2024-04-02 12:28:55 +02:00
$this -> task -> $field = $this -> _checkValForAPI ( $field , $value , $this -> task );
2020-09-07 10:18:17 +02:00
}
/* if ( isset ( $request_data [ " lines " ])) {
2021-02-26 18:49:22 +01:00
$lines = array ();
foreach ( $request_data [ " lines " ] as $line ) {
array_push ( $lines , ( object ) $line );
}
$this -> project -> lines = $lines ;
} */
2020-09-07 10:18:17 +02:00
if ( $this -> task -> create ( DolibarrApiAccess :: $user ) < 0 ) {
throw new RestException ( 500 , " Error creating task " , array_merge ( array ( $this -> task -> error ), $this -> task -> errors ));
}
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
return $this -> task -> id ;
}
// /**
// * Get time spent of a task
// *
// * @param int $id Id of task
// * @return int
// *
// * @url GET {id}/tasks
// */
/*
2021-02-26 18:49:22 +01:00
public function getLines ( $id , $includetimespent = 0 )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'lire' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2021-02-26 18:49:22 +01:00
}
$result = $this -> project -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Project not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'project' , $this -> project -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2021-02-26 18:49:22 +01:00
}
$this -> project -> getLinesArray ( DolibarrApiAccess :: $user );
$result = array ();
foreach ( $this -> project -> lines as $line ) // $line is a task
{
if ( $includetimespent == 1 )
{
$timespent = $line -> getSummaryOfTimeSpent ( 0 );
}
if ( $includetimespent == 1 )
{
// TODO
// Add class for timespent records and loop and fill $line->lines with records of timespent
}
array_push ( $result , $this -> _cleanObjectDatas ( $line ));
}
return $result ;
}
*/
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
/**
* Get roles a user is assigned to a task with
*
2023-02-20 02:33:44 +01:00
* @ param int $id Id of task
* @ param int $userid Id of user ( 0 = connected user )
2023-09-26 18:43:25 +02:00
* @ return array Array of roles
2020-09-07 10:18:17 +02:00
*
* @ url GET { id } / roles
*
*/
public function getRoles ( $id , $userid = 0 )
{
global $db ;
2017-10-16 17:56:59 +02:00
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'lire' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2020-09-07 10:18:17 +02:00
}
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
$result = $this -> task -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Task not found' );
}
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'tasks' , $this -> task -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-07 10:18:17 +02:00
}
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
$usert = DolibarrApiAccess :: $user ;
2021-02-26 18:49:22 +01:00
if ( $userid > 0 ) {
2020-09-07 10:18:17 +02:00
$usert = new User ( $this -> db );
$usert -> fetch ( $userid );
}
2022-12-28 11:41:59 +01:00
$this -> task -> roles = $this -> task -> getUserRolesForProjectsOrTasks ( null , $usert , 0 , $id );
2020-09-07 10:18:17 +02:00
$result = array ();
foreach ( $this -> task -> roles as $line ) {
array_push ( $result , $this -> _cleanObjectDatas ( $line ));
}
2023-02-20 02:33:44 +01:00
2020-09-07 10:18:17 +02:00
return $result ;
}
// /**
// * Add a task to given project
// *
// * @param int $id Id of project to update
// * @param array $request_data Projectline data
// *
// * @url POST {id}/tasks
// *
// * @return int
// */
/*
2021-02-26 18:49:22 +01:00
public function postLine ( $id , $request_data = null )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'creer' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2021-02-26 18:49:22 +01:00
}
$result = $this -> project -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Project not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'project' , $this -> project -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2021-02-26 18:49:22 +01:00
}
2021-04-25 19:21:48 +02:00
2021-02-26 18:49:22 +01: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' );
2021-04-25 19:21:48 +02:00
2021-02-26 18:49:22 +01:00
$updateRes = $this -> project -> addline (
$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 ,
'HT' ,
0 ,
$request_data -> date_start ,
$request_data -> date_end ,
$request_data -> product_type ,
$request_data -> rang ,
$request_data -> special_code ,
$fk_parent_line ,
$request_data -> fk_fournprice ,
$request_data -> pa_ht ,
$request_data -> label ,
$request_data -> array_options ,
$request_data -> fk_unit ,
$this -> element ,
$request_data -> id
);
if ( $updateRes > 0 ) {
return $updateRes ;
}
return false ;
}
*/
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
// /**
2023-06-29 15:54:09 +02:00
// * Update a task of a given project
2020-09-07 10:18:17 +02:00
// *
// * @param int $id Id of project to update
// * @param int $taskid Id of task to update
// * @param array $request_data Projectline data
// *
// * @url PUT {id}/tasks/{taskid}
// *
// * @return object
// */
/*
2021-02-26 18:49:22 +01:00
public function putLine ( $id , $lineid , $request_data = null )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'creer' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2021-02-26 18:49:22 +01:00
}
$result = $this -> project -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Project not found' );
}
if ( ! DolibarrApi :: _checkAccessToResource ( 'project' , $this -> project -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2021-02-26 18:49:22 +01:00
}
2021-04-25 19:21:48 +02:00
2021-02-26 18:49:22 +01: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' );
2021-04-25 19:21:48 +02:00
2021-02-26 18:49:22 +01:00
$updateRes = $this -> project -> 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 ,
'HT' ,
$request_data -> info_bits ,
$request_data -> date_start ,
$request_data -> date_end ,
$request_data -> product_type ,
$request_data -> fk_parent_line ,
0 ,
$request_data -> fk_fournprice ,
$request_data -> pa_ht ,
$request_data -> label ,
$request_data -> special_code ,
$request_data -> array_options ,
$request_data -> fk_unit
);
if ( $updateRes > 0 ) {
$result = $this -> get ( $id );
unset ( $result -> line );
return $this -> _cleanObjectDatas ( $result );
}
return false ;
} */
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
/**
* Update task general fields ( won ' t touch time spent of task )
*
2024-02-22 01:32:55 +01:00
* @ param int $id Id of task to update
* @ param array $request_data Datas
* @ return Object Updated object
2020-09-07 10:18:17 +02:00
*/
public function put ( $id , $request_data = null )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'creer' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2020-09-07 10:18:17 +02:00
}
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
$result = $this -> task -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Task not found' );
}
2016-11-19 16:08:27 +01:00
2021-09-28 13:46:03 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'task' , $this -> task -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2016-11-19 16:08:27 +01:00
}
2020-09-07 10:18:17 +02:00
foreach ( $request_data as $field => $value ) {
2021-02-26 18:49:22 +01:00
if ( $field == 'id' ) {
continue ;
}
2023-12-15 12:15:33 +01:00
if ( $field === 'caller' ) {
2024-01-12 17:55:52 +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
2024-04-02 12:28:55 +02:00
$this -> task -> context [ 'caller' ] = sanitizeVal ( $request_data [ 'caller' ], 'aZ09' );
2023-12-15 12:15:33 +01:00
continue ;
}
2024-04-01 11:35:57 +02:00
if ( $field == 'array_options' && is_array ( $value )) {
foreach ( $value as $index => $val ) {
2024-12-31 16:25:57 +01:00
$this -> task -> array_options [ $index ] = $this -> _checkValForAPI ( $field , $val , $this -> task );
2024-04-01 11:35:57 +02:00
}
continue ;
}
2023-12-15 12:15:33 +01:00
2024-04-02 12:28:55 +02:00
$this -> task -> $field = $this -> _checkValForAPI ( $field , $value , $this -> task );
2020-09-07 10:18:17 +02:00
}
2016-11-19 16:08:27 +01:00
2021-02-26 18:49:22 +01:00
if ( $this -> task -> update ( DolibarrApiAccess :: $user ) > 0 ) {
2020-09-07 10:18:17 +02:00
return $this -> get ( $id );
} else {
throw new RestException ( 500 , $this -> task -> error );
}
}
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
/**
* Delete task
*
* @ param int $id Task ID
*
* @ return array
*/
public function delete ( $id )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'supprimer' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2020-09-07 10:18:17 +02:00
}
$result = $this -> task -> fetch ( $id );
if ( ! $result ) {
throw new RestException ( 404 , 'Task not found' );
}
2016-11-19 16:08:27 +01:00
2021-09-28 13:46:03 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'task' , $this -> task -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2016-11-19 16:08:27 +01:00
}
2020-09-07 10:18:17 +02:00
if ( ! $this -> task -> delete ( DolibarrApiAccess :: $user )) {
throw new RestException ( 500 , 'Error when delete task : ' . $this -> task -> error );
}
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
return array (
'success' => array (
'code' => 200 ,
'message' => 'Task deleted'
)
);
}
2016-11-19 16:08:27 +01:00
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
/**
* Add time spent to a task of a project .
* You can test this API with the following input message
* { " date " : " 2016-12-31 23:15:00 " , " duration " : 1800 , " user_id " : 1 , " note " : " My time test " }
*
* @ param int $id Task ID
* @ param datetime $date Date ( YYYY - MM - DD HH : MI : SS in GMT )
* @ param int $duration Duration in seconds ( 3600 = 1 h )
* @ param int $user_id User ( Use 0 for connected user )
* @ param string $note Note
*
* @ url POST { id } / addtimespent
2023-04-27 19:46:39 +02:00
* NOTE : Should be " POST { id}/timespent " , since POST already implies " add "
2020-09-07 10:18:17 +02:00
*
* @ return array
*/
public function addTimeSpent ( $id , $date , $duration , $user_id = 0 , $note = '' )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'creer' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2020-09-07 10:18:17 +02:00
}
$result = $this -> task -> fetch ( $id );
if ( $result <= 0 ) {
throw new RestException ( 404 , 'Task not found' );
}
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'project' , $this -> task -> fk_project )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2020-09-07 10:18:17 +02:00
}
2016-11-19 16:08:27 +01:00
2020-09-07 10:18:17 +02:00
$uid = $user_id ;
2021-02-26 18:49:22 +01:00
if ( empty ( $uid )) {
$uid = DolibarrApiAccess :: $user -> id ;
}
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
$newdate = dol_stringtotime ( $date , 1 );
$this -> task -> timespent_date = $newdate ;
$this -> task -> timespent_datehour = $newdate ;
$this -> task -> timespent_withhour = 1 ;
$this -> task -> timespent_duration = $duration ;
2022-11-25 23:44:32 +01:00
$this -> task -> timespent_fk_user = $uid ;
2020-09-07 10:18:17 +02:00
$this -> task -> timespent_note = $note ;
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
$result = $this -> task -> addTimeSpent ( DolibarrApiAccess :: $user , 0 );
if ( $result == 0 ) {
throw new RestException ( 304 , 'Error nothing done. May be object is already validated' );
}
if ( $result < 0 ) {
throw new RestException ( 500 , 'Error when adding time: ' . $this -> task -> error );
}
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
return array (
'success' => array (
'code' => 200 ,
'message' => 'Time spent added'
)
);
}
2017-10-16 17:56:59 +02:00
2023-04-27 19:46:39 +02:00
/**
* Update time spent for a task of a project .
* You can test this API with the following input message
* { " date " : " 2016-12-31 23:15:00 " , " duration " : 1800 , " user_id " : 1 , " note " : " My time test " }
*
* @ param int $id Task ID
2023-08-15 13:51:17 +02:00
* @ param int $timespent_id Time spent ID ( llx_element_time . rowid )
2023-04-27 19:46:39 +02:00
* @ param datetime $date Date ( YYYY - MM - DD HH : MI : SS in GMT )
* @ param int $duration Duration in seconds ( 3600 = 1 h )
* @ param int $user_id User ( Use 0 for connected user )
* @ param string $note Note
*
* @ url PUT { id } / timespent / { timespent_id }
*
* @ return array
*/
public function putTimeSpent ( $id , $timespent_id , $date , $duration , $user_id = 0 , $note = '' )
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'creer' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2023-04-27 19:46:39 +02:00
}
2023-04-28 18:07:46 +02:00
$this -> timespentRecordChecks ( $id , $timespent_id );
2023-04-27 19:46:39 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'task' , $this -> task -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2023-04-27 19:46:39 +02:00
}
$newdate = dol_stringtotime ( $date , 1 );
$this -> task -> timespent_date = $newdate ;
$this -> task -> timespent_datehour = $newdate ;
$this -> task -> timespent_withhour = 1 ;
$this -> task -> timespent_duration = $duration ;
$this -> task -> timespent_fk_user = $user_id ? ? DolibarrApiAccess :: $user -> id ;
$this -> task -> timespent_note = $note ;
$result = $this -> task -> updateTimeSpent ( DolibarrApiAccess :: $user , 0 );
if ( $result == 0 ) {
throw new RestException ( 304 , 'Error nothing done.' );
}
if ( $result < 0 ) {
throw new RestException ( 500 , 'Error when updating time spent: ' . $this -> task -> error );
}
return array (
'success' => array (
'code' => 200 ,
'message' => 'Time spent updated'
)
);
}
2017-10-16 17:56:59 +02:00
2023-04-27 19:49:18 +02:00
/**
* Delete time spent for a task of a project .
*
* @ param int $id Task ID
2023-08-15 13:51:17 +02:00
* @ param int $timespent_id Time spent ID ( llx_element_time . rowid )
2023-04-27 19:49:18 +02:00
*
* @ url DELETE { id } / timespent / { timespent_id }
*
* @ return array
*/
2023-04-28 18:07:46 +02:00
public function deleteTimeSpent ( $id , $timespent_id )
2023-04-27 19:49:18 +02:00
{
2024-02-09 15:58:49 +01:00
if ( ! DolibarrApiAccess :: $user -> hasRight ( 'projet' , 'supprimer' )) {
2024-02-01 19:16:58 +01:00
throw new RestException ( 403 );
2023-04-27 19:49:18 +02:00
}
2023-04-28 18:07:46 +02:00
$this -> timespentRecordChecks ( $id , $timespent_id );
2023-04-27 19:49:18 +02:00
if ( ! DolibarrApi :: _checkAccessToResource ( 'task' , $this -> task -> id )) {
2024-04-02 14:47:49 +02:00
throw new RestException ( 403 , 'Access not allowed for login ' . DolibarrApiAccess :: $user -> login );
2023-04-27 19:49:18 +02:00
}
if ( $this -> task -> delTimeSpent ( DolibarrApiAccess :: $user , 0 ) < 0 ) {
throw new RestException ( 500 , 'Error when deleting time spent: ' . $this -> task -> error );
}
return array (
'success' => array (
'code' => 200 ,
'message' => 'Time spent deleted'
)
);
}
2023-04-28 18:07:46 +02:00
/**
* Validate task & timespent IDs for timespent API methods .
* Loads the selected task & timespent records .
*
* @ param int $id Task ID
2023-08-15 13:51:17 +02:00
* @ param int $timespent_id Time spent ID ( llx_element_time . rowid )
2023-04-28 18:20:48 +02:00
*
* @ return void
2023-04-28 18:07:46 +02:00
*/
protected function timespentRecordChecks ( $id , $timespent_id )
2023-04-27 20:51:33 +02:00
{
2023-04-27 19:49:18 +02:00
if ( $this -> task -> fetch ( $id ) <= 0 ) {
throw new RestException ( 404 , 'Task not found' );
}
if ( $this -> task -> fetchTimeSpent ( $timespent_id ) <= 0 ) {
throw new RestException ( 404 , 'Timespent not found' );
2023-04-27 20:51:33 +02:00
} elseif ( $this -> task -> id != $id ) {
2023-04-27 19:49:18 +02:00
throw new RestException ( 404 , 'Timespent not found in selected task' );
}
}
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +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-09-07 10:18:17 +02:00
*/
protected function _cleanObjectDatas ( $object )
{
// phpcs:enable
$object = parent :: _cleanObjectDatas ( $object );
unset ( $object -> barcode_type );
unset ( $object -> barcode_type_code );
unset ( $object -> barcode_type_label );
unset ( $object -> barcode_type_coder );
unset ( $object -> cond_reglement_id );
unset ( $object -> cond_reglement );
unset ( $object -> fk_delivery_address );
unset ( $object -> shipping_method_id );
unset ( $object -> fk_account );
unset ( $object -> note );
unset ( $object -> fk_incoterms );
unset ( $object -> label_incoterms );
unset ( $object -> location_incoterms );
unset ( $object -> name );
unset ( $object -> lastname );
unset ( $object -> firstname );
unset ( $object -> civility_id );
unset ( $object -> mode_reglement_id );
unset ( $object -> country );
unset ( $object -> country_id );
unset ( $object -> country_code );
unset ( $object -> weekWorkLoad );
unset ( $object -> weekWorkLoad );
//unset($object->lines); // for task we use timespent_lines, but for project we use lines
unset ( $object -> total_ht );
unset ( $object -> total_tva );
unset ( $object -> total_localtax1 );
unset ( $object -> total_localtax2 );
unset ( $object -> total_ttc );
unset ( $object -> comments );
return $object ;
}
/**
* Validate fields before create or update object
*
* @ param array $data Array with data to verify
* @ return array
* @ throws RestException
*/
private function _validate ( $data )
{
$object = array ();
foreach ( self :: $FIELDS as $field ) {
2021-02-26 18:49:22 +01:00
if ( ! isset ( $data [ $field ])) {
2020-09-07 10:18:17 +02:00
throw new RestException ( 400 , " $field field missing " );
2021-02-26 18:49:22 +01:00
}
2020-09-07 10:18:17 +02:00
$object [ $field ] = $data [ $field ];
}
return $object ;
}
2017-10-16 17:56:59 +02:00
2020-09-07 10:18:17 +02:00
// \todo
// getSummaryOfTimeSpent
2016-11-19 16:08:27 +01:00
}