aboutsummaryrefslogtreecommitdiffstats
path: root/lib/src/main/java/com/trilead/ssh2/transport/TransportConnection.java
diff options
context:
space:
mode:
authorMatt Johnston <matt@ucc.asn.au>2011-01-24 22:07:26 +0800
committerKenny Root <kenny@the-b.org>2011-01-25 00:04:31 +0800
commit1f226a971901ce18b3cf615e302885e4bf543978 (patch)
tree48437c9495fe57b0a0508d398739f16591c73b68 /lib/src/main/java/com/trilead/ssh2/transport/TransportConnection.java
parent8d9e879725756d6b2e61449e09d905d06c3aa69c (diff)
downloadsshlib-1f226a971901ce18b3cf615e302885e4bf543978.tar.gz
sshlib-1f226a971901ce18b3cf615e302885e4bf543978.tar.bz2
sshlib-1f226a971901ce18b3cf615e302885e4bf543978.zip
Make 'zlib' compression work.
Previously all compression was the equivalent of zlib@openssh.com since TransportConnection enforced that.
Diffstat (limited to 'lib/src/main/java/com/trilead/ssh2/transport/TransportConnection.java')
-rw-r--r--lib/src/main/java/com/trilead/ssh2/transport/TransportConnection.java19
1 files changed, 13 insertions, 6 deletions
diff --git a/lib/src/main/java/com/trilead/ssh2/transport/TransportConnection.java b/lib/src/main/java/com/trilead/ssh2/transport/TransportConnection.java
index 77eaded..2c04ce4 100644
--- a/lib/src/main/java/com/trilead/ssh2/transport/TransportConnection.java
+++ b/lib/src/main/java/com/trilead/ssh2/transport/TransportConnection.java
@@ -56,7 +56,9 @@ public class TransportConnection
ICompressor send_comp = null;
- boolean can_compress = false;
+ boolean can_recv_compress = false;
+
+ boolean can_send_compress = false;
byte[] recv_comp_buffer;
@@ -117,16 +119,20 @@ public class TransportConnection
{
recv_comp = comp;
- if (comp != null)
+ if (comp != null) {
recv_comp_buffer = new byte[comp.getBufferSize()];
+ can_recv_compress |= recv_comp.canCompressPreauth();
+ }
}
public void changeSendCompression(ICompressor comp)
{
send_comp = comp;
- if (comp != null)
+ if (comp != null) {
send_comp_buffer = new byte[comp.getBufferSize()];
+ can_send_compress |= send_comp.canCompressPreauth();
+ }
}
public void sendMessage(byte[] message) throws IOException
@@ -152,7 +158,7 @@ public class TransportConnection
else if (padd > 64)
padd = 64;
- if (send_comp != null && can_compress) {
+ if (send_comp != null && can_send_compress) {
if (send_comp_buffer.length < message.length + 1024)
send_comp_buffer = new byte[message.length + 1024];
len = send_comp.compress(message, off, len, send_comp_buffer);
@@ -313,7 +319,7 @@ public class TransportConnection
+ " bytes payload");
}
- if (recv_comp != null && can_compress) {
+ if (recv_comp != null && can_recv_compress) {
int[] uncomp_len = new int[] { payload_length };
buffer = recv_comp.uncompress(buffer, off, uncomp_len);
@@ -331,6 +337,7 @@ public class TransportConnection
*
*/
public void startCompression() {
- can_compress = true;
+ can_recv_compress = true;
+ can_send_compress = true;
}
}