Java tutorial
/* * Copyright 2015 The original authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.freakz.hokan_ng_springboot.bot; import com.vaadin.annotations.Push; import com.vaadin.annotations.Theme; import com.vaadin.server.DefaultErrorHandler; import com.vaadin.server.VaadinRequest; import com.vaadin.spring.annotation.SpringUI; import com.vaadin.ui.Notification; import com.vaadin.ui.UI; import com.vaadin.ui.themes.ValoTheme; import lombok.extern.slf4j.Slf4j; import org.freakz.hokan_ng_springboot.bot.service.UiServiceMessageHandlerImpl; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.ApplicationContext; import org.vaadin.spring.events.EventBus; import org.vaadin.spring.events.annotation.EventBusListenerMethod; import org.vaadin.spring.security.VaadinSecurity; import org.vaadin.spring.security.util.SecurityExceptionUtils; import org.vaadin.spring.security.util.SuccessfulLoginEvent; /** * Main application UI that shows either the {@link MainScreen} or the {@link LoginScreen}, * depending on whether there is an authenticated user or not. Also note that the UI is using web socket based push. * * @author Petter Holmstrm (petter@vaadin.com) */ @Push @Slf4j @SpringUI @Theme(ValoTheme.THEME_NAME) public class SingleSecuredUI extends UI implements UiServiceMessageHandlerImpl.BroadcastListener { @Autowired ApplicationContext applicationContext; @Autowired VaadinSecurity vaadinSecurity; @Autowired EventBus.SessionEventBus eventBus; @Autowired UiServiceMessageHandlerImpl uiServiceMessageHandler; @Override protected void init(VaadinRequest request) { uiServiceMessageHandler.register(this); getPage().setTitle("Hokan"); // Let's register a custom error handler to make the 'access denied' messages a bit friendlier. setErrorHandler(new DefaultErrorHandler() { @Override public void error(com.vaadin.server.ErrorEvent event) { if (SecurityExceptionUtils.isAccessDeniedException(event.getThrowable())) { Notification.show("Sorry, you don't have access to do that."); } else { super.error(event); } } }); if (vaadinSecurity.isAuthenticated()) { showMainScreen(); } else { showLoginScreen(request.getParameter("goodbye") != null); } } @Override public void attach() { super.attach(); eventBus.subscribe(this); } @Override public void detach() { eventBus.unsubscribe(this); uiServiceMessageHandler.unregister(this); super.detach(); } private void showLoginScreen(boolean loggedOut) { LoginScreen loginScreen = applicationContext.getBean(LoginScreen.class); loginScreen.setLoggedOut(loggedOut); setContent(loginScreen); } private void showMainScreen() { setContent(applicationContext.getBean(MainScreen.class)); } @EventBusListenerMethod void onLogin(SuccessfulLoginEvent loginEvent) { if (loginEvent.getSource().equals(this)) { access(() -> showMainScreen()); } else { // We cannot inject the Main Screen if the event was fired from another UI, since that UI's scope would be active // and the main screen for that UI would be injected. Instead, we just reload the page and let the init(...) method // do the work for us. getPage().reload(); } } @Override public void receiveBroadcast(String message) { access(new Runnable() { @Override public void run() { Notification n = new Notification("IRC message", message, Notification.Type.TRAY_NOTIFICATION); n.show(getPage()); } }); } }