From b36dc81569fffc9d12fd6648366c965bbae4000e Mon Sep 17 00:00:00 2001 From: Tatu Lund Date: Wed, 5 Aug 2020 13:00:28 +0300 Subject: Fix possible NPE with MPR (#12040) It is possible when Vaadin 8 is used with MPR, that ui.getCurrent().getSession() returns null. See: https://github.com/vaadin/multiplatform-runtime/issues/5 --- server/src/main/java/com/vaadin/server/Page.java | 21 ++++++++++++++++----- .../communication/ServletUIInitHandlerTest.java | 1 + 2 files changed, 17 insertions(+), 5 deletions(-) (limited to 'server') diff --git a/server/src/main/java/com/vaadin/server/Page.java b/server/src/main/java/com/vaadin/server/Page.java index 0708a23000..0479ee3c88 100644 --- a/server/src/main/java/com/vaadin/server/Page.java +++ b/server/src/main/java/com/vaadin/server/Page.java @@ -997,11 +997,22 @@ public class Page implements Serializable { * set to {@code false} */ public URI getLocation() throws IllegalStateException { - if (location == null && !uI.getSession().getConfiguration() - .isSendUrlsAsParameters()) { - throw new IllegalStateException("Location is not available as the " - + Constants.SERVLET_PARAMETER_SENDURLSASPARAMETERS - + " parameter is configured as false"); + if (location == null) { + if (uI.getSession() != null && !uI.getSession().getConfiguration() + .isSendUrlsAsParameters()) { + throw new IllegalStateException("Location is not available as the " + + Constants.SERVLET_PARAMETER_SENDURLSASPARAMETERS + + " parameter is configured as false"); + } else if (VaadinSession.getCurrent() == null) { + throw new IllegalStateException("Location is not available as the " + + Constants.SERVLET_PARAMETER_SENDURLSASPARAMETERS + + " parameter state cannot be determined"); + } else if (!VaadinSession.getCurrent().getConfiguration() + .isSendUrlsAsParameters()) { + throw new IllegalStateException("Location is not available as the " + + Constants.SERVLET_PARAMETER_SENDURLSASPARAMETERS + + " parameter is configured as false"); + } } return location; } diff --git a/server/src/test/java/com/vaadin/server/communication/ServletUIInitHandlerTest.java b/server/src/test/java/com/vaadin/server/communication/ServletUIInitHandlerTest.java index 66f3dca4c5..9d68aca898 100644 --- a/server/src/test/java/com/vaadin/server/communication/ServletUIInitHandlerTest.java +++ b/server/src/test/java/com/vaadin/server/communication/ServletUIInitHandlerTest.java @@ -54,6 +54,7 @@ public class ServletUIInitHandlerTest { session); session.setCommunicationManager(communicationManager); session.setConfiguration(deploymentConfiguration); + session.setCurrent(session); session.addUIProvider(new UIProvider() { @Override -- cgit v1.2.3