Search in sources :

Example 1 with OAuthSPI

use of org.olat.login.oauth.OAuthSPI in project OpenOLAT by OpenOLAT.

the class AddOpenIDConnectIFFullConfigurableController method validateFormLogic.

@Override
protected boolean validateFormLogic(UserRequest ureq) {
    boolean allOk = true;
    allOk &= validate(openIdConnectIFName);
    List<ValidationStatus> nameValidation = new ArrayList<ValidationStatus>();
    openIdConnectIFName.validate(nameValidation);
    allOk &= nameValidation.isEmpty();
    allOk &= validate(openIdConnectIFDisplayName);
    allOk &= validate(openIdConnectIFApiKeyEl);
    allOk &= validate(openIdConnectIFApiSecretEl);
    allOk &= validate(openIdConnectIFIssuerEl);
    allOk &= validate(openIdConnectIFAuthorizationEndPointEl);
    String providerName = openIdConnectIFName.getValue();
    if (StringHelper.containsNonWhitespace(providerName)) {
        OAuthSPI existingSpi = oauthModule.getProvider(providerName);
        if (existingSpi != null) {
            openIdConnectIFName.setErrorKey("error.duplicate.provider", null);
            allOk &= false;
        }
    }
    return allOk & super.validateFormLogic(ureq);
}
Also used : ValidationStatus(org.olat.core.util.ValidationStatus) ArrayList(java.util.ArrayList) OAuthSPI(org.olat.login.oauth.OAuthSPI)

Example 2 with OAuthSPI

use of org.olat.login.oauth.OAuthSPI in project OpenOLAT by OpenOLAT.

the class OAuthAdminController method doConfirmDelete.

private void doConfirmDelete(UserRequest ureq, ConfigurableProviderWrapper providerWrapper) {
    OAuthSPI spi = providerWrapper.getSpi();
    String title = translate("confirm.delete.provider.title", new String[] { spi.getProviderName() });
    String text = translate("confirm.delete.provider.text", new String[] { spi.getProviderName() });
    confirmDeleteCtrl = activateOkCancelDialog(ureq, title, text, confirmDeleteCtrl);
    confirmDeleteCtrl.setUserObject(providerWrapper);
}
Also used : OAuthSPI(org.olat.login.oauth.OAuthSPI)

Example 3 with OAuthSPI

use of org.olat.login.oauth.OAuthSPI in project OpenOLAT by OpenOLAT.

the class OAuthAdminController method initCustomProviders.

private void initCustomProviders() {
    // remove old ones
    for (ConfigurableProviderWrapper providerWrapper : providerWrappers) {
        FormItemContainer layoutCont = providerWrapper.getLayoutCont();
        customProvidersCont.remove(layoutCont);
    }
    providerWrappers.clear();
    List<OAuthSPI> configurableSpies = oauthModule.getAllConfigurableSPIs();
    for (OAuthSPI configurableSpi : configurableSpies) {
        if (configurableSpi instanceof OpenIdConnectFullConfigurableProvider) {
            ConfigurableProviderWrapper wrapper = initOpenIDConnectIFFullConfigurableProviders(customProvidersCont, (OpenIdConnectFullConfigurableProvider) configurableSpi);
            if (wrapper != null) {
                providerWrappers.add(wrapper);
            }
        }
    }
}
Also used : OpenIdConnectFullConfigurableProvider(org.olat.login.oauth.spi.OpenIdConnectFullConfigurableProvider) OAuthSPI(org.olat.login.oauth.OAuthSPI) FormItemContainer(org.olat.core.gui.components.form.flexible.FormItemContainer)

Example 4 with OAuthSPI

use of org.olat.login.oauth.OAuthSPI in project OpenOLAT by OpenOLAT.

the class OAuthAuthenticationController method formInnerEvent.

@Override
protected void formInnerEvent(UserRequest ureq, FormItem source, FormEvent event) {
    if (source instanceof FormLink) {
        FormLink button = (FormLink) source;
        if ("login".equals(button.getCmd())) {
            OAuthSPI provider = (OAuthSPI) source.getUserObject();
            redirect(ureq, provider);
        }
    }
    super.formInnerEvent(ureq, source, event);
}
Also used : OAuthSPI(org.olat.login.oauth.OAuthSPI) FormLink(org.olat.core.gui.components.form.flexible.elements.FormLink)

Example 5 with OAuthSPI

use of org.olat.login.oauth.OAuthSPI in project openolat by klemens.

the class DMZDispatcher method execute.

/**
 * Main method called by OpenOLATServlet. This processess all requests for
 * users who are not authenticated.
 *
 * @param request
 * @param response
 * @param uriPrefix
 */
@Override
public void execute(HttpServletRequest request, HttpServletResponse response) {
    if (rejectRequest(request, response)) {
        return;
    }
    UserRequest ureq = null;
    String uriPrefix = DispatcherModule.getLegacyUriPrefix(request);
    try {
        // upon creation URL is checked for
        ureq = new UserRequestImpl(uriPrefix, request, response);
    } catch (NumberFormatException nfe) {
        // a 404 message must be shown -> e.g. robots correct their links.
        if (log.isDebug()) {
            log.debug("Bad Request " + request.getPathInfo());
        }
        DispatcherModule.sendBadRequest(request.getPathInfo(), response);
        return;
    }
    try {
        // find out about which subdispatcher is meant
        // e.g. got here because of /dmz/...
        // maybe something like /dmz/registration/
        // 
        // add the context path to align with uriPrefix e.g. /olat/dmz/
        String pathInfo = request.getContextPath() + request.getPathInfo();
        ChiefControllerCreator subPathccc = null;
        // if /olat/dmz/
        boolean dmzOnly = pathInfo.equals(uriPrefix);
        if (!dmzOnly) {
            int sl = pathInfo.indexOf('/', uriPrefix.length());
            String sub;
            if (sl > 1) {
                // e.g. something like /registration/ or /pwchange/
                sub = pathInfo.substring(uriPrefix.length() - 1, sl + 1);
            } else {
                // e.g. something like /info.html from (/dmz/info.html)
                sub = pathInfo;
            }
            // chief controller creator for sub path, e.g.
            subPathccc = dmzServicesByPath.get(sub);
            if (subPathccc != null) {
                UserSession usess = ureq.getUserSession();
                Windows ws = Windows.getWindows(usess);
                synchronized (ws) {
                    // o_clusterOK by:fj per user session
                    ChiefController occ = subPathccc.createChiefController(ureq);
                    Window window = occ.getWindow();
                    window.setUriPrefix(uriPrefix);
                    ws.registerWindow(window);
                    window.dispatchRequest(ureq, true);
                    return;
                }
            }
        }
        // else a /olat/dmz/ request
        UserSession usess = ureq.getUserSession();
        Windows ws = Windows.getWindows(usess);
        // and make it useless under heavily load or 2 concurrent requests
        synchronized (usess) {
            // o_clusterOK by:fj per user session
            Window window;
            boolean windowHere = ws.isExisting(uriPrefix, ureq.getWindowID());
            boolean validDispatchUri = ureq.isValidDispatchURI();
            if (validDispatchUri && !windowHere) {
                // probably valid framework link from previous user && new Session(no window):
                // when a previous user logged off, and 30min later (when the httpsession is invalidated), the next user clicks e.g. on
                // the log-in link in the -same- browser window ->
                // -> there is no window -> create a new one
                window = null;
                CoreSpringFactory.getImpl(UserSessionManager.class).signOffAndClear(usess);
                usess.setLocale(LocaleNegotiator.getPreferedLocale(ureq));
                // update locale infos
                I18nManager.updateLocaleInfoToThread(usess);
                // request new windows since it is a new usersession, the old one was purged
                ws = Windows.getWindows(usess);
            } else if (validDispatchUri) {
                window = ws.getWindow(ureq);
            } else if (dmzOnly) {
                // e.g. /dmz/ -> start screen, clear previous session data
                window = null;
                CoreSpringFactory.getImpl(UserSessionManager.class).signOffAndClear(usess);
                usess.setLocale(LocaleNegotiator.getPreferedLocale(ureq));
                // update locale infos
                I18nManager.updateLocaleInfoToThread(usess);
                OAuthLoginModule oauthModule = CoreSpringFactory.getImpl(OAuthLoginModule.class);
                if (canRedirectConfigurableOAuth(request, response, oauthModule)) {
                    return;
                } else if (canRedirectOAuth(request, oauthModule)) {
                    OAuthSPI oauthSpi = oauthModule.getRootProvider();
                    HttpSession session = request.getSession();
                    OAuthResource.redirect(oauthSpi, response, session);
                    return;
                }
                // request new windows since it is a new usersession, the old one was purged
                ws = Windows.getWindows(usess);
            } else {
                response.sendError(HttpServletResponse.SC_BAD_REQUEST);
                return;
            }
            if (window == null) {
                // no window found, -> start a new WorkFlow/Controller and obtain the window
                // main controller which also implements the windowcontroller for pagestatus and modal dialogs
                Object wSettings = usess.getEntry(WINDOW_SETTINGS);
                ChiefController occ = chiefControllerCreator.createChiefController(ureq);
                window = occ.getWindow();
                window.setUriPrefix(uriPrefix);
                ws.registerWindow(window);
                String businessPath = (String) usess.removeEntryFromNonClearedStore(DMZDISPATCHER_BUSINESSPATH);
                if (businessPath != null) {
                    List<ContextEntry> ces = BusinessControlFactory.getInstance().createCEListFromString(businessPath);
                    window.getDTabs().activate(ureq, null, ces);
                }
                // apply the settings forward
                usess.putEntryInNonClearedStore(WINDOW_SETTINGS, wSettings);
            }
            window.dispatchRequest(ureq);
        }
    } catch (InvalidRequestParameterException e) {
        try {
            response.sendError(HttpServletResponse.SC_BAD_REQUEST);
        } catch (IOException e1) {
            log.error("An exception occured while handling the invalid request parameter exception...", e1);
        }
    } catch (Throwable th) {
        try {
            ChiefController msgcc = MsgFactory.createMessageChiefController(ureq, th);
            // the controller's window must be failsafe also
            msgcc.getWindow().dispatchRequest(ureq, true);
        // do not dispatch (render only), since this is a new Window created as
        // a result of another window's click.
        } catch (Throwable t) {
            log.error("An exception occured while handling the exception...", t);
        }
    }
}
Also used : Window(org.olat.core.gui.components.Window) OAuthLoginModule(org.olat.login.oauth.OAuthLoginModule) HttpSession(javax.servlet.http.HttpSession) Windows(org.olat.core.gui.Windows) ChiefController(org.olat.core.gui.control.ChiefController) IOException(java.io.IOException) ContextEntry(org.olat.core.id.context.ContextEntry) UserSessionManager(org.olat.core.util.session.UserSessionManager) InvalidRequestParameterException(org.olat.core.gui.components.form.flexible.impl.InvalidRequestParameterException) ChiefControllerCreator(org.olat.core.gui.control.ChiefControllerCreator) UserSession(org.olat.core.util.UserSession) OAuthSPI(org.olat.login.oauth.OAuthSPI) UserRequest(org.olat.core.gui.UserRequest) UserRequestImpl(org.olat.core.gui.UserRequestImpl)

Aggregations

OAuthSPI (org.olat.login.oauth.OAuthSPI)16 HttpSession (javax.servlet.http.HttpSession)4 FormLink (org.olat.core.gui.components.form.flexible.elements.FormLink)4 OpenIdConnectFullConfigurableProvider (org.olat.login.oauth.spi.OpenIdConnectFullConfigurableProvider)4 IOException (java.io.IOException)2 ArrayList (java.util.ArrayList)2 UserRequest (org.olat.core.gui.UserRequest)2 UserRequestImpl (org.olat.core.gui.UserRequestImpl)2 Windows (org.olat.core.gui.Windows)2 Window (org.olat.core.gui.components.Window)2 FormItemContainer (org.olat.core.gui.components.form.flexible.FormItemContainer)2 InvalidRequestParameterException (org.olat.core.gui.components.form.flexible.impl.InvalidRequestParameterException)2 ChiefController (org.olat.core.gui.control.ChiefController)2 ChiefControllerCreator (org.olat.core.gui.control.ChiefControllerCreator)2 ContextEntry (org.olat.core.id.context.ContextEntry)2 UserSession (org.olat.core.util.UserSession)2 ValidationStatus (org.olat.core.util.ValidationStatus)2 UserSessionManager (org.olat.core.util.session.UserSessionManager)2 OAuthDisplayName (org.olat.login.oauth.OAuthDisplayName)2 OAuthLoginModule (org.olat.login.oauth.OAuthLoginModule)2