* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ /** * \file htdocs/admin/openid_connect.php * \ingroup openid_connect * \brief Page to setup openid_connect module */ // Load Dolibarr environment require '../main.inc.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/openid_connect.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/class/html.form.class.php'; dol_include_once('/core/lib/openid_connect.lib.php'); $langs->load("admin"); $langs->load("openidconnect"); if (!$user->admin) accessforbidden(); $action = GETPOST('action', 'alpha'); /* * Actions */ $errors = []; $error = 0; if ($action == 'set') { $client_id = GETPOST('MAIN_AUTHENTICATION_OIDC_LOGIN_CLAIM', 'alpha'); $res = dolibarr_set_const($db, 'MAIN_AUTHENTICATION_OIDC_LOGIN_CLAIM', $client_id, 'chaine', 0, '', 0); if (!$res > 0) { $errors[] = $db->lasterror(); $error++; } $client_id = GETPOST('MAIN_AUTHENTICATION_OIDC_CLIENT_ID', 'alpha'); $res = dolibarr_set_const($db, 'MAIN_AUTHENTICATION_OIDC_CLIENT_ID', $client_id, 'chaine', 0, '', 0); if (!$res > 0) { $errors[] = $db->lasterror(); $error++; } $client_secret = GETPOST('MAIN_AUTHENTICATION_OIDC_CLIENT_SECRET', 'alpha'); $res = dolibarr_set_const($db, 'MAIN_AUTHENTICATION_OIDC_CLIENT_SECRET', $client_secret, 'chaine', 0, '', 0); if (!$res > 0) { $errors[] = $db->lasterror(); $error++; } $scopes = GETPOST('MAIN_AUTHENTICATION_OIDC_SCOPES', 'alpha'); $res = dolibarr_set_const($db, 'MAIN_AUTHENTICATION_OIDC_SCOPES', $scopes, 'chaine', 0, '', 0); if (!$res > 0) { $errors[] = $db->lasterror(); $error++; } $authorize_url = GETPOST('MAIN_AUTHENTICATION_OIDC_AUTHORIZE_URL', 'alpha'); $res = dolibarr_set_const($db, 'MAIN_AUTHENTICATION_OIDC_AUTHORIZE_URL', $authorize_url, 'chaine', 0, '', 0); if (!$res > 0) { $errors[] = $db->lasterror(); $error++; } $value = GETPOST('MAIN_AUTHENTICATION_OIDC_TOKEN_URL', 'alpha'); $res = dolibarr_set_const($db, 'MAIN_AUTHENTICATION_OIDC_TOKEN_URL', $value, 'chaine', 0, '', 0); if (!$res > 0) { $errors[] = $db->lasterror(); $error++; } $value = GETPOST('MAIN_AUTHENTICATION_OIDC_USERINFO_URL', 'alpha'); $res = dolibarr_set_const($db, 'MAIN_AUTHENTICATION_OIDC_USERINFO_URL', $value, 'chaine', 0, '', 0); if (!$res > 0) { $errors[] = $db->lasterror(); $error++; } $logout_url = GETPOST('MAIN_AUTHENTICATION_OIDC_LOGOUT_URL', 'alpha'); $res = dolibarr_set_const($db, 'MAIN_AUTHENTICATION_OIDC_LOGOUT_URL', $logout_url, 'chaine', 0, '', 0); if (!$res > 0) { $errors[] = $db->lasterror(); $error++; } } if ($action != '') { if (!$error) { setEventMessage($langs->trans("SetupSaved")); header("Location: " . $_SERVER["PHP_SELF"]); exit; } else { setEventMessages('', $errors, 'errors'); } } /* * View */ $form = new Form($db); llxHeader(); $linkback=''.$langs->trans("BackToModuleList").''; print load_fiche_titre($langs->trans("OpenIDconnectSetup"), $linkback, 'title_setup'); print "
\n"; $head = openid_connect_prepare_head(); print dol_get_fiche_head($head, 'settings', $langs->trans("Parameters"), 0, 'action'); print '
'; print '
'; print ''; print ''; $var=true; print ''; print ''; print ''."\n"; print ''."\n"; print ''."\n"; print "\n"; // MAIN_AUTHENTICATION_OIDC_LOGIN_CLAIM $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // MAIN_AUTHENTICATION_OIDC_CLIENT_ID $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // MAIN_AUTHENTICATION_OIDC_CLIENT_SECRET $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // MAIN_AUTHENTICATION_OIDC_SCOPES $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // MAIN_AUTHENTICATION_OIDC_AUTHORIZE_URL $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // MAIN_AUTHENTICATION_OIDC_TOKEN_URL $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // MAIN_AUTHENTICATION_OIDC_USERINFO_URL $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // MAIN_AUTHENTICATION_OIDC_LOGOUT_URL $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // REDIRECT_URL $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; // LOGOUT_URL $var = !$var; print '' . "\n"; print ''."\n"; print ''."\n"; print ''; print '' . "\n"; print '
'.$langs->trans("Parameters").' '.$langs->trans("Value").'
'.$langs->trans("MainAuthenticationOidcLoginClaimName").''.$langs->trans("MainAuthenticationOidcLoginClaimDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcClientIdName").''.$langs->trans("MainAuthenticationOidcClientIdDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcClientSecretName").''.$langs->trans("MainAuthenticationOidcClientSecretDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcScopesName").''.$langs->trans("MainAuthenticationOidcScopesDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcAuthorizeUrlName").''.$langs->trans("MainAuthenticationOidcAuthorizeUrlDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcTokenUrlName").''.$langs->trans("MainAuthenticationOidcTokenUrlDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcUserinfoUrlName").''.$langs->trans("MainAuthenticationOidcUserinfoUrlDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcLogoutUrlName").''.$langs->trans("MainAuthenticationOidcLogoutUrlDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcRedirectUrlName").''.$langs->trans("MainAuthenticationOidcRedirectUrlDesc").'' . "\n"; print '
'.$langs->trans("MainAuthenticationOidcLogoutRedirectUrlName").''.$langs->trans("MainAuthenticationOidcLogoutRedirectUrlDesc").'' . "\n"; print '
'."\n"; print '
'; print '
'; print ''; print '
'; print '
'; print '
'; print dol_get_fiche_end(); llxFooter();