28 require
'../main.inc.php';
29 require_once DOL_DOCUMENT_ROOT.
'/core/lib/admin.lib.php';
30 require_once DOL_DOCUMENT_ROOT.
'/core/lib/oauth.lib.php';
35 $urlwithouturlroot = preg_replace(
'/'.preg_quote(DOL_URL_ROOT,
'/').
'$/i',
'', trim($dolibarr_main_url_root));
36 $urlwithroot = $urlwithouturlroot.DOL_URL_ROOT;
40 $langs->loadLangs(array(
'admin',
'oauth',
'modulebuilder'));
47 $action =
GETPOST(
'action',
'aZ09');
48 $provider =
GETPOST(
'provider',
'aZ09');
49 $label =
GETPOST(
'label',
'aZ09');
58 if ($action ==
'add') {
59 if ($provider && $provider !=
'-1') {
60 $constname = strtoupper($provider).($label ?
'-'.$label :
'').
'_ID';
63 setEventMessages($langs->trans(
"AOAuthEntryForThisProviderAndLabelAlreadyHasAKey"),
null,
'errors');
66 dolibarr_set_const($db, $constname, $langs->trans(
'ToComplete'),
'chaine', 0,
'', $conf->entity);
71 if ($action ==
'update') {
72 foreach ($conf->global as $key => $val) {
73 if (!empty($val) && preg_match(
'/^OAUTH_.+_ID$/', $key)) {
74 $constvalue = str_replace(
'_ID',
'', $key);
83 if (!
dolibarr_set_const($db, $constvalue.
'_URLAUTHORIZE',
GETPOST($constvalue.
'_URLAUTHORIZE'),
'chaine', 0,
'', $conf->entity)) {
93 if (is_array(
GETPOST($constvalue.
'_SCOPE'))) {
94 $scopestring = implode(
',',
GETPOST($constvalue.
'_SCOPE'));
96 $scopestring =
GETPOST($constvalue.
'_SCOPE');
98 if (!
dolibarr_set_const($db, $constvalue.
'_SCOPE', $scopestring,
'chaine', 0,
'', $conf->entity)) {
102 if (!
dolibarr_set_const($db, $constvalue.
'_SCOPE',
'',
'chaine', 0,
'', $conf->entity)) {
117 if ($action ==
'confirm_delete') {
118 $provider =
GETPOST(
'provider',
'aZ09');
121 $globalkey = empty($provider) ? $label : $label.
'-'.$provider;
124 $backtourl = DOL_URL_ROOT.
'/admin/oauth.php?action=delete_entry&provider='.$provider.
'&label='.$label.
'&token='.
newToken();
125 $urlwithouturlroot = preg_replace(
'/'.preg_quote(DOL_URL_ROOT,
'/').
'$/i',
'', trim($dolibarr_main_url_root));
126 $urlwithroot = $urlwithouturlroot.DOL_URL_ROOT;
127 $callbacktodel = $urlwithroot;
128 if ($label ==
'OAUTH_GOOGLE') {
129 $callbacktodel .=
'/core/modules/oauth/google_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
130 } elseif ($label ==
'OAUTH_GITHUB') {
131 $callbacktodel .=
'/core/modules/oauth/github_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
132 } elseif ($label ==
'OAUTH_STRIPE_LIVE') {
133 $callbacktodel .=
'/core/modules/oauth/stripelive_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
134 } elseif ($label ==
'OAUTH_STRIPE_TEST') {
135 $callbacktodel .=
'/core/modules/oauth/stripetest_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
136 } elseif ($label ==
'OAUTH_MICROSOFT') {
137 $callbacktodel .=
'/core/modules/oauth/microsoft_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
138 } elseif ($label ==
'OAUTH_OTHER') {
139 $callbacktodel .=
'/core/modules/oauth/generic_oauthcallback.php?action=delete&keyforprovider='.$provider.
'&token='.
newToken().
'&backtourl='.urlencode($backtourl);
141 header(
"Location: ".$callbacktodel);
144 $action =
'delete_entry';
148 if ($action ==
'delete_entry') {
149 $provider =
GETPOST(
'provider',
'aZ09');
152 $globalkey = empty($provider) ? $label : $label.
'-'.$provider;
154 if (!
dolibarr_del_const($db, $globalkey.
'_NAME', $conf->entity) || !
dolibarr_del_const($db, $globalkey.
'_ID', $conf->entity) || !
dolibarr_del_const($db, $globalkey.
'_SECRET', $conf->entity) || !
dolibarr_del_const($db, $globalkey.
'_URLAUTHORIZE', $conf->entity) || !
dolibarr_del_const($db, $globalkey.
'_SCOPE', $conf->entity)) {
170 if ($action ==
'delete') {
171 $formquestion = array();
172 $formconfirm =
$form->formconfirm($_SERVER[
"PHP_SELF"].
'?provider='.
GETPOST(
'provider').
'&label='.
GETPOST(
'label'), $langs->trans(
'OAuthServiceConfirmDeleteTitle'), $langs->trans(
'OAuthServiceConfirmDeleteMessage'),
'confirm_delete', $formquestion, 0, 1, 220);
177 $linkback =
'<a href="'.DOL_URL_ROOT.
'/admin/modules.php?restore_lastsearch_values=1">'.$langs->trans(
"BackToModuleList").
'</a>';
178 print
load_fiche_titre($langs->trans(
'ConfigOAuth'), $linkback,
'title_setup');
180 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'" method="POST">';
181 print
'<input type="hidden" name="token" value="'.newToken().
'">';
182 print
'<input type="hidden" name="action" value="add">';
189 print
'<span class="opacitymedium">'.$langs->trans(
"ListOfSupportedOauthProviders").
'</span><br><br>';
192 print
'<select name="provider" id="provider" class="minwidth150">';
193 print
'<option name="-1" value="-1">'.$langs->trans(
"OAuthProvider").
'</option>';
194 foreach ($list as $key) {
196 $keyforsupportedoauth2array = $key[0];
198 if (in_array($keyforsupportedoauth2array, array_keys($supportedoauth2array))) {
206 print
'<option name="'.$keyforsupportedoauth2array.
'" value="'.str_replace(
'_NAME',
'', $keyforsupportedoauth2array).
'">'.$supportedoauth2array[$keyforsupportedoauth2array][
'name'].
'</option>'.
"\n";
210 print
' <input type="text" name="label" value="" placeholder="'.$langs->trans(
"Label").
'" pattern="^\S+$" title="'.$langs->trans(
"SpaceOrSpecialCharAreNotAllowed").
'">';
211 print
' <input type="submit" class="button small" name="add" value="'.$langs->trans(
"Add").
'">';
222 foreach ($conf->global as $key => $val) {
223 if (!empty($val) && preg_match(
'/^OAUTH_.*_ID$/', $key)) {
224 $provider = preg_replace(
'/_ID$/',
'', $key);
225 $listinsetup[] = array(
229 $provider.
'_URLAUTHORIZE',
236 if (count($listinsetup) > 0) {
237 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'" method="POST">';
238 print
'<input type="hidden" name="token" value="'.newToken().
'">';
239 print
'<input type="hidden" name="action" value="update">';
241 print
'<div class="div-table-responsive-no-min">';
246 foreach ($listinsetup as $key) {
248 $keyforsupportedoauth2array = $key[0];
249 $keyforsupportedoauth2array = preg_replace(
'/^OAUTH_/',
'', $keyforsupportedoauth2array);
250 $keyforsupportedoauth2array = preg_replace(
'/_NAME$/',
'', $keyforsupportedoauth2array);
251 if (preg_match(
'/^.*-/', $keyforsupportedoauth2array)) {
252 $keybeforeprovider = preg_replace(
'/-.*$/',
'', $keyforsupportedoauth2array);
253 $keyforprovider = preg_replace(
'/^.*-/',
'', $keyforsupportedoauth2array);
255 $keybeforeprovider = $keyforsupportedoauth2array;
256 $keyforprovider =
'';
258 $keyforsupportedoauth2array = preg_replace(
'/-.*$/',
'', $keyforsupportedoauth2array);
259 $keyforsupportedoauth2array =
'OAUTH_'.$keyforsupportedoauth2array.
'_NAME';
261 if (in_array($keyforsupportedoauth2array, array_keys($supportedoauth2array))) {
270 print
'<table class="noborder centpercent">';
273 $label = $langs->trans($keyforsupportedoauth2array);
274 print
'<tr class="liste_titre'.($i > 1 ?
' liste_titre_add' :
'').
'">';
275 print
'<td class="titlefieldcreate">';
276 print
img_picto(
'', $supportedoauth2array[$keyforsupportedoauth2array][
'picto'],
'class="pictofixedwidth"');
277 if ($label == $keyforsupportedoauth2array) {
278 print $supportedoauth2array[$keyforsupportedoauth2array][
'name'];
282 if ($keyforprovider) {
283 print
' (<b>'.$keyforprovider.
'</b>)';
285 print
' (<b>'.$langs->trans(
"NoName").
'</b>)';
289 if (!empty($supportedoauth2array[$keyforsupportedoauth2array][
'urlforcredentials'])) {
290 print $langs->trans(
"OAUTH_URL_FOR_CREDENTIAL", $supportedoauth2array[$keyforsupportedoauth2array][
'urlforcredentials']);
296 $label = preg_replace(
'/_NAME$/',
'', $keyforsupportedoauth2array);
297 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?action=delete&token='.
newToken().
'&provider='.urlencode($keyforprovider).
'&label='.urlencode($label).
'">';
307 $redirect_uri = $urlwithroot.
'/core/modules/oauth/'.$supportedoauth2array[$keyforsupportedoauth2array][
'callbackfile'].
'_oauthcallback.php';
308 print
'<tr class="oddeven value">';
309 print
'<td>'.$langs->trans(
"UseTheFollowingUrlAsRedirectURI").
'</td>';
310 print
'<td><input style="width: 80%" type="text" name="uri'.$keyforsupportedoauth2array.
'" id="uri'.$keyforsupportedoauth2array.$keyforprovider.
'" value="'.$redirect_uri.
'" disabled>';
311 print
ajax_autoselect(
'uri'.$keyforsupportedoauth2array.$keyforprovider);
316 if ($keyforsupportedoauth2array ==
'OAUTH_OTHER_NAME') {
317 print
'<tr class="oddeven value">';
318 print
'<td>'.$langs->trans(
"URLOfServiceForAuthorization").
'</td>';
319 print
'<td><input style="width: 80%" type="text" name="'.$key[3].
'" value="'.
getDolGlobalString($key[3]).
'" >';
325 print
'<tr class="oddeven value">';
326 print
'<td>'.$langs->trans(
"UseTheFollowingUrlAsRedirectURI").
'</td>';
327 print
'<td>'.$langs->trans(
"FeatureNotYetSupported").
'</td>';
334 print
'<tr class="oddeven value">';
335 print
'<td><label for="'.$key[1].
'">'.$langs->trans(
"OAUTH_ID").
'</label></td>';
336 print
'<td><input type="text" size="100" id="'.$key[1].
'" name="'.$key[1].
'" value="'.
getDolGlobalString($key[1]).
'">';
342 print
'<tr class="oddeven value">';
343 print
'<td><label for="'.$key[2].
'">'.$langs->trans(
"OAUTH_SECRET").
'</label></td>';
344 print
'<td><input type="password" size="100" id="'.$key[2].
'" name="'.$key[2].
'" value="'.
getDolGlobalString($key[2]).
'">';
350 if ($keybeforeprovider ==
'MICROSOFT') {
351 print
'<tr class="oddeven value">';
352 print
'<td><label for="'.$key[2].
'">'.$langs->trans(
"OAUTH_TENANT").
'</label></td>';
353 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').
'">';
361 if ($keyforsupportedoauth2array ==
'OAUTH_OTHER_NAME') {
362 print
'<tr class="oddeven value">';
363 print
'<td>'.$langs->trans(
"Scopes").
'</td>';
365 print
'<input style="width: 80%" type"text" name="'.$key[4].
'" value="'.
getDolGlobalString($key[4]).
'" >';
370 $availablescopes = array_flip(explode(
',', $supportedoauth2array[$keyforsupportedoauth2array][
'availablescopes']));
372 $scopestodispay = array();
373 foreach ($availablescopes as $keyscope => $valscope) {
374 if (in_array($keyscope, $currentscopes)) {
375 $scopestodispay[$keyscope] = 1;
377 $scopestodispay[$keyscope] = 0;
381 print
'<tr class="oddeven value">';
382 print
'<td>'.$langs->trans(
"Scopes").
'</td>';
384 foreach ($scopestodispay as $scope => $val) {
385 print
'<input type="checkbox" id="'.$keyforprovider.$scope.
'" name="'.$key[4].
'[]" value="'.$scope.
'"'.($val ?
' checked' :
'').
'>';
386 print
'<label style="margin-right: 10px" for="'.$keyforprovider.$scope.
'">'.$scope.
'</label>';
393 print
'<tr class="oddeven value">';
394 print
'<td>'.$langs->trans(
"UseTheFollowingUrlAsRedirectURI").
'</td>';
395 print
'<td>'.$langs->trans(
"FeatureNotYetSupported").
'</td>';
401 print
'</table>'.
"\n";
408 print
$form->buttonsSaveCancel(
"Save",
'');
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.
if(!defined('NOREQUIRESOC')) if(!defined('NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) llxHeader()
Empty header.
if($cancel &&! $id) if($action=='add' &&! $cancel) if($action=='delete') if($id) $form
Actions.
load_fiche_titre($titre, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='')
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='')
Set event messages in dol_events session object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
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.
if(!function_exists('utf8_encode')) if(!function_exists('utf8_decode')) getDolGlobalString($key, $default='')
Return dolibarr global constant string value.
GETPOSTISSET($paramname)
Return true if we are in a context of submitting the parameter $paramname from a POST of a form.
$formconfirm
if ($action == 'delbookkeepingyear') {
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.