From: Tatu Lund Date: Thu, 30 Sep 2021 09:09:27 +0000 (+0300) Subject: fix: Add row limit to DataCommunicator row data requests (#12415) X-Git-Tag: 8.15.0~34 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=2fc98eaf9c0e2cd42cf4a66fb6d2cd2e9f0a08a9;p=vaadin-framework.git fix: Add row limit to DataCommunicator row data requests (#12415) * Add row limit to DataCommunicator row data requests * Add missing constant * Add unit test * Add test for extending Grid * Fixed test --- diff --git a/server/src/main/java/com/vaadin/data/provider/DataCommunicator.java b/server/src/main/java/com/vaadin/data/provider/DataCommunicator.java index 0c1dafe09e..8d974c85d3 100644 --- a/server/src/main/java/com/vaadin/data/provider/DataCommunicator.java +++ b/server/src/main/java/com/vaadin/data/provider/DataCommunicator.java @@ -60,6 +60,7 @@ import elemental.json.JsonObject; public class DataCommunicator extends AbstractExtension { private Registration dataProviderUpdateRegistration; + private static final int MAXIMUM_ALLOWED_ROWS = 500; /** * Simple implementation of collection data provider communication. All data @@ -306,10 +307,24 @@ public class DataCommunicator extends AbstractExtension { */ protected void onRequestRows(int firstRowIndex, int numberOfRows, int firstCachedRowIndex, int cacheSize) { + if (numberOfRows > getMaximumAllowedRows()) { + throw new IllegalStateException( + "Client tried fetch more rows than allowed. This is denied to prevent denial of service."); + } setPushRows(Range.withLength(firstRowIndex, numberOfRows)); markAsDirty(); } + /** + * Set the maximum allowed rows to be fetched in one query. + * + * @return Maximum allowed rows for one query. + * @since 8.14.1 + */ + protected int getMaximumAllowedRows() { + return MAXIMUM_ALLOWED_ROWS; + } + /** * Triggered when rows have been dropped from the client side cache. * diff --git a/server/src/test/java/com/vaadin/data/provider/DataCommunicatorTest.java b/server/src/test/java/com/vaadin/data/provider/DataCommunicatorTest.java index c187c91471..ed681f298d 100644 --- a/server/src/test/java/com/vaadin/data/provider/DataCommunicatorTest.java +++ b/server/src/test/java/com/vaadin/data/provider/DataCommunicatorTest.java @@ -314,4 +314,12 @@ public class DataCommunicatorTest { assertTrue("DataCommunicator should be marked as dirty", ui.getConnectorTracker().isDirty(communicator)); } + + + @Test(expected = IllegalStateException.class) + public void requestTooMuchRowsFail() { + TestDataCommunicator communicator = new TestDataCommunicator(); + communicator.onRequestRows(0, communicator.getMaximumAllowedRows() + 10, + 0, 0); + } } diff --git a/server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java b/server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java index 5320959967..f0284b7f28 100644 --- a/server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java +++ b/server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java @@ -827,4 +827,23 @@ public class GridTest { column.isSortableByUser()); } + @Test + public void extendGridCustomDataCommunicator() { + Grid grid = new MyGrid<>(); + } + + public class MyDataCommunicator extends DataCommunicator { + @Override + protected int getMaximumAllowedRows() { + return 600; + } + } + + public class MyGrid extends Grid { + + public MyGrid() { + super(new MyDataCommunicator()); + } + + } }