dolibarr 23.0.3
index.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2004 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3 * Copyright (C) 2005-2016 Laurent Destailleur <eldy@users.sourceforge.org>
4 * Copyright (C) 2011 Juanjo Menent <jmenent@2byte.es>
5 * Copyright (C) 2012-2018 Regis Houssin <regis.houssin@inodbox.com>
6 * Copyright (C) 2015 Jean-François Ferry <jfefe@aternatik.fr>
7 * Copyright (C) 2024 MDW <mdeweerd@users.noreply.github.com>
8 * Copyright (C) 2024-2025 Frédéric France <frederic.france@free.fr>
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 3 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 */
23
30// Load Dolibarr environment
31require '../../main.inc.php';
32require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php';
33require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
34require_once DOL_DOCUMENT_ROOT.'/core/lib/api.lib.php';
35
47require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php';
48require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
49
50// Load translation files required by the page
51$langs->load("admin");
52
53if (!$user->admin) {
55}
56
57$action = GETPOST('action', 'aZ09');
58
59// Activate Production mode
60if ($action == 'setproductionmode') {
61 $status = GETPOST('status', 'alpha');
62
63 if (dolibarr_set_const($db, 'API_PRODUCTION_MODE', $status, 'chaine', 0, '', 0) > 0) {
64 $error = 0;
65
66 if ($status == 1) {
67 $result = dol_mkdir($conf->api->dir_temp);
68 if ($result < 0) {
69 setEventMessages($langs->trans("ErrorFailedToCreateDir", $conf->api->dir_temp), null, 'errors');
70 $error++;
71 }
72 } else {
73 // Delete the cache file otherwise it does not update
74 $result = dol_delete_file($conf->api->dir_temp.'/routes.php');
75 if ($result < 0) {
76 setEventMessages($langs->trans("ErrorFailedToDeleteFile", $conf->api->dir_temp.'/routes.php'), null, 'errors');
77 $error++;
78 }
79 }
80
81 if (!$error) {
82 header("Location: ".$_SERVER["PHP_SELF"]);
83 exit;
84 }
85 } else {
86 dol_print_error($db);
87 }
88}
89
90// Disable compression mode
91if ($action == 'setdisablecompression') {
92 if (dolibarr_set_const($db, 'API_DISABLE_COMPRESSION', GETPOSTINT('status'), 'chaine', 0, '', 0) <= 0) {
93 dol_print_error($db);
94 }
95}
96
97// Disable compression mode
98if ($action == 'setenablecount' && !empty($dolibarr_api_count_always_enabled)) {
99 if (dolibarr_set_const($db, 'API_ENABLE_COUNT_CALLS', GETPOSTINT('status'), 'chaine', 0, '', 0) <= 0) {
100 dol_print_error($db);
101 }
102}
103
104if ($action == 'save') {
105 if (dolibarr_set_const($db, 'API_RESTRICT_ON_IP', GETPOST('API_RESTRICT_ON_IP', 'alpha')) <= 0) {
106 dol_print_error($db);
107 }
108}
109
110
111dol_mkdir(DOL_DATA_ROOT.'/api/temp'); // May have been deleted by a purge
112
113
114/*
115 * View
116 */
117
118llxHeader('', '', '', '', 0, 0, '', '', '', 'mod-api page-admin-index');
119
120$linkback = '<a href="'.dolBuildUrl(DOL_URL_ROOT.'/admin/modules.php', ['restore_lastsearch_values' => 1]).'">'.img_picto($langs->trans("BackToModuleList"), 'back', 'class="pictofixedwidth"').'<span class="hideonsmartphone">'.$langs->trans("BackToModuleList").'</span></a>';
121
122print load_fiche_titre($langs->trans("ApiSetup"), $linkback, 'title_setup');
123
124$head = api_admin_prepare_head();
125
126print dol_get_fiche_head($head, 'parameter', '', -1);
127
128print '<span class="opacitymedium">'.$langs->trans("ApiDesc")."</span><br>\n";
129print "<br>\n";
130
131print '<form method="POST" action="'.dolBuildUrl($_SERVER["PHP_SELF"]).'">';
132print '<input type="hidden" name="token" value="'.newToken().'">';
133print '<input type="hidden" name="action" value="save">';
134
135print '<table class="noborder centpercent">';
136
137print '<tr class="liste_titre">';
138print "<td>".$langs->trans("Parameter")."</td>";
139print '<td>'.$langs->trans("Value")."</td>";
140print "<td>&nbsp;</td>";
141print "</tr>";
142
143print '<tr class="oddeven">';
144print '<td>'.$langs->trans("ApiProductionMode").'</td>';
145$production_mode = getDolGlobalBool('API_PRODUCTION_MODE');
146if ($production_mode) {
147 print '<td><a class="reposition" href="'.$_SERVER['PHP_SELF'].'?action=setproductionmode&token='.newToken().'&status=0">';
148 print img_picto($langs->trans("Activated"), 'switch_on');
149 print '</a></td>';
150} else {
151 print '<td><a class="reposition" href="'.$_SERVER['PHP_SELF'].'?action=setproductionmode&token='.newToken().'&status=1">';
152 print img_picto($langs->trans("Disabled"), 'switch_off');
153 print '</a></td>';
154}
155print '<td>&nbsp;</td>';
156print '</tr>';
157
158print '<tr class="oddeven">';
159print '<td>'.$langs->trans("API_DISABLE_COMPRESSION").'</td>';
160$disable_compression = getDolGlobalBool('API_DISABLE_COMPRESSION');
161if ($disable_compression) {
162 print '<td><a class="reposition" href="'.$_SERVER['PHP_SELF'].'?action=setdisablecompression&token='.newToken().'&status=0">';
163 print img_picto($langs->trans("Activated"), 'switch_on');
164 print '</a></td>';
165} else {
166 print '<td><a class="reposition" href="'.$_SERVER['PHP_SELF'].'?action=setdisablecompression&token='.newToken().'&status=1">';
167 print img_picto($langs->trans("Disabled"), 'switch_off');
168 print '</a></td>';
169}
170print '<td>&nbsp;</td>';
171print '</tr>';
172
173print '<tr class="oddeven">';
174print '<td>'.$langs->trans("API_ENABLE_COUNT_CALLS").'</td>';
175$enable_count = getDolGlobalBool('API_ENABLE_COUNT_CALLS');
176if (!empty($dolibarr_api_count_always_enabled)) {
177 print '<td>';
178 print img_picto($langs->trans("AlwaysEnabled"), 'switch_on', 'class="opacitymedium"');
179 print '</td>';
180} else {
181 if ($enable_count) {
182 print '<td><a class="reposition" href="'.$_SERVER['PHP_SELF'].'?action=setenablecount&token='.newToken().'&status=0">';
183 print img_picto($langs->trans("Activated"), 'switch_on');
184 print '</a></td>';
185 } else {
186 print '<td><a class="reposition" href="'.$_SERVER['PHP_SELF'].'?action=setenablecount&token='.newToken().'&status=1">';
187 print img_picto($langs->trans("Disabled"), 'switch_off');
188 print '</a></td>';
189 }
190}
191print '<td>&nbsp;</td>';
192print '</tr>';
193
194print '<tr class="oddeven">';
195print '<td>'.$form->textwithpicto($langs->trans("RESTRICT_ON_IP"), $langs->trans("Example").': '.$langs->trans("IPListExample"));
196print '</td>';
197print '<td><input type="text" name="API_RESTRICT_ON_IP" value="'.dol_escape_htmltag(getDolGlobalString('API_RESTRICT_ON_IP')).'" spellcheck="false"></td>';
198print '<td>';
199print '<input type="submit" class="button button-save smallpaddingimp" name="save" value="'.dol_escape_htmltag($langs->trans("Save")).'"></td>';
200print '</td>';
201print '</tr>';
202
203print '</table>';
204print '<br><br>';
205
206print '</form>';
207
208
209// Define $urlwithroot
210$urlwithouturlroot = preg_replace('/'.preg_quote(DOL_URL_ROOT, '/').'$/i', '', trim($dolibarr_main_url_root));
211$urlwithroot = $urlwithouturlroot.DOL_URL_ROOT; // This is to use external domain name found into config file
212//$urlwithroot=DOL_MAIN_URL_ROOT; // This is to use same domain name than current
213
214// Show message
215$message = '';
216//$url = $urlwithroot.'/api/index.php/login?login=<strong>auserlogin</strong>&password=<strong>thepassword</strong>[&reset=1]';
217$url = $urlwithroot.'/api/index.php/login?login=auserlogin&password=thepassword[&reset=1]';
218$message .= '<span class="opacitymedium">'.$langs->trans("UrlToGetKeyToUseAPIs").':</span><br>';
219$message .= '<div class="urllink soixantepercent">'.img_picto('', 'globe').' <input type="text" class="quatrevingtpercent" id="urltogettoken" value="'.$url.'" spellcheck="false"></div>';
220print $message;
221print ajax_autoselect("urltogettoken");
222print '<br>';
223print '<br>';
224
225// Explorer
226print '<span class="opacitymedium">'.$langs->trans("ApiExporerIs").':</span><br>';
227if (dol_is_dir(DOL_DOCUMENT_ROOT.'/includes/restler/framework/Luracast/Restler/explorer')) {
228 $url = DOL_MAIN_URL_ROOT.'/api/index.php/explorer';
229 print '<div class="urllink soixantepercent">'.img_picto('', 'globe').' <a href="'.$url.'" target="_blank" rel="noopener noreferrer">'.$url."</a></div><br>\n";
230
231 print '<div class="opacitymediumxxx"><br><span class="opacitymedium">'.$langs->trans("SwaggerDescriptionFile").':</span><br>';
232 $urlswagger = DOL_MAIN_URL_ROOT.'/api/index.php/explorer/swagger.json?DOLAPIKEY=youruserapikey';
233 //$urlswaggerreal = DOL_MAIN_URL_ROOT.'/api/index.php/explorer/swagger.json?DOLAPIKEY='.$user->api_key;
234 print '<div class="urllink soixantepercent">'.img_picto('', 'globe').' <input type="text" class="quatrevingtpercent" id="urltogetapidesc" value="'.$urlswagger.'" spellcheck="false"></div>';
235 print '</div>';
236 print ajax_autoselect("urltogetapidesc");
237} else {
238 $langs->load("errors");
239 print info_admin($langs->trans("ErrorNotAvailableWithThisDistribution"), 0, 0, 'error');
240}
241
242llxFooter();
243$db->close();
global $dolibarr_main_url_root
dolibarr_set_const($db, $name, $value, $type='chaine', $visible=0, $note='', $entity=1)
Insert a parameter (key,value) into database (delete old key then insert it again).
api_admin_prepare_head()
Return array head with list of tabs to view object information.
Definition api.lib.php:32
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
Definition wrapper.php:91
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Definition wrapper.php:73
dol_delete_file($file, $disableglob=0, $nophperrors=0, $nohook=0, $object=null, $allowdotdot=false, $indexdatabase=1, $nolog=0)
Remove a file or several files with a mask.
dol_is_dir($folder)
Test if filename is a directory.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0, $morecssdiv='')
Show tabs of a record.
ajax_autoselect($htmlname, $addlink='', $textonlink='Link')
Make content of an input box selected when we click into input field.
newToken()
Return the value of token currently saved into session with name 'newtoken'.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
getDolGlobalBool($key, $default=false)
Return a Dolibarr global constant boolean value.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
info_admin($text, $infoonimgalt=0, $nodiv=0, $admin='1', $morecss='hideonsmartphone', $textfordropdown='', $picto='')
Show information in HTML for admin users or standard users.
dol_mkdir($dir, $dataroot='', $newmask='')
Creation of a directory (this can create recursive subdir)
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.