27 require
'../main.inc.php';
28 require_once DOL_DOCUMENT_ROOT.
'/core/lib/admin.lib.php';
29 require_once DOL_DOCUMENT_ROOT.
'/core/lib/oauth.lib.php';
30 require_once DOL_DOCUMENT_ROOT.
'/core/class/doleditor.class.php';
31 use OAuth\Common\Storage\DoliStorage;
34 $langs->loadLangs(array(
'admin',
'printing',
'oauth'));
36 $action =
GETPOST(
'action',
'aZ09');
37 $mode =
GETPOST(
'mode',
'alpha');
38 $value =
GETPOST(
'value',
'alpha');
39 $varname =
GETPOST(
'varname',
'alpha');
40 $driver =
GETPOST(
'driver',
'alpha');
42 if (!empty($driver)) {
43 $langs->load($driver);
66 if ($action ==
'setconst' && $user->admin) {
70 $setupconstarray =
GETPOST(
'setupdriver',
'array');
72 foreach ($setupconstarray as $setupconst) {
80 $result =
dolibarr_set_const($db, $constname, $constvalue, $consttype, 0, $constnote, $conf->entity);
96 if ($action ==
'setvalue' && $user->admin) {
100 if (!($result > 0)) {
120 $urlwithouturlroot = preg_replace(
'/'.preg_quote(DOL_URL_ROOT,
'/').
'$/i',
'', trim($dolibarr_main_url_root));
121 $urlwithroot = $urlwithouturlroot.DOL_URL_ROOT;
126 llxHeader(
'', $langs->trans(
"TokenManager"));
128 $linkback =
'<a href="'.DOL_URL_ROOT.
'/admin/modules.php?restore_lastsearch_values=1">'.$langs->trans(
"BackToModuleList").
'</a>';
129 print
load_fiche_titre($langs->trans(
'ConfigOAuth'), $linkback,
'title_setup');
139 if ($mode ==
'setup' && $user->admin) {
140 print
'<span class="opacitymedium">'.$langs->trans(
"OAuthSetupForLogin").
"</span><br><br>\n";
143 foreach ($conf->global as $key => $val) {
144 if (!empty($val) && preg_match(
'/^OAUTH_.*_ID$/', $key)) {
145 $provider = preg_replace(
'/_ID$/',
'', $key);
146 $listinsetup[] = array(
150 $provider.
'_URLAUTHORIZE',
156 $oauthstateanticsrf = bin2hex(random_bytes(128/8));
159 foreach ($listinsetup as $key) {
161 $keyforsupportedoauth2array = $key[0];
162 $keyforsupportedoauth2array = preg_replace(
'/^OAUTH_/',
'', $keyforsupportedoauth2array);
163 $keyforsupportedoauth2array = preg_replace(
'/_NAME$/',
'', $keyforsupportedoauth2array);
164 if (preg_match(
'/^.*-/', $keyforsupportedoauth2array)) {
165 $keybeforeprovider = preg_replace(
'/-.*$/',
'', $keyforsupportedoauth2array);
166 $keyforprovider = preg_replace(
'/^.*-/',
'', $keyforsupportedoauth2array);
168 $keybeforeprovider = $keyforsupportedoauth2array;
169 $keyforprovider =
'';
171 $keyforsupportedoauth2array = preg_replace(
'/-.*$/',
'', $keyforsupportedoauth2array);
172 $keyforsupportedoauth2array =
'OAUTH_'.$keyforsupportedoauth2array.
'_NAME';
175 $OAUTH_SERVICENAME = (empty($supportedoauth2array[$keyforsupportedoauth2array][
'name']) ?
'Unknown' : $supportedoauth2array[$keyforsupportedoauth2array][
'name'].($keyforprovider ?
'-'.$keyforprovider :
''));
181 $state = $shortscope;
184 if ($keyforsupportedoauth2array ==
'OAUTH_GITHUB_NAME') {
189 $urltorenew = $urlwithroot.
'/core/modules/oauth/github_oauthcallback.php?shortscope='.urlencode($shortscope).
'&state='.urlencode($shortscope).
'&backtourl='.urlencode(DOL_URL_ROOT.
'/admin/oauthlogintokens.php');
190 $urltodelete = $urlwithroot.
'/core/modules/oauth/github_oauthcallback.php?action=delete&token='.
newToken().
'&backtourl='.urlencode(DOL_URL_ROOT.
'/admin/oauthlogintokens.php');
191 $urltocheckperms =
'https://github.com/settings/applications/';
192 } elseif ($keyforsupportedoauth2array ==
'OAUTH_GOOGLE_NAME') {
196 $urltorenew = $urlwithroot.
'/core/modules/oauth/google_oauthcallback.php?shortscope='.urlencode($shortscope).
'&state='.urlencode($state).
'-'.$oauthstateanticsrf.
'&backtourl='.urlencode(DOL_URL_ROOT.
'/admin/oauthlogintokens.php');
197 $urltodelete = $urlwithroot.
'/core/modules/oauth/google_oauthcallback.php?action=delete&token='.
newToken().
'&backtourl='.urlencode(DOL_URL_ROOT.
'/admin/oauthlogintokens.php');
198 $urltocheckperms =
'https://security.google.com/settings/security/permissions';
199 } elseif (!empty($supportedoauth2array[$keyforsupportedoauth2array][
'returnurl'])) {
200 $urltorenew = $urlwithroot.$supportedoauth2array[$keyforsupportedoauth2array][
'returnurl'].
'?shortscope='.urlencode($shortscope).
'&state='.urlencode($state).
'&backtourl='.urlencode(DOL_URL_ROOT.
'/admin/oauthlogintokens.php');
201 $urltodelete = $urlwithroot.$supportedoauth2array[$keyforsupportedoauth2array][
'returnurl'].
'?action=delete&token='.
newToken().
'&backtourl='.urlencode(DOL_URL_ROOT.
'/admin/oauthlogintokens.php');
202 $urltocheckperms =
'';
206 $urltocheckperms =
'';
210 $urltorenew .=
'&keyforprovider='.urlencode($keyforprovider);
213 $urltodelete .=
'&keyforprovider='.urlencode($keyforprovider);
219 require_once DOL_DOCUMENT_ROOT.
'/includes/OAuth/bootstrap.php';
221 $storage =
new DoliStorage($db, $conf, $keyforprovider);
224 print
'<!-- '.$OAUTH_SERVICENAME.
' -->'.
"\n";
225 $tokenobj = $storage->retrieveAccessToken($OAUTH_SERVICENAME);
235 $refreshtoken =
false;
240 if (is_object($tokenobj)) {
241 $expire = ($tokenobj->getEndOfLife() !== $tokenobj::EOL_NEVER_EXPIRES && $tokenobj->getEndOfLife() !== $tokenobj::EOL_UNKNOWN && time() > ($tokenobj->getEndOfLife() - 30));
243 if ($key[1] !=
'' && $key[2] !=
'') {
244 if (is_object($tokenobj)) {
245 $refreshtoken = $tokenobj->getRefreshToken();
247 $endoflife = $tokenobj->getEndOfLife();
248 if ($endoflife == $tokenobj::EOL_NEVER_EXPIRES) {
249 $expiredat = $langs->trans(
"Never");
250 } elseif ($endoflife == $tokenobj::EOL_UNKNOWN) {
251 $expiredat = $langs->trans(
"Unknown");
260 print
'<form method="post" action="'.$_SERVER[
"PHP_SELF"].
'?mode=setup&driver='.$driver.
'" autocomplete="off">';
261 print
'<input type="hidden" name="token" value="'.newToken().
'">';
262 print
'<input type="hidden" name="action" value="setconst">';
264 print
'<div class="div-table-responsive-no-min">';
265 print
'<table class="noborder centpercent">'.
"\n";
268 $label = $langs->trans($keyforsupportedoauth2array);
269 print
'<tr class="liste_titre">';
270 print
'<th class="titlefieldcreate">';
271 print
img_picto(
'', $supportedoauth2array[$keyforsupportedoauth2array][
'picto'],
'class="pictofixedwidth"');
272 if ($label == $keyforsupportedoauth2array) {
273 print $supportedoauth2array[$keyforsupportedoauth2array][
'name'];
277 if ($keyforprovider) {
278 print
' (<b>'.$keyforprovider.
'</b>)';
280 print
' (<b>'.$langs->trans(
"NoName").
'</b>)';
287 print
'<tr class="oddeven">';
288 print
'<td'.(empty($key[
'required']) ?
'' :
' class="required"').
'>';
290 print $langs->trans(
"OAuthIDSecret").
'</td>';
292 print
'<span class="opacitymedium">'.$langs->trans(
"SeePreviousTab").
'</span>';
299 print
'<tr class="oddeven">';
300 print
'<td>'.$langs->trans(
"Scopes").
'</td>';
301 print
'<td colspan="2">';
303 print $currentscopes;
306 print
'<tr class="oddeven">';
307 print
'<td'.(empty($key[
'required']) ?
'' :
' class="required"').
'>';
309 print $langs->trans(
"IsTokenGenerated");
312 if (is_object($tokenobj)) {
315 print
'<span class="opacitymedium">'.$langs->trans(
"NoAccessToken").
'</span>';
318 print
'<td width="50%">';
320 if (is_object($tokenobj)) {
323 print
'<a class="button smallpaddingimp" href="'.$urltodelete.
'">'.$langs->trans(
'DeleteAccess').
'</a><br>';
325 print
'<span class="opacitymedium">'.$langs->trans(
'GoOnTokenProviderToDeleteToken').
'</span><br>';
330 print
'<a class="button smallpaddingimp" href="'.$urltorenew.
'">'.$langs->trans(
'GetAccess').
'</a>';
331 print
$form->textwithpicto(
'', $langs->trans(
'RequestAccess'));
335 if ($urltocheckperms) {
336 print
'<br>'.$langs->trans(
"ToCheckDeleteTokenOnProvider", $OAUTH_SERVICENAME).
': <a href="'.$urltocheckperms.
'" target="_'.strtolower($OAUTH_SERVICENAME).
'">'.$urltocheckperms.
'</a>';
341 print
'<tr class="oddeven">';
342 print
'<td'.(empty($key[
'required']) ?
'' :
' class="required"').
'>';
344 print $langs->trans(
"Token").
'</td>';
345 print
'<td colspan="2">';
347 if (is_object($tokenobj)) {
348 $tokentoshow = $tokenobj->getAccessToken();
360 if (is_object($tokenobj)) {
362 print
'<tr class="oddeven">';
363 print
'<td'.(empty($key[
'required']) ?
'' :
' class="required"').
'>';
365 print $langs->trans(
"TOKEN_REFRESH");
367 print
'<td colspan="2">';
373 print
'<tr class="oddeven">';
374 print
'<td'.(empty($key[
'required']) ?
'' :
' class="required"').
'>';
376 print $langs->trans(
"TOKEN_EXPIRED");
378 print
'<td colspan="2">';
384 print
'<tr class="oddeven">';
385 print
'<td'.(empty($key[
'required']) ?
'' :
' class="required"').
'>';
387 print $langs->trans(
"TOKEN_EXPIRE_AT");
389 print
'<td colspan="2">';
398 if (!empty($driver)) {
399 if ($submit_enabled) {
400 print
$form->buttonsSaveCancel(
"Modify",
'');
409 if ($mode ==
'test' && $user->admin) {
410 print $langs->trans(
'PrintTestDesc'.$driver).
"<br><br>\n";
412 print
'<div class="div-table-responsive-no-min">';
413 print
'<table class="noborder centpercent">';
414 if (!empty($driver)) {
415 require_once DOL_DOCUMENT_ROOT.
'/core/modules/printing/'.$driver.
'.modules.php';
416 $classname =
'printing_'.$driver;
417 $langs->load($driver);
418 $printer =
new $classname($db);
420 if (count($printer->getlistAvailablePrinters())) {
421 if ($printer->listAvailablePrinters() == 0) {
422 print $printer->resprint;
427 print $langs->trans(
'PleaseConfigureDriverfromList');
435 if ($mode ==
'userconf' && $user->admin) {
436 print $langs->trans(
'PrintUserConfDesc'.$driver).
"<br><br>\n";
438 print
'<div class="div-table-responsive">';
439 print
'<table class="noborder centpercent">';
440 print
'<tr class="liste_titre">';
441 print
'<th>'.$langs->trans(
"User").
'</th>';
442 print
'<th>'.$langs->trans(
"PrintModule").
'</th>';
443 print
'<th>'.$langs->trans(
"PrintDriver").
'</th>';
444 print
'<th>'.$langs->trans(
"Printer").
'</th>';
445 print
'<th>'.$langs->trans(
"PrinterLocation").
'</th>';
446 print
'<th>'.$langs->trans(
"PrinterId").
'</th>';
447 print
'<th>'.$langs->trans(
"NumberOfCopy").
'</th>';
448 print
'<th class="center">'.$langs->trans(
"Delete").
'</th>';
450 $sql =
"SELECT p.rowid, p.printer_name, p.printer_location, p.printer_id, p.copy, p.module, p.driver, p.userid, u.login";
451 $sql .=
" FROM ".MAIN_DB_PREFIX.
"printing as p, ".MAIN_DB_PREFIX.
"user as u WHERE p.userid = u.rowid";
452 $resql = $db->query(
$sql);
453 while ($obj = $db->fetch_object($resql)) {
454 print
'<tr class="oddeven">';
455 print
'<td>'.$obj->login.
'</td>';
456 print
'<td>'.$obj->module.
'</td>';
457 print
'<td>'.$obj->driver.
'</td>';
458 print
'<td>'.$obj->printer_name.
'</td>';
459 print
'<td>'.$obj->printer_location.
'</td>';
460 print
'<td>'.$obj->printer_id.
'</td>';
461 print
'<td>'.$obj->copy.
'</td>';
462 print
'<td class="center">'.img_picto($langs->trans(
"Delete"),
'delete').
'</td>';