summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--paramiko/auth_handler.py4
-rw-r--r--paramiko/ber.py6
-rw-r--r--paramiko/common.py18
-rw-r--r--paramiko/file.py4
-rw-r--r--paramiko/kex_gex.py2
-rw-r--r--paramiko/kex_group1.py4
-rw-r--r--paramiko/kex_gss.py13
-rw-r--r--paramiko/message.py2
-rw-r--r--paramiko/pkey.py2
-rw-r--r--paramiko/ssh_exception.py4
-rw-r--r--paramiko/transport.py15
-rw-r--r--paramiko/util.py12
-rw-r--r--paramiko/win_pageant.py2
-rw-r--r--tests/test_client.py4
-rw-r--r--tests/test_file.py2
-rw-r--r--tests/test_kex.py2
-rw-r--r--tests/test_message.py24
-rw-r--r--tests/test_packetizer.py2
-rw-r--r--tests/test_transport.py8
-rw-r--r--tests/util.py1
20 files changed, 73 insertions, 58 deletions
diff --git a/paramiko/auth_handler.py b/paramiko/auth_handler.py
index f18a3ed6..18c83293 100644
--- a/paramiko/auth_handler.py
+++ b/paramiko/auth_handler.py
@@ -613,9 +613,7 @@ Error Message: {}
self._log(INFO, "Auth rejected: public key: {}".format(str(e)))
key = None
except Exception as e:
- msg = (
- "Auth rejected: unsupported or mangled public key ({}: {})"
- ) # noqa
+ msg = "Auth rejected: unsupported or mangled public key ({}: {})" # noqa
self._log(INFO, msg.format(e.__class__.__name__, e))
key = None
if key is None:
diff --git a/paramiko/ber.py b/paramiko/ber.py
index 4e93e66f..051a9537 100644
--- a/paramiko/ber.py
+++ b/paramiko/ber.py
@@ -57,7 +57,7 @@ class BER(object):
while self.idx < len(self.content):
t = byte_ord(self.content[self.idx])
self.idx += 1
- ident = (ident << 7) | (t & 0x7f)
+ ident = (ident << 7) | (t & 0x7F)
if not (t & 0x80):
break
if self.idx >= len(self.content):
@@ -68,7 +68,7 @@ class BER(object):
if size & 0x80:
# more complimicated...
# FIXME: theoretically should handle indefinite-length (0x80)
- t = size & 0x7f
+ t = size & 0x7F
if self.idx + t > len(self.content):
return None
size = util.inflate_long(
@@ -106,7 +106,7 @@ class BER(object):
def encode_tlv(self, ident, val):
# no need to support ident > 31 here
self.content += byte_chr(ident)
- if len(val) > 0x7f:
+ if len(val) > 0x7F:
lenstr = util.deflate_long(len(val))
self.content += byte_chr(0x80 + len(lenstr)) + lenstr
else:
diff --git a/paramiko/common.py b/paramiko/common.py
index 3721efe4..b57149b7 100644
--- a/paramiko/common.py
+++ b/paramiko/common.py
@@ -26,20 +26,24 @@ import struct
# Formerly of py3compat.py. May be fully delete'able with a deeper look?
#
+
def byte_chr(c):
assert isinstance(c, int)
return struct.pack("B", c)
+
def byte_mask(c, mask):
assert isinstance(c, int)
return struct.pack("B", c & mask)
+
def byte_ord(c):
# In case we're handed a string instead of an int.
if not isinstance(c, int):
c = ord(c)
return c
+
(
MSG_DISCONNECT,
MSG_IGNORE,
@@ -198,7 +202,7 @@ CONNECTION_FAILED_CODE = {
zero_byte = byte_chr(0)
one_byte = byte_chr(1)
four_byte = byte_chr(4)
-max_byte = byte_chr(0xff)
+max_byte = byte_chr(0xFF)
cr_byte = byte_chr(13)
linefeed_byte = byte_chr(10)
crlf = cr_byte + linefeed_byte
@@ -206,7 +210,7 @@ cr_byte_value = 13
linefeed_byte_value = 10
-xffffffff = 0xffffffff
+xffffffff = 0xFFFFFFFF
x80000000 = 0x80000000
o666 = 438
o660 = 432
@@ -225,17 +229,17 @@ CRITICAL = logging.CRITICAL
# Common IO/select/etc sleep period, in seconds
io_sleep = 0.01
-DEFAULT_WINDOW_SIZE = 64 * 2 ** 15
-DEFAULT_MAX_PACKET_SIZE = 2 ** 15
+DEFAULT_WINDOW_SIZE = 64 * 2**15
+DEFAULT_MAX_PACKET_SIZE = 2**15
# lower bound on the max packet size we'll accept from the remote host
# Minimum packet size is 32768 bytes according to
# http://www.ietf.org/rfc/rfc4254.txt
-MIN_WINDOW_SIZE = 2 ** 15
+MIN_WINDOW_SIZE = 2**15
# However, according to http://www.ietf.org/rfc/rfc4253.txt it is perfectly
# legal to accept a size much smaller, as OpenSSH client does as size 16384.
-MIN_PACKET_SIZE = 2 ** 12
+MIN_PACKET_SIZE = 2**12
# Max windows size according to http://www.ietf.org/rfc/rfc4254.txt
-MAX_WINDOW_SIZE = 2 ** 32 - 1
+MAX_WINDOW_SIZE = 2**32 - 1
diff --git a/paramiko/file.py b/paramiko/file.py
index a30e5137..b1450ac9 100644
--- a/paramiko/file.py
+++ b/paramiko/file.py
@@ -520,9 +520,7 @@ class BufferedFile(ClosingContextManager):
return
if self.newlines is None:
self.newlines = newline
- elif self.newlines != newline and isinstance(
- self.newlines, bytes
- ):
+ elif self.newlines != newline and isinstance(self.newlines, bytes):
self.newlines = (self.newlines, newline)
elif newline not in self.newlines:
self.newlines += (newline,)
diff --git a/paramiko/kex_gex.py b/paramiko/kex_gex.py
index 7bf24ddd..aa68efa5 100644
--- a/paramiko/kex_gex.py
+++ b/paramiko/kex_gex.py
@@ -111,7 +111,7 @@ class KexGex(object):
qnorm = util.deflate_long(q, 0)
qhbyte = byte_ord(qnorm[0])
byte_count = len(qnorm)
- qmask = 0xff
+ qmask = 0xFF
while not (qhbyte & 0x80):
qhbyte <<= 1
qmask >>= 1
diff --git a/paramiko/kex_group1.py b/paramiko/kex_group1.py
index 1e3d55f6..f4ac4944 100644
--- a/paramiko/kex_group1.py
+++ b/paramiko/kex_group1.py
@@ -33,7 +33,7 @@ from paramiko.ssh_exception import SSHException
_MSG_KEXDH_INIT, _MSG_KEXDH_REPLY = range(30, 32)
c_MSG_KEXDH_INIT, c_MSG_KEXDH_REPLY = [byte_chr(c) for c in range(30, 32)]
-b7fffffffffffffff = byte_chr(0x7f) + max_byte * 7
+b7fffffffffffffff = byte_chr(0x7F) + max_byte * 7
b0000000000000000 = zero_byte * 8
@@ -86,7 +86,7 @@ class KexGroup1(object):
# potential x).
while 1:
x_bytes = os.urandom(128)
- x_bytes = byte_mask(x_bytes[0], 0x7f) + x_bytes[1:]
+ x_bytes = byte_mask(x_bytes[0], 0x7F) + x_bytes[1:]
if (
x_bytes[:8] != b7fffffffffffffff
and x_bytes[:8] != b0000000000000000
diff --git a/paramiko/kex_gss.py b/paramiko/kex_gss.py
index 55f3f5e7..a826cc0a 100644
--- a/paramiko/kex_gss.py
+++ b/paramiko/kex_gss.py
@@ -41,7 +41,12 @@ import os
from hashlib import sha1
from paramiko.common import (
- DEBUG, max_byte, zero_byte, byte_chr, byte_mask, byte_ord,
+ DEBUG,
+ max_byte,
+ zero_byte,
+ byte_chr,
+ byte_mask,
+ byte_ord,
)
from paramiko import util
from paramiko.message import Message
@@ -77,7 +82,7 @@ class KexGSSGroup1(object):
# draft-ietf-secsh-transport-09.txt, page 17
P = 0xFFFFFFFFFFFFFFFFC90FDAA22168C234C4C6628B80DC1CD129024E088A67CC74020BBEA63B139B22514A08798E3404DDEF9519B3CD3A431B302B0A6DF25F14374FE1356D6D51C245E485B576625E7EC6F44C42E9A637ED6B0BFF5CB6F406B7EDEE386BFB5A899FA5AE9F24117C4B1FE649286651ECE65381FFFFFFFFFFFFFFFF # noqa
G = 2
- b7fffffffffffffff = byte_chr(0x7f) + max_byte * 7 # noqa
+ b7fffffffffffffff = byte_chr(0x7F) + max_byte * 7 # noqa
b0000000000000000 = zero_byte * 8 # noqa
NAME = "gss-group1-sha1-toWM5Slw5Ew8Mqkay+al2g=="
@@ -147,7 +152,7 @@ class KexGSSGroup1(object):
"""
while 1:
x_bytes = os.urandom(128)
- x_bytes = byte_mask(x_bytes[0], 0x7f) + x_bytes[1:]
+ x_bytes = byte_mask(x_bytes[0], 0x7F) + x_bytes[1:]
first = x_bytes[:8]
if first not in (self.b7fffffffffffffff, self.b0000000000000000):
break
@@ -402,7 +407,7 @@ class KexGSSGex(object):
qnorm = util.deflate_long(q, 0)
qhbyte = byte_ord(qnorm[0])
byte_count = len(qnorm)
- qmask = 0xff
+ qmask = 0xFF
while not (qhbyte & 0x80):
qhbyte <<= 1
qmask >>= 1
diff --git a/paramiko/message.py b/paramiko/message.py
index fc832732..5833f9dd 100644
--- a/paramiko/message.py
+++ b/paramiko/message.py
@@ -39,7 +39,7 @@ class Message(object):
paramiko doesn't support yet.
"""
- big_int = 0xff000000
+ big_int = 0xFF000000
def __init__(self, content=None):
"""
diff --git a/paramiko/pkey.py b/paramiko/pkey.py
index 5e4a51ca..895fd840 100644
--- a/paramiko/pkey.py
+++ b/paramiko/pkey.py
@@ -50,7 +50,7 @@ def _unpad_openssh(data):
# really ought to be made constant time (possibly by upstreaming this logic
# into pyca/cryptography).
padding_length = six.indexbytes(data, -1)
- if 0x20 <= padding_length < 0x7f:
+ if 0x20 <= padding_length < 0x7F:
return data # no padding, last byte part comment (printable ascii)
if padding_length > 15:
raise SSHException("Invalid key")
diff --git a/paramiko/ssh_exception.py b/paramiko/ssh_exception.py
index 620ab259..c7b0c249 100644
--- a/paramiko/ssh_exception.py
+++ b/paramiko/ssh_exception.py
@@ -125,9 +125,7 @@ class BadHostKeyException(SSHException):
self.expected_key = expected_key
def __str__(self):
- msg = (
- "Host key for server '{}' does not match: got '{}', expected '{}'"
- ) # noqa
+ msg = "Host key for server '{}' does not match: got '{}', expected '{}'" # noqa
return msg.format(
self.hostname,
self.key.get_base64(),
diff --git a/paramiko/transport.py b/paramiko/transport.py
index b2e8d432..1d5f9014 100644
--- a/paramiko/transport.py
+++ b/paramiko/transport.py
@@ -112,7 +112,12 @@ from paramiko.ssh_exception import (
IncompatiblePeer,
ProxyCommandFailure,
)
-from paramiko.util import retry_on_signal, ClosingContextManager, clamp_value, b
+from paramiko.util import (
+ retry_on_signal,
+ ClosingContextManager,
+ clamp_value,
+ b,
+)
# for thread cleanup
@@ -1875,9 +1880,9 @@ class Transport(threading.Thread, ClosingContextManager):
"""you are holding the lock"""
chanid = self._channel_counter
while self._channels.get(chanid) is not None:
- self._channel_counter = (self._channel_counter + 1) & 0xffffff
+ self._channel_counter = (self._channel_counter + 1) & 0xFFFFFF
chanid = self._channel_counter
- self._channel_counter = (self._channel_counter + 1) & 0xffffff
+ self._channel_counter = (self._channel_counter + 1) & 0xFFFFFF
return chanid
def _unlink_channel(self, chanid):
@@ -2592,7 +2597,7 @@ class Transport(threading.Thread, ClosingContextManager):
def _activate_inbound(self):
"""switch on newly negotiated encryption parameters for
- inbound traffic"""
+ inbound traffic"""
block_size = self._cipher_info[self.remote_cipher]["block-size"]
if self.server_mode:
IV_in = self._compute_key("A", block_size)
@@ -2628,7 +2633,7 @@ class Transport(threading.Thread, ClosingContextManager):
def _activate_outbound(self):
"""switch on newly negotiated encryption parameters for
- outbound traffic"""
+ outbound traffic"""
m = Message()
m.add_byte(cMSG_NEWKEYS)
self._send_message(m)
diff --git a/paramiko/util.py b/paramiko/util.py
index 5e2f6392..5a21977e 100644
--- a/paramiko/util.py
+++ b/paramiko/util.py
@@ -29,7 +29,14 @@ import traceback
import threading
import logging
-from paramiko.common import DEBUG, zero_byte, xffffffff, max_byte, byte_ord, byte_chr
+from paramiko.common import (
+ DEBUG,
+ zero_byte,
+ xffffffff,
+ max_byte,
+ byte_ord,
+ byte_chr,
+)
from paramiko.config import SSHConfig
@@ -67,7 +74,7 @@ def deflate_long(n, add_sign_padding=True):
for i in enumerate(s):
if (n == 0) and (i[1] != 0):
break
- if (n == -1) and (i[1] != 0xff):
+ if (n == -1) and (i[1] != 0xFF):
break
else:
# degenerate case, n was either 0 or -1
@@ -330,6 +337,7 @@ def b(s, encoding="utf8"):
else:
raise TypeError("Expected unicode or bytes, got {!r}".format(s))
+
# TODO: clean this up / force callers to assume bytes OR unicode
def u(s, encoding="utf8"):
"""cast bytes or unicode to unicode"""
diff --git a/paramiko/win_pageant.py b/paramiko/win_pageant.py
index 93f74621..a1096ee8 100644
--- a/paramiko/win_pageant.py
+++ b/paramiko/win_pageant.py
@@ -36,7 +36,7 @@ except ImportError:
from . import _winapi
-_AGENT_COPYDATA_ID = 0x804e50ba
+_AGENT_COPYDATA_ID = 0x804E50BA
_AGENT_MAX_MSGLEN = 8192
# Note: The WM_COPYDATA value is pulled from win32con, as a workaround
# so we do not have to import this huge library just for this one variable.
diff --git a/tests/test_client.py b/tests/test_client.py
index a0dcab1a..cb34348a 100644
--- a/tests/test_client.py
+++ b/tests/test_client.py
@@ -803,7 +803,7 @@ class PasswordPassphraseTests(ClientTest):
@requires_sha1_signing
def test_password_kwarg_used_for_passphrase_when_no_passphrase_kwarg_given(
- self
+ self,
): # noqa
# Backwards compatibility: passphrase in the password field.
self._test_connection(
@@ -814,7 +814,7 @@ class PasswordPassphraseTests(ClientTest):
@raises(AuthenticationException) # TODO: more granular
@requires_sha1_signing
def test_password_kwarg_not_used_for_passphrase_when_passphrase_kwarg_given( # noqa
- self
+ self,
):
# Sanity: if we're given both fields, the password field is NOT used as
# a passphrase.
diff --git a/tests/test_file.py b/tests/test_file.py
index b0147450..bcd1ad2b 100644
--- a/tests/test_file.py
+++ b/tests/test_file.py
@@ -189,7 +189,7 @@ class BufferedFileTest(unittest.TestCase):
self.assertRaises(TypeError, f.write, object())
def test_write_unicode_as_binary(self):
- text = u"\xa7 why is writing text to a binary file allowed?\n"
+ text = "\xa7 why is writing text to a binary file allowed?\n"
with LoopbackFile("rb+") as f:
f.write(text)
self.assertEqual(f.read(), text.encode("utf-8"))
diff --git a/tests/test_kex.py b/tests/test_kex.py
index 24fb8b81..45a691f2 100644
--- a/tests/test_kex.py
+++ b/tests/test_kex.py
@@ -47,7 +47,7 @@ from paramiko.kex_curve25519 import KexCurve25519
def dummy_urandom(n):
- return byte_chr(0xcc) * n
+ return byte_chr(0xCC) * n
def dummy_generate_key_pair(obj):
diff --git a/tests/test_message.py b/tests/test_message.py
index 23b06858..bd2d5795 100644
--- a/tests/test_message.py
+++ b/tests/test_message.py
@@ -48,18 +48,18 @@ class MessageTest(unittest.TestCase):
msg = Message()
msg.add_boolean(True)
msg.add_boolean(False)
- msg.add_byte(byte_chr(0xf3))
+ msg.add_byte(byte_chr(0xF3))
- msg.add_bytes(zero_byte + byte_chr(0x3f))
+ msg.add_bytes(zero_byte + byte_chr(0x3F))
msg.add_list(["huey", "dewey", "louie"])
self.assertEqual(msg.asbytes(), self.__b)
msg = Message()
msg.add_int64(5)
- msg.add_int64(0xf5e4d3c2b109)
+ msg.add_int64(0xF5E4D3C2B109)
msg.add_mpint(17)
- msg.add_mpint(0xf5e4d3c2b109)
- msg.add_mpint(-0x65e4d3c2b109)
+ msg.add_mpint(0xF5E4D3C2B109)
+ msg.add_mpint(-0x65E4D3C2B109)
self.assertEqual(msg.asbytes(), self.__c)
def test_decode(self):
@@ -73,22 +73,22 @@ class MessageTest(unittest.TestCase):
msg = Message(self.__b)
self.assertEqual(msg.get_boolean(), True)
self.assertEqual(msg.get_boolean(), False)
- self.assertEqual(msg.get_byte(), byte_chr(0xf3))
- self.assertEqual(msg.get_bytes(2), zero_byte + byte_chr(0x3f))
+ self.assertEqual(msg.get_byte(), byte_chr(0xF3))
+ self.assertEqual(msg.get_bytes(2), zero_byte + byte_chr(0x3F))
self.assertEqual(msg.get_list(), ["huey", "dewey", "louie"])
msg = Message(self.__c)
self.assertEqual(msg.get_int64(), 5)
- self.assertEqual(msg.get_int64(), 0xf5e4d3c2b109)
+ self.assertEqual(msg.get_int64(), 0xF5E4D3C2B109)
self.assertEqual(msg.get_mpint(), 17)
- self.assertEqual(msg.get_mpint(), 0xf5e4d3c2b109)
- self.assertEqual(msg.get_mpint(), -0x65e4d3c2b109)
+ self.assertEqual(msg.get_mpint(), 0xF5E4D3C2B109)
+ self.assertEqual(msg.get_mpint(), -0x65E4D3C2B109)
def test_add(self):
msg = Message()
msg.add(5)
msg.add(0x1122334455)
- msg.add(0xf00000000000000000)
+ msg.add(0xF00000000000000000)
msg.add(True)
msg.add("cat")
msg.add(["a", "b"])
@@ -98,7 +98,7 @@ class MessageTest(unittest.TestCase):
msg = Message(self.__d)
self.assertEqual(msg.get_adaptive_int(), 5)
self.assertEqual(msg.get_adaptive_int(), 0x1122334455)
- self.assertEqual(msg.get_adaptive_int(), 0xf00000000000000000)
+ self.assertEqual(msg.get_adaptive_int(), 0xF00000000000000000)
self.assertEqual(msg.get_so_far(), self.__d[:29])
self.assertEqual(msg.get_remainder(), self.__d[29:])
msg.rewind()
diff --git a/tests/test_packetizer.py b/tests/test_packetizer.py
index 27dee358..d4dd58ad 100644
--- a/tests/test_packetizer.py
+++ b/tests/test_packetizer.py
@@ -34,7 +34,7 @@ from .loop import LoopSocket
x55 = byte_chr(0x55)
-x1f = byte_chr(0x1f)
+x1f = byte_chr(0x1F)
class PacketizerTest(unittest.TestCase):
diff --git a/tests/test_transport.py b/tests/test_transport.py
index 177e83da..d5cb5576 100644
--- a/tests/test_transport.py
+++ b/tests/test_transport.py
@@ -686,7 +686,7 @@ class TransportTest(unittest.TestCase):
self.assertEqual(chan.send_ready(), True)
total = 0
K = "*" * 1024
- limit = 1 + (64 * 2 ** 15)
+ limit = 1 + (64 * 2**15)
while total < limit:
chan.send(K)
total += len(K)
@@ -874,7 +874,7 @@ class TransportTest(unittest.TestCase):
for val, correct in [
(4095, MIN_PACKET_SIZE),
(None, DEFAULT_MAX_PACKET_SIZE),
- (2 ** 32, MAX_WINDOW_SIZE),
+ (2**32, MAX_WINDOW_SIZE),
]:
self.assertEqual(self.tc._sanitize_packet_size(val), correct)
@@ -885,7 +885,7 @@ class TransportTest(unittest.TestCase):
for val, correct in [
(32767, MIN_WINDOW_SIZE),
(None, DEFAULT_WINDOW_SIZE),
- (2 ** 32, MAX_WINDOW_SIZE),
+ (2**32, MAX_WINDOW_SIZE),
]:
self.assertEqual(self.tc._sanitize_window_size(val), correct)
@@ -950,7 +950,7 @@ class TransportTest(unittest.TestCase):
verify behaviours sending various instances to a channel
"""
self.setup_test_server()
- text = u"\xa7 slice me nicely"
+ text = "\xa7 slice me nicely"
with self.tc.open_session() as chan:
schan = self.ts.accept(1.0)
if schan is None:
diff --git a/tests/util.py b/tests/util.py
index f3efb6b0..00642cb0 100644
--- a/tests/util.py
+++ b/tests/util.py
@@ -78,7 +78,6 @@ if (
def tearDownClass(cls):
del cls.realm
-
else:
try:
# Try to setup a kerberos environment