Issue #207 - allowing untrusted sessions to have non-validating generators

This commit is contained in:
Joakim Erdfelt 2017-04-21 17:21:47 -07:00
parent 6e797f5e7d
commit 38e0976513
2 changed files with 17 additions and 4 deletions

View File

@ -62,9 +62,10 @@ public class Generator
private final WebSocketBehavior behavior;
private final ByteBufferPool bufferPool;
private final boolean validating;
private final boolean readOnly;
private boolean validating = true;
/**
* Are any flags in use
* <p>
@ -375,6 +376,11 @@ public class Generator
return bufferPool;
}
public boolean isValidating()
{
return validating;
}
public void setRsv1InUse(boolean rsv1InUse)
{
if (readOnly)
@ -402,6 +408,11 @@ public class Generator
flagsInUse = (byte)((flagsInUse & 0xEF) | (rsv3InUse?0x10:0x00));
}
public void setValidating(boolean validating)
{
this.validating = validating;
}
public boolean isRsv1InUse()
{
return (flagsInUse & 0x40) != 0;

View File

@ -33,7 +33,9 @@ public class UntrustedWSSession extends WebSocketSession implements AutoCloseabl
public UntrustedWSSession(WebSocketContainerScope containerScope, URI requestURI, Object endpoint, LogicalConnection connection)
{
super(containerScope, requestURI, endpoint, connection);
this.untrustedConnection = new UntrustedWSConnection((AbstractWebSocketConnection) connection);
AbstractWebSocketConnection abstractWebSocketConnection = (AbstractWebSocketConnection) connection;
abstractWebSocketConnection.getGenerator().setValidating(false);
this.untrustedConnection = new UntrustedWSConnection(abstractWebSocketConnection);
this.untrustedEndpoint = (UntrustedWSEndpoint) endpoint;
}