28require
'../main.inc.php';
29require_once DOL_DOCUMENT_ROOT.
'/core/lib/admin.lib.php';
30require_once DOL_DOCUMENT_ROOT.
'/core/lib/oauth.lib.php';
46$urlwithroot = $urlwithouturlroot.DOL_URL_ROOT;
50$langs->loadLangs(array(
'admin',
'oauth',
'modulebuilder'));
57$action =
GETPOST(
'action',
'aZ09');
58$provider =
GETPOST(
'provider',
'aZ09');
59$label =
GETPOST(
'label',
'aZ09');
61$servicetoeditname =
GETPOST(
'servicetoeditname',
'aZ09');
70if ($action ==
'add') {
71 if ($provider && $provider !=
'-1') {
72 $constname = strtoupper($provider).($label ?
'-'.$label :
'').
'_ID';
75 setEventMessages($langs->trans(
"AOAuthEntryForThisProviderAndLabelAlreadyHasAKey"),
null,
'errors');
78 dolibarr_set_const($db, $constname, $langs->trans(
'ToComplete'),
'chaine', 0,
'', $conf->entity);
83if ($action ==
'update') {
84 foreach ($conf->global as $key => $val) {
85 if (!empty($val) && preg_match(
'/^OAUTH_.+_ID$/', $key)) {
86 $constvalue = str_replace(
'_ID',
'', $key);
87 $newconstvalue = $constvalue;
88 if (GETPOSTISSET($constvalue.
'_NAME')) {
89 $newconstvalue = preg_replace(
'/-.*$/',
'', $constvalue).
'-'.preg_replace(
'/[^a-z]/',
'',
GETPOST($constvalue.
'_NAME'));
92 if (GETPOSTISSET($constvalue.
'_ID')) {
98 if (GETPOSTISSET($constvalue.
'_SECRET')) {
103 if (GETPOSTISSET($constvalue.
'_URL')) {
104 $cleanurl =
GETPOST($constvalue.
'_URL');
105 $cleanurl = preg_replace(
'/\/$/',
'', $cleanurl);
106 if (!
dolibarr_set_const($db, $newconstvalue.
'_URL', $cleanurl,
'chaine', 0,
'', $conf->entity)) {
110 if (GETPOSTISSET($constvalue.
'_URLAUTHORIZE')) {
111 if (!
dolibarr_set_const($db, $newconstvalue.
'_URLAUTHORIZE',
GETPOST($constvalue.
'_URLAUTHORIZE'),
'chaine', 0,
'', $conf->entity)) {
115 if (GETPOSTISSET($constvalue.
'_TENANT')) {
120 if (GETPOSTISSET($constvalue.
'_SCOPE')) {
121 if (is_array(
GETPOST($constvalue.
'_SCOPE'))) {
122 $scopestring = implode(
',',
GETPOST($constvalue.
'_SCOPE'));
124 $scopestring =
GETPOST($constvalue.
'_SCOPE');
126 if (!
dolibarr_set_const($db, $newconstvalue.
'_SCOPE', $scopestring,
'chaine', 0,
'', $conf->entity)) {
129 } elseif ($newconstvalue !== $constvalue) {
130 if (!
dolibarr_set_const($db, $newconstvalue.
'_SCOPE',
'',
'chaine', 0,
'', $conf->entity)) {
136 if ($constvalue !== $newconstvalue) {
144 $oldname = preg_replace(
'/^OAUTH_/',
'', $constvalue);
145 $oldprovider = ucfirst(strtolower(preg_replace(
'/-.*$/',
'', $oldname)));
146 $oldlabel = preg_replace(
'/^.*-/',
'', $oldname);
147 $newlabel = preg_replace(
'/^.*-/',
'', $newconstvalue);
150 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"oauth_token";
151 $sql.=
" SET service = '".$db->escape($oldprovider.
"-".$newlabel).
"'";
152 $sql.=
" WHERE service = '".$db->escape($oldprovider.
"-".$oldlabel).
"'";
155 $resql = $db->query($sql);
162 if (!
dolibarr_set_const($db,
'MAIN_MAIL_SMTPS_OAUTH_SERVICE', strtoupper($oldprovider).
'-'.$newlabel,
'chaine', 0,
'', $conf->entity)) {
178if ($action ==
'confirm_delete') {
179 $provider =
GETPOST(
'provider',
'aZ09');
182 $globalkey = empty($provider) ? $label : $label.
'-'.$provider;
185 $backtourl = DOL_URL_ROOT.
'/admin/oauth.php?action=delete_entry&provider='.$provider.
'&label='.$label.
'&token='.
newToken();
187 $urlwithroot = $urlwithouturlroot.DOL_URL_ROOT;
188 $callbacktodel = $urlwithroot;
189 if ($label ==
'OAUTH_GOOGLE') {
190 $callbacktodel .=
'/core/modules/oauth/google_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
191 } elseif ($label ==
'OAUTH_GITHUB') {
192 $callbacktodel .=
'/core/modules/oauth/github_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
193 } elseif ($label ==
'OAUTH_STRIPELIVE') {
194 $callbacktodel .=
'/core/modules/oauth/stripelive_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
195 } elseif ($label ==
'OAUTH_STRIPETEST') {
196 $callbacktodel .=
'/core/modules/oauth/stripetest_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
197 } elseif ($label ==
'OAUTH_MICROSOFT') {
198 $callbacktodel .=
'/core/modules/oauth/microsoft_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
199 } elseif ($label ==
'OAUTH_MICROSOFT2') {
200 $callbacktodel .=
'/core/modules/oauth/microsoft2_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
201 } elseif ($label ==
'OAUTH_GENERIC') {
202 $callbacktodel .=
'/core/modules/oauth/generic_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
204 header(
"Location: ".$callbacktodel);
207 $action =
'delete_entry';
211if ($action ==
'delete_entry') {
212 $provider =
GETPOST(
'provider',
'aZ09');
215 $globalkey = empty($provider) ? $label : $label.
'-'.$provider;
235$form =
new Form($db);
237$title = $langs->trans(
'ConfigOAuth');
238$help_url =
'EN:Module_OAuth|FR:Module_OAuth_FR|ES:Módulo_OAuth_ES';
240llxHeader(
'', $title, $help_url,
'', 0, 0,
'',
'',
'',
'mod-admin page-oauth');
243if ($action ==
'delete') {
244 $formquestion = array();
245 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?provider='.
GETPOST(
'provider').
'&label='.
GETPOST(
'label'), $langs->trans(
'OAuthServiceConfirmDeleteTitle'), $langs->trans(
'OAuthServiceConfirmDeleteMessage'),
'confirm_delete', $formquestion, 0, 1, 220);
250$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>';
254print
'<form action="'.$_SERVER[
"PHP_SELF"].
'" method="POST">';
255print
'<input type="hidden" name="token" value="'.newToken().
'">';
256print
'<input type="hidden" name="action" value="add">';
263print
'<span class="opacitymedium">'.$langs->trans(
"ListOfSupportedOauthProviders").
'</span><br><br>';
269print
'<select name="provider" id="provider" class="minwidth150">';
270print
'<option name="-1" value="-1">'.$langs->trans(
"OAuthProvider").
'</option>';
272foreach ($list as $key) {
274 $keyforsupportedoauth2array = $key[0];
276 if (in_array($keyforsupportedoauth2array, array_keys($supportedoauth2array))) {
283 print
'<option name="'.$keyforsupportedoauth2array.
'" value="'.str_replace(
'_NAME',
'', $keyforsupportedoauth2array).
'">';
285 $keyforsupportedoauth2array = preg_replace(
'/^OAUTH_/',
'', $keyforsupportedoauth2array);
286 $keyforsupportedoauth2array = preg_replace(
'/_NAME$/',
'', $keyforsupportedoauth2array);
287 $keyforsupportedoauth2array = preg_replace(
'/-.*$/',
'', $keyforsupportedoauth2array);
288 $keyforsupportedoauth2array =
'OAUTH_'.$keyforsupportedoauth2array.
'_NAME';
290 $label = $langs->trans($keyforsupportedoauth2array);
291 if ($label == $keyforsupportedoauth2array) {
292 print $supportedoauth2array[$keyforsupportedoauth2array][
'name'];
296 print
'</option>'.
"\n";
300print
' <input type="text" name="label" value="" placeholder="'.$langs->trans(
"Label").
'" pattern="^[a-zA-Z0-9]+$" title="'.$langs->trans(
"SpaceOrSpecialCharAreNotAllowed").
'">';
301print
' <input type="submit" class="button small" name="add" value="'.$langs->trans(
"Add").
'">';
312foreach ($conf->global as $key => $val) {
313 if (!empty($val) && preg_match(
'/^OAUTH_.*_ID$/', $key)) {
314 $provider = preg_replace(
'/_ID$/',
'', $key);
315 $listinsetup[] = array(
326if (count($listinsetup) > 0) {
327 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'" method="POST">';
328 print
'<input type="hidden" name="token" value="'.newToken().
'">';
329 print
'<input type="hidden" name="action" value="update">';
331 print
'<div class="div-table-responsive-no-min">';
336 foreach ($listinsetup as $key) {
338 $keyforsupportedoauth2array = $key[0];
339 $keyforsupportedoauth2array = preg_replace(
'/^OAUTH_/',
'', $keyforsupportedoauth2array);
340 $keyforsupportedoauth2array = preg_replace(
'/_NAME$/',
'', $keyforsupportedoauth2array);
341 if (preg_match(
'/^.*-/', $keyforsupportedoauth2array)) {
342 $keybeforeprovider = preg_replace(
'/-.*$/',
'', $keyforsupportedoauth2array);
343 $keyforprovider = preg_replace(
'/^.*-/',
'', $keyforsupportedoauth2array);
345 $keybeforeprovider = $keyforsupportedoauth2array;
346 $keyforprovider =
'';
348 $keyforsupportedoauth2array = preg_replace(
'/-.*$/',
'', $keyforsupportedoauth2array);
349 $keyforsupportedoauth2array =
'OAUTH_'.$keyforsupportedoauth2array.
'_NAME';
351 if (in_array($keyforsupportedoauth2array, array_keys($supportedoauth2array))) {
360 print
'<table class="noborder centpercent">';
363 $label = $langs->trans($keyforsupportedoauth2array);
364 print
'<tr class="liste_titre'.($i > 1 ?
' liste_titre_add' :
'').
'">';
365 print
'<td class="titlefieldcreate">';
366 print
img_picto(
'', $supportedoauth2array[$keyforsupportedoauth2array][
'picto'],
'class="pictofixedwidth"');
367 if ($label == $keyforsupportedoauth2array) {
368 print $supportedoauth2array[$keyforsupportedoauth2array][
'name'];
372 if ($servicetoeditname == $key[0]) {
373 print
' (<input style="width: 20%" type="text" name="'.$key[0].
'" value="'.$keyforprovider.
'" >)';
374 } elseif ($keyforprovider) {
375 print
' (<b>'.$keyforprovider.
'</b>)';
377 print
' (<b>'.$langs->trans(
"NoName").
'</b>)';
379 if (!($servicetoeditname == $key[0])) {
380 print
'<a class="editfielda reposition" href="'.$_SERVER[
"PHP_SELF"].
'?token='.
newToken().
'&servicetoeditname='.urlencode($key[0]).
'">'.
img_edit($langs->transnoentitiesnoconv(
'Edit'), 1).
'</a>';
384 if (!empty($supportedoauth2array[$keyforsupportedoauth2array][
'urlforcredentials'])) {
385 print $langs->trans(
"OAUTH_URL_FOR_CREDENTIAL", $supportedoauth2array[$keyforsupportedoauth2array][
'urlforcredentials']);
391 $label = preg_replace(
'/_NAME$/',
'', $keyforsupportedoauth2array);
392 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?action=delete&token='.
newToken().
'&provider='.urlencode($keyforprovider).
'&label='.urlencode($label).
'">';
402 $redirect_uri = $urlwithroot.
'/core/modules/oauth/'.$supportedoauth2array[$keyforsupportedoauth2array][
'callbackfile'].
'_oauthcallback.php';
403 print
'<tr class="oddeven value">';
404 print
'<td>'.$form->textwithpicto($langs->trans(
"RedirectURL"), $langs->trans(
"UseTheFollowingUrlAsRedirectURI")).
'</td>';
405 print
'<td><input style="width: 80%" type="text" name="uri'.$keyforsupportedoauth2array.
'" id="uri'.$keyforsupportedoauth2array.$keyforprovider.
'" value="'.$redirect_uri.
'" disabled>';
406 print
ajax_autoselect(
'uri'.$keyforsupportedoauth2array.$keyforprovider);
411 if ($keyforsupportedoauth2array ==
'OAUTH_GENERIC_NAME') {
412 print
'<tr class="oddeven value">';
414 $tooltiphelp = $langs->trans(
"Example").
'<br>https://mastodon.example.com<br>https://mastodon.social';
415 print $form->textwithpicto($langs->trans(
"URLOfOAuthServiceEndpoints"), $tooltiphelp);
417 print
'<td><input style="width: 80%" type="text" name="'.$key[3].
'" value="'.
getDolGlobalString($key[3]).
'" >';
423 print
'<tr class="oddeven value">';
424 print
'<td>'.$langs->trans(
"UseTheFollowingUrlAsRedirectURI").
'</td>';
425 print
'<td>'.$langs->trans(
"FeatureNotYetSupported").
'</td>';
432 print
'<tr class="oddeven value">';
433 print
'<td><label for="'.$key[1].
'">'.$langs->trans(
"OAUTH_ID").
'</label></td>';
434 print
'<td><input type="text" size="100" id="'.$key[1].
'" name="'.$key[1].
'" value="'.
getDolGlobalString($key[1]).
'">';
440 print
'<tr class="oddeven value">';
441 print
'<td><label for="'.$key[2].
'">'.$langs->trans(
"OAUTH_SECRET").
'</label></td>';
442 print
'<td><input type="password" size="100" id="'.$key[2].
'" name="'.$key[2].
'" value="'.
getDolGlobalString($key[2]).
'">';
448 if ($keybeforeprovider ==
'MICROSOFT' || $keybeforeprovider ==
'MICROSOFT2' || $keybeforeprovider ==
'MICROSOFT3') {
449 print
'<tr class="oddeven value">';
450 print
'<td><label for="'.$key[2].
'">'.$langs->trans(
"OAUTH_TENANT").
'</label></td>';
451 print
'<td><input type="text" size="100" id="OAUTH_'.$keybeforeprovider.($keyforprovider ?
'-'.$keyforprovider :
'').
'_TENANT" name="OAUTH_'.$keybeforeprovider.($keyforprovider ?
'-'.$keyforprovider :
'').
'_TENANT" value="'.
getDolGlobalString(
'OAUTH_'.$keybeforeprovider.($keyforprovider ?
'-'.$keyforprovider :
'').
'_TENANT').
'">';
459 if ($keyforsupportedoauth2array ==
'OAUTH_GENERIC_NAME') {
460 print
'<tr class="oddeven value">';
462 print $form->textwithpicto($langs->trans(
"Scopes"), $langs->trans(
"ScopesDesc"));
465 print
'<input style="width: 80%" type"text" name="'.$key[4].
'" value="'.
getDolGlobalString($key[4]).
'" >';
470 $availablescopes = array_flip(explode(
',', $supportedoauth2array[$keyforsupportedoauth2array][
'availablescopes']));
472 $scopestodispay = array();
473 foreach ($availablescopes as $keyscope => $valscope) {
474 if (in_array($keyscope, $currentscopes)) {
475 $scopestodispay[$keyscope] = 1;
477 $scopestodispay[$keyscope] = 0;
481 print
'<tr class="oddeven value">';
482 print
'<td>'.$langs->trans(
"Scopes").
'</td>';
484 foreach ($scopestodispay as $scope => $val) {
485 print
'<input type="checkbox" id="'.$keyforprovider.$scope.
'" name="'.$key[4].
'[]" value="'.$scope.
'"'.($val ?
' checked' :
'').
'>';
486 print
'<label style="margin-right: 10px" for="'.$keyforprovider.$scope.
'">'.$scope.
'</label>';
493 print
'<tr class="oddeven value">';
494 print
'<td>'.$langs->trans(
"UseTheFollowingUrlAsRedirectURI").
'</td>';
495 print
'<td>'.$langs->trans(
"FeatureNotYetSupported").
'</td>';
501 print
'</table>'.
"\n";
508 print $form->buttonsSaveCancel(
"Save",
'');
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).
dolibarr_del_const($db, $name, $entity=1)
Delete a constant.
ajax_combobox($htmlname, $events=array(), $minLengthToAutocomplete=0, $forcefocus=0, $widthTypeOfAutocomplete='resolve', $idforemptyvalue='-1', $morecss='')
Convert a html select field into an ajax combobox.
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
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.
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)
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.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
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.
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.
img_edit($titlealt='default', $float=0, $other='')
Show logo edit/modify fiche.
getAllOauth2Array()
Return array of possible OAUTH2 services.
getSupportedOauth2Array()
Return array of tabs to use on pages to setup cron module.
oauthadmin_prepare_head()
Return array of tabs to used on pages to setup cron module.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.