use of cz.metacentrum.perun.webgui.widgets.recaptcha.RecaptchaWidget 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();
}
use of cz.metacentrum.perun.webgui.widgets.recaptcha.RecaptchaWidget 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();
}
Aggregations