Search in sources :

Example 1 with VerifyCaptcha

use of cz.metacentrum.perun.webgui.json.registrarManager.VerifyCaptcha in project perun by CESNET.

the class ApplicationFormGui method loadPerunPrincipal.

/**
	 * Performs a login into the RPC, loads user and his roles into session and enables GUI.
	 */
private void loadPerunPrincipal(final JsonCallbackEvents externalEvents) {
    // events after getting PerunPrincipal from RPC
    GetPerunPrincipal principal = new GetPerunPrincipal(new JsonCallbackEvents() {

        @Override
        public void onFinished(JavaScriptObject jso) {
            // store perun principal into session for future use
            PerunPrincipal pp = (PerunPrincipal) jso;
            session.setPerunPrincipal(pp);
            // store users roles and editable entities into session
            if (pp.getRoles().hasAnyRole()) {
                session.setRoles(pp.getRoles());
            }
            // proceed after GUI configuration is loaded
            GetGuiConfiguration getConf = new GetGuiConfiguration(new JsonCallbackEvents() {

                @Override
                public void onFinished(JavaScriptObject jso) {
                    // store configuration
                    session.setConfiguration((BasicOverlayType) jso.cast());
                    if (Utils.getVosToSkipCaptchaFor().contains(vo.getShortName())) {
                        // skip captcha
                        final GetApplicationsForUser request;
                        if (session.getUser() == null) {
                            // if not yet user in perun, search by actor / extSourceName
                            request = new GetApplicationsForUser(0, externalEvents);
                        } else {
                            // if user in perun
                            request = new GetApplicationsForUser(session.getUser().getId(), externalEvents);
                        }
                        request.retrieveData();
                        // finish loading GUI
                        loadingBox.hide();
                        bodySplitter.clear();
                        bodySplitter.add(ft);
                    // challange captcha only for default URL (non)
                    } else if (session.getRpcUrl().startsWith("/non/rpc")) {
                        if (Location.getParameterMap().keySet().contains("m") && Location.getParameterMap().keySet().contains("i")) {
                            // passed params doesn't matter, different UI is loaded.
                            final GetApplicationsForUser request;
                            if (session.getUser() == null) {
                                // if not yet user in perun, search by actor / extSourceName
                                request = new GetApplicationsForUser(0, externalEvents);
                            } else {
                                // if user in perun
                                request = new GetApplicationsForUser(session.getUser().getId(), externalEvents);
                            }
                            request.retrieveData();
                            // finish loading GUI
                            loadingBox.hide();
                            bodySplitter.clear();
                            bodySplitter.add(ft);
                        } else {
                            // CHALLENGE WITH CAPTCHA
                            FlexTable ft = new FlexTable();
                            ft.setSize("100%", "500px");
                            // captcha with public key
                            String key = Utils.getReCaptchaPublicKey();
                            if (key == null) {
                                PerunError error = new JSONObject().getJavaScriptObject().cast();
                                error.setErrorId("0");
                                error.setName("Missing public key");
                                error.setErrorInfo("Public key for Re-Captcha service is missing. Please add public key to GUIs configuration file.");
                                error.setRequestURL("");
                                UiElements.generateError(error, "Missing public key", "Public key for Re-Captcha service is missing.<br />Accessing application form without authorization is not possible.");
                                loadingBox.hide();
                                return;
                            }
                            final RecaptchaWidget captcha = new RecaptchaWidget(key, LocaleInfo.getCurrentLocale().getLocaleName(), "clean");
                            final CustomButton cb = new CustomButton();
                            cb.setIcon(SmallIcons.INSTANCE.arrowRightIcon());
                            cb.setText(ApplicationMessages.INSTANCE.captchaSendButton());
                            cb.setImageAlign(true);
                            final TextBox response = new TextBox();
                            captcha.setOwnTextBox(response);
                            Scheduler.get().scheduleDeferred(new Command() {

                                @Override
                                public void execute() {
                                    response.setFocus(true);
                                }
                            });
                            response.addKeyDownHandler(new KeyDownHandler() {

                                @Override
                                public void onKeyDown(KeyDownEvent event) {
                                    if (event.getNativeKeyCode() == KeyCodes.KEY_ENTER) {
                                        cb.click();
                                    }
                                }
                            });
                            cb.addClickHandler(new ClickHandler() {

                                @Override
                                public void onClick(ClickEvent clickEvent) {
                                    VerifyCaptcha req = new VerifyCaptcha(captcha.getChallenge(), captcha.getResponse(), JsonCallbackEvents.disableButtonEvents(cb, new JsonCallbackEvents() {

                                        public void onFinished(JavaScriptObject jso) {
                                            BasicOverlayType bt = jso.cast();
                                            if (bt.getBoolean()) {
                                                // OK captcha answer - load GUI
                                                // Authorized anonymous user
                                                session.getUiElements().setLogText("Auth OK");
                                                final GetApplicationsForUser request;
                                                if (session.getUser() == null) {
                                                    // if not yet user in perun, search by actor / extSourceName
                                                    request = new GetApplicationsForUser(0, externalEvents);
                                                } else {
                                                    // if user in perun
                                                    request = new GetApplicationsForUser(session.getUser().getId(), externalEvents);
                                                }
                                                request.retrieveData();
                                            } else {
                                                // wrong captcha answer
                                                UiElements.generateAlert(ApplicationMessages.INSTANCE.captchaErrorHeader(), ApplicationMessages.INSTANCE.captchaErrorMessage());
                                            }
                                        }
                                    }));
                                    req.retrieveData();
                                }
                            });
                            // set layout
                            int row = 0;
                            // display VO logo if present in attribute
                            for (int i = 0; i < vo.getAttributes().length(); i++) {
                                if (vo.getAttributes().get(i).getFriendlyName().equalsIgnoreCase("voLogoURL")) {
                                    ft.setWidget(row, 0, new Image(vo.getAttributes().get(i).getValue()));
                                    ft.getFlexCellFormatter().setAlignment(row, 0, HasHorizontalAlignment.ALIGN_CENTER, HasVerticalAlignment.ALIGN_MIDDLE);
                                    row++;
                                }
                            }
                            ft.getFlexCellFormatter().setAlignment(row, 0, HasHorizontalAlignment.ALIGN_CENTER, HasVerticalAlignment.ALIGN_MIDDLE);
                            ft.setHTML(row, 0, ApplicationMessages.INSTANCE.captchaDescription());
                            ft.setWidget(row + 1, 0, captcha);
                            ft.getFlexCellFormatter().setHorizontalAlignment(row + 1, 0, HasHorizontalAlignment.ALIGN_CENTER);
                            ft.getFlexCellFormatter().setVerticalAlignment(row + 1, 0, HasVerticalAlignment.ALIGN_BOTTOM);
                            FlexTable sendFt = new FlexTable();
                            sendFt.setStyleName("inputFormFlexTable");
                            sendFt.setWidget(0, 0, response);
                            sendFt.setWidget(0, 1, cb);
                            ft.setWidget(row + 2, 0, sendFt);
                            ft.getFlexCellFormatter().setHorizontalAlignment(row + 2, 0, HasHorizontalAlignment.ALIGN_CENTER);
                            ft.getFlexCellFormatter().setVerticalAlignment(row + 2, 0, HasVerticalAlignment.ALIGN_TOP);
                            ft.setHeight("100%");
                            ft.getFlexCellFormatter().setHeight(row, 0, "50%");
                            ft.getFlexCellFormatter().setHeight(row + 2, 0, "50%");
                            // finish loading GUI
                            loadingBox.hide();
                            bodySplitter.clear();
                            bodySplitter.add(ft);
                        }
                    } else {
                        // Authorized known user
                        session.getUiElements().setLogText("Auth OK");
                        final GetApplicationsForUser req;
                        if (session.getUser() == null) {
                            // if not yet user in perun, search by actor / extSourceName
                            req = new GetApplicationsForUser(0, externalEvents);
                        } else {
                            // if user in perun
                            req = new GetApplicationsForUser(session.getUser().getId(), externalEvents);
                        }
                        req.retrieveData();
                    }
                }
            });
            getConf.retrieveData();
        }
    });
    principal.retrieveData();
}
Also used : JsonCallbackEvents(cz.metacentrum.perun.webgui.json.JsonCallbackEvents) GetApplicationsForUser(cz.metacentrum.perun.webgui.json.registrarManager.GetApplicationsForUser) VerifyCaptcha(cz.metacentrum.perun.webgui.json.registrarManager.VerifyCaptcha) AjaxLoaderImage(cz.metacentrum.perun.webgui.widgets.AjaxLoaderImage) JSONObject(com.google.gwt.json.client.JSONObject) Command(com.google.gwt.user.client.Command) CustomButton(cz.metacentrum.perun.webgui.widgets.CustomButton) GetPerunPrincipal(cz.metacentrum.perun.webgui.json.authzResolver.GetPerunPrincipal) RecaptchaWidget(cz.metacentrum.perun.webgui.widgets.recaptcha.RecaptchaWidget) GetPerunPrincipal(cz.metacentrum.perun.webgui.json.authzResolver.GetPerunPrincipal) GetGuiConfiguration(cz.metacentrum.perun.webgui.json.GetGuiConfiguration)

Example 2 with VerifyCaptcha

use of cz.metacentrum.perun.webgui.json.registrarManager.VerifyCaptcha in project perun by CESNET.

the class PasswordResetGui method loadPerunPrincipal.

/**
	 * Performs a login into the RPC, loads user and his roles into session and enables GUI.
	 */
private void loadPerunPrincipal() {
    // show loading box
    final PopupPanel loadingBox = session.getUiElements().perunLoadingBox();
    loadingBox.show();
    // events after getting PerunPrincipal from RPC
    final JsonCallbackEvents events = new JsonCallbackEvents() {

        @Override
        public void onFinished(JavaScriptObject jso) {
            // store perun principal into session for future use
            PerunPrincipal pp = (PerunPrincipal) jso;
            session.setPerunPrincipal(pp);
            // check if user exists
            if (session.getUser() != null && !pp.getRoles().hasAnyRole() && !session.getRpcUrl().startsWith("/non/rpc")) {
                // if not and no role, redraw page body
                RootLayoutPanel body = RootLayoutPanel.get();
                loadingBox.hide();
                body.clear();
                body.add(new NotUserOfPerunWidget());
                return;
            }
            if (session.getUser() != null && !pp.getRoles().hasAnyRole()) {
                // store users roles and editable entities into session
                session.setRoles(pp.getRoles());
                // display logged user
                session.getUiElements().setLoggedUserInfo(pp);
            }
            GetGuiConfiguration getConf = new GetGuiConfiguration(new JsonCallbackEvents() {

                @Override
                public void onFinished(JavaScriptObject jso) {
                    session.setConfiguration((BasicOverlayType) jso.cast());
                    // hides the loading box
                    loadingBox.hide();
                    if (session.getRpcUrl().startsWith("/non/rpc")) {
                        // CHALLENGE WITH CAPTCHA
                        FlexTable ft = new FlexTable();
                        ft.setSize("100%", "500px");
                        // captcha with public key
                        String key = Utils.getReCaptchaPublicKey();
                        if (key == null) {
                            PerunError error = new JSONObject().getJavaScriptObject().cast();
                            error.setErrorId("0");
                            error.setName("Missing public key");
                            error.setErrorInfo("Public key for Re-Captcha service is missing. Please add public key to GUIs configuration file.");
                            error.setRequestURL("");
                            UiElements.generateError(error, "Missing public key", "Public key for Re-Captcha service is missing.<br />Accessing password reset without authorization is not possible.");
                            loadingBox.hide();
                            return;
                        }
                        final RecaptchaWidget captcha = new RecaptchaWidget(key, LocaleInfo.getCurrentLocale().getLocaleName(), "clean");
                        final CustomButton cb = new CustomButton();
                        cb.setIcon(SmallIcons.INSTANCE.arrowRightIcon());
                        cb.setText(ApplicationMessages.INSTANCE.captchaSendButton());
                        cb.setImageAlign(true);
                        final TextBox response = new TextBox();
                        captcha.setOwnTextBox(response);
                        Scheduler.get().scheduleDeferred(new Command() {

                            @Override
                            public void execute() {
                                response.setFocus(true);
                            }
                        });
                        response.addKeyDownHandler(new KeyDownHandler() {

                            @Override
                            public void onKeyDown(KeyDownEvent event) {
                                if (event.getNativeKeyCode() == KeyCodes.KEY_ENTER) {
                                    cb.click();
                                }
                            }
                        });
                        cb.addClickHandler(new ClickHandler() {

                            @Override
                            public void onClick(ClickEvent clickEvent) {
                                VerifyCaptcha req = new VerifyCaptcha(captcha.getChallenge(), captcha.getResponse(), JsonCallbackEvents.disableButtonEvents(cb, new JsonCallbackEvents() {

                                    public void onFinished(JavaScriptObject jso) {
                                        BasicOverlayType bt = jso.cast();
                                        if (bt.getBoolean()) {
                                            // OK captcha answer - load GUI
                                            // add menu item and load content
                                            contentPanel.setWidget(new PasswordResetFormPage().getContent());
                                        //Anchor a = leftMenu.addMenuContents("Password reset", SmallIcons.INSTANCE.keyIcon(), new PasswordResetFormPage().getContent());
                                        //a.fireEvent(new ClickEvent(){});
                                        } else {
                                            // wrong captcha answer
                                            UiElements.generateAlert(ApplicationMessages.INSTANCE.captchaErrorHeader(), ApplicationMessages.INSTANCE.captchaErrorMessage());
                                        }
                                    }
                                }));
                                req.retrieveData();
                            }
                        });
                        // set layout
                        int row = 0;
                        ft.getFlexCellFormatter().setAlignment(row, 0, HasHorizontalAlignment.ALIGN_CENTER, HasVerticalAlignment.ALIGN_MIDDLE);
                        ft.setHTML(row, 0, "<h2>In order to continue to the password reset page, please, use CAPTCHA below.</h2>");
                        ft.setWidget(row + 1, 0, captcha);
                        ft.getFlexCellFormatter().setHorizontalAlignment(row + 1, 0, HasHorizontalAlignment.ALIGN_CENTER);
                        ft.getFlexCellFormatter().setVerticalAlignment(row + 1, 0, HasVerticalAlignment.ALIGN_BOTTOM);
                        FlexTable sendFt = new FlexTable();
                        sendFt.setStyleName("inputFormFlexTable");
                        sendFt.setWidget(0, 0, response);
                        sendFt.setWidget(0, 1, cb);
                        ft.setWidget(row + 2, 0, sendFt);
                        ft.getFlexCellFormatter().setHorizontalAlignment(row + 2, 0, HasHorizontalAlignment.ALIGN_CENTER);
                        ft.getFlexCellFormatter().setVerticalAlignment(row + 2, 0, HasVerticalAlignment.ALIGN_TOP);
                        ft.setHeight("100%");
                        ft.getFlexCellFormatter().setHeight(row, 0, "50%");
                        ft.getFlexCellFormatter().setHeight(row + 2, 0, "50%");
                        // finish loading GUI
                        loadingBox.hide();
                        contentPanel.setWidget(ft);
                    } else {
                        // add menu item and load content
                        contentPanel.setWidget(new PasswordResetFormPage().getContent());
                    //Anchor a = leftMenu.addMenuContents("Password reset", SmallIcons.INSTANCE.keyIcon(), new PasswordResetFormPage().getContent());
                    //a.fireEvent(new ClickEvent(){});
                    }
                }

                @Override
                public void onError(PerunError error) {
                    // hides the loading box
                    loadingBox.hide();
                    // shows error box
                    PopupPanel loadingFailedBox;
                    if (error == null) {
                        loadingFailedBox = session.getUiElements().perunLoadingFailedBox("Request timeout exceeded.");
                    } else {
                        if (error.getName().contains("UserNotExistsException")) {
                            loadingFailedBox = session.getUiElements().perunLoadingFailedBox("You are not registered to any Virtual Organization.</br></br>" + error.getErrorInfo());
                        } else {
                            loadingFailedBox = session.getUiElements().perunLoadingFailedBox(error.getErrorInfo());
                        }
                    }
                    loadingFailedBox.show();
                    leftMenu.addItem("Password reset", SmallIcons.INSTANCE.keyIcon(), null);
                }
            });
            getConf.retrieveData();
        }

        @Override
        public void onError(PerunError error) {
            // hides the loading box
            loadingBox.hide();
            // shows error box
            PopupPanel loadingFailedBox;
            if (error == null) {
                loadingFailedBox = session.getUiElements().perunLoadingFailedBox("Request timeout exceeded.");
            } else {
                if (error.getName().contains("UserNotExistsException")) {
                    loadingFailedBox = session.getUiElements().perunLoadingFailedBox("You are not registered to any Virtual Organization.</br></br>" + error.getErrorInfo());
                } else {
                    loadingFailedBox = session.getUiElements().perunLoadingFailedBox(error.getErrorInfo());
                }
            }
            loadingFailedBox.show();
            leftMenu.addItem("Password reset", SmallIcons.INSTANCE.keyIcon(), null);
        }
    };
    GetPerunPrincipal loggedUserRequest = new GetPerunPrincipal(events);
    loggedUserRequest.retrieveData();
}
Also used : JsonCallbackEvents(cz.metacentrum.perun.webgui.json.JsonCallbackEvents) BasicOverlayType(cz.metacentrum.perun.webgui.model.BasicOverlayType) VerifyCaptcha(cz.metacentrum.perun.webgui.json.registrarManager.VerifyCaptcha) JSONObject(com.google.gwt.json.client.JSONObject) Command(com.google.gwt.user.client.Command) CustomButton(cz.metacentrum.perun.webgui.widgets.CustomButton) RecaptchaWidget(cz.metacentrum.perun.webgui.widgets.recaptcha.RecaptchaWidget) GetPerunPrincipal(cz.metacentrum.perun.webgui.json.authzResolver.GetPerunPrincipal) PerunPrincipal(cz.metacentrum.perun.webgui.model.PerunPrincipal) GetPerunPrincipal(cz.metacentrum.perun.webgui.json.authzResolver.GetPerunPrincipal) PerunError(cz.metacentrum.perun.webgui.model.PerunError) PasswordResetFormPage(cz.metacentrum.perun.webgui.client.passwordresetresources.PasswordResetFormPage) GetGuiConfiguration(cz.metacentrum.perun.webgui.json.GetGuiConfiguration)

Aggregations

JSONObject (com.google.gwt.json.client.JSONObject)2 Command (com.google.gwt.user.client.Command)2 GetGuiConfiguration (cz.metacentrum.perun.webgui.json.GetGuiConfiguration)2 JsonCallbackEvents (cz.metacentrum.perun.webgui.json.JsonCallbackEvents)2 GetPerunPrincipal (cz.metacentrum.perun.webgui.json.authzResolver.GetPerunPrincipal)2 VerifyCaptcha (cz.metacentrum.perun.webgui.json.registrarManager.VerifyCaptcha)2 CustomButton (cz.metacentrum.perun.webgui.widgets.CustomButton)2 RecaptchaWidget (cz.metacentrum.perun.webgui.widgets.recaptcha.RecaptchaWidget)2 PasswordResetFormPage (cz.metacentrum.perun.webgui.client.passwordresetresources.PasswordResetFormPage)1 GetApplicationsForUser (cz.metacentrum.perun.webgui.json.registrarManager.GetApplicationsForUser)1 BasicOverlayType (cz.metacentrum.perun.webgui.model.BasicOverlayType)1 PerunError (cz.metacentrum.perun.webgui.model.PerunError)1 PerunPrincipal (cz.metacentrum.perun.webgui.model.PerunPrincipal)1 AjaxLoaderImage (cz.metacentrum.perun.webgui.widgets.AjaxLoaderImage)1