20use Luracast\Restler\RestException;
22require_once DOL_DOCUMENT_ROOT.
'/salaries/class/salary.class.php';
23require_once DOL_DOCUMENT_ROOT.
'/salaries/class/paymentsalary.class.php';
37 public static $FIELDS = array(
46 public static $FIELDSPAYMENT = array(
76 public function index($sortfield =
"t.rowid", $sortorder =
'ASC', $limit = 100, $page = 0)
80 if (!DolibarrApiAccess::$user->hasRight(
'salaries',
'read')) {
81 throw new RestException(403);
84 $sql =
"SELECT rowid FROM " . MAIN_DB_PREFIX .
"salary as t";
87 $sql .= $this->db->order($sortfield, $sortorder);
92 $offset = $limit * $page;
94 $sql .= $this->db->plimit($limit + 1, $offset);
98 $result = $this->db->query($sql);
101 $num = $this->db->num_rows($result);
102 $min = min($num, ($limit <= 0 ? $num : $limit));
103 for ($i = 0; $i < $min; $i++) {
104 $obj = $this->db->fetch_object($result);
105 $salary =
new Salary($this->db);
106 if ($salary->fetch($obj->rowid) > 0) {
111 throw new RestException(503,
'Error when retrieving list of salaries: ' . $this->db->lasterror());
127 if (!DolibarrApiAccess::$user->hasRight(
'salaries',
'read')) {
128 throw new RestException(403);
131 $salary =
new Salary($this->db);
132 $result = $salary->fetch(
$id);
134 throw new RestException(404,
'salary not found');
148 public function post($request_data =
null)
150 if (!DolibarrApiAccess::$user->hasRight(
'salaries',
'write')) {
151 throw new RestException(403);
154 $result = $this->
_validate($request_data);
156 $salary =
new Salary($this->db);
157 foreach ($request_data as $field => $value) {
161 if ($salary->create(DolibarrApiAccess::$user) < 0) {
162 throw new RestException(500,
'Error creating salary', array_merge(array($salary->error), $salary->errors));
176 public function put(
$id, $request_data =
null)
178 if (!DolibarrApiAccess::$user->hasRight(
'salaries',
'write')) {
179 throw new RestException(403);
182 $salary =
new Salary($this->db);
183 $result = $salary->fetch(
$id);
185 throw new RestException(404,
'salary not found');
188 foreach ($request_data as $field => $value) {
189 if ($field ==
'id') {
195 if ($salary->update(DolibarrApiAccess::$user) > 0) {
196 return $this->
get(
$id);
198 throw new RestException(500, $salary->error);
247 public function getAllPayments($sortfield =
"t.rowid", $sortorder =
'ASC', $limit = 100, $page = 0)
251 if (!DolibarrApiAccess::$user->hasRight(
'salaries',
'read')) {
252 throw new RestException(403);
255 $sql =
"SELECT t.rowid FROM " . MAIN_DB_PREFIX .
"payment_salary as t, ".MAIN_DB_PREFIX.
"salary as s";
256 $sql .=
' WHERE s.rowid = t.fk_salary AND t.entity IN ('.getEntity(
'salary').
')';
258 $sql .= $this->db->order($sortfield, $sortorder);
263 $offset = $limit * $page;
265 $sql .= $this->db->plimit($limit + 1, $offset);
270 $result = $this->db->query($sql);
273 $num = $this->db->num_rows($result);
274 $min = min($num, ($limit <= 0 ? $num : $limit));
275 for ($i = 0; $i < $min; $i++) {
276 $obj = $this->db->fetch_object($result);
278 if ($paymentsalary->fetch($obj->rowid) > 0) {
283 throw new RestException(503,
'Error when retrieving list of paymentsalaries: ' . $this->db->lasterror());
301 if (!DolibarrApiAccess::$user->hasRight(
'salaries',
'read')) {
302 throw new RestException(403);
306 $result = $paymentsalary->fetch($pid);
308 throw new RestException(404,
'paymentsalary not found');
329 if (!DolibarrApiAccess::$user->hasRight(
'salaries',
'write')) {
330 throw new RestException(403);
336 $paymentsalary->fk_salary =
$id;
337 foreach ($request_data as $field => $value) {
338 $paymentsalary->$field = $this->
_checkValForAPI($field, $value, $paymentsalary);
341 if ($paymentsalary->create(DolibarrApiAccess::$user, 1) < 0) {
342 throw new RestException(500,
'Error creating paymentsalary', array_merge(array($paymentsalary->error), $paymentsalary->errors));
344 if (isModEnabled(
"bank")) {
345 $paymentsalary->addPaymentToBank(
346 DolibarrApiAccess::$user,
349 (
int) $request_data[
'accountid'],
354 return $paymentsalary->id;
372 if (!DolibarrApiAccess::$user->hasRight(
'salaries',
'write')) {
373 throw new RestException(403);
377 $result = $paymentsalary->fetch(
$id);
379 throw new RestException(404,
'Payment salary not found');
382 foreach ($request_data as $field => $value) {
383 if ($field ==
'id') {
386 $paymentsalary->$field = $this->
_checkValForAPI($field, $value, $paymentsalary);
389 if ($paymentsalary->update(DolibarrApiAccess::$user) > 0) {
390 return $this->
get(
$id);
392 throw new RestException(500, $paymentsalary->error);
438 if ($data ===
null) {
442 foreach (Salaries::$FIELDS as $field) {
443 if (!isset($data[$field])) {
444 throw new RestException(400,
"$field field missing");
446 $salary[$field] = $data[$field];
461 if ($data ===
null) {
464 $paymentsalary = array();
465 $fields = Salaries::$FIELDSPAYMENT;
466 if (isModEnabled(
"bank")) {
467 array_push($fields,
"accountid");
469 foreach ($fields as $field) {
470 if (!isset($data[$field])) {
471 throw new RestException(400,
"$field field missing");
473 $paymentsalary[$field] = $data[$field];
475 return $paymentsalary;
$id
Support class for third parties, contacts, members, users or resources.
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
_checkValForAPI($field, $value, $object)
Check and convert a string depending on its type/name.
Class to manage payments of salaries.
put($id, $request_data=null)
Update salary.
__construct()
Constructor.
index($sortfield="t.rowid", $sortorder='ASC', $limit=100, $page=0)
Get the list of salaries.
updatePayment($id, $request_data=null)
Update paymentsalary.
_cleanObjectDatas($object)
Clean sensible object datas.
_validate($data)
Delete a payment salary.
getPayments($pid)
Get a given payment.
getAllPayments($sortfield="t.rowid", $sortorder='ASC', $limit=100, $page=0)
Delete salary.
post($request_data=null)
Create salary object.
_validatepayments($data)
Validate fields before creating an object.
addPayment($id, $request_data=null)
Create payment salary on a salary.
Class to manage salary payments.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.