# do not edit -- automatically generated by arch changelog # arch-tag: automatic-ChangeLog--robey@lag.net--2003-public/secsh--dev--1.0 # 2005-04-18 00:53:57 GMT Robey Pointer <robey@lag.net> patch-164 Summary: fix some docs Revision: secsh--dev--1.0--patch-164 remove some epydoc comments about fileno() being non-portable. modified files: paramiko/channel.py 2005-04-18 00:30:52 GMT Robey Pointer <robey@lag.net> patch-163 Summary: add SFTPClient.close() Revision: secsh--dev--1.0--patch-163 add SFTPClient.close() and add a simple little unit test for it. modified files: paramiko/sftp_client.py tests/test_sftp.py 2005-04-18 00:11:34 GMT Robey Pointer <robey@lag.net> patch-162 Summary: avoid os.environ['HOME'] in the demos Revision: secsh--dev--1.0--patch-162 avoid using os.environ['HOME'], which will never work on windows, and use os.path.expanduser() instead. it's semi-moot because windows doesn't have a standard location for ssh files, but i think paramiko should set a good example anyway. modified files: demo.py demo_simple.py 2005-04-16 23:38:22 GMT Robey Pointer <robey@lag.net> patch-161 Summary: integrated laptop work (test commit) Revision: secsh--dev--1.0--patch-161 Patches applied: * robey@lag.net--2003-public-master-shake/secsh--dev--1.0--base-0 tag of robey@lag.net--2003-public/secsh--dev--1.0--patch-160 * robey@lag.net--2003-public-master-shake/secsh--dev--1.0--patch-1 test commit * robey@lag.net--2003-public/secsh--dev--1.0--base-0 initial import * robey@lag.net--2003-public/secsh--dev--1.0--patch-1 no changes modified files: README paramiko/server.py new patches: robey@lag.net--2003-public-master-shake/secsh--dev--1.0--base-0 robey@lag.net--2003-public-master-shake/secsh--dev--1.0--patch-1 2005-04-10 00:46:41 GMT Robey Pointer <robey@lag.net> patch-160 Summary: 1.3 marowak Revision: secsh--dev--1.0--patch-160 bump version to 1.3 / marowak modified files: Makefile README paramiko/__init__.py paramiko/transport.py setup.py 2005-04-10 00:39:18 GMT Robey Pointer <robey@lag.net> patch-159 Summary: clean up SFTPAttributes.__repr__ Revision: secsh--dev--1.0--patch-159 clean up SFTPAttributes repr() a bit. modified files: paramiko/sftp_attr.py 2005-04-10 00:13:54 GMT Robey Pointer <robey@lag.net> patch-158 Summary: remove ChangeLog from MANIFEST.in Revision: secsh--dev--1.0--patch-158 remove ChangeLog from the dist list. modified files: MANIFEST.in 2005-04-06 07:24:28 GMT Robey Pointer <robey@lag.net> patch-157 Summary: change SubsystemHandler/SFTPServerInterface API Revision: secsh--dev--1.0--patch-157 change the API of SubsystemHandler to accept a reference to the ServerInstance object during construction. this will break all code that currently creates subsystem handlers (like sftp servers) -- sorry! lots of little doc fixups (mostly indenting). modified files: paramiko/server.py paramiko/sftp_server.py paramiko/sftp_si.py paramiko/transport.py tests/stub_sftp.py 2005-03-26 05:53:00 GMT Robey Pointer <robey@lag.net> patch-156 Summary: rewrite channel pipes to work on windows Revision: secsh--dev--1.0--patch-156 the pipe system i was using for simulating an os-level FD (for select) was retarded. i realized this week that i could just use a single byte in the pipe to signal "data is ready" and not try to feed all incoming data thru the pipe -- and then i don't have to try to make the pipe non-blocking (which should make it work on windows). a lot of duplicate code got removed and now it's all going thru the same code-path on read. there's still a slight penalty on incoming feeds and calling 'recv' when a pipe has been opened (by calling 'fileno'), but it's tiny. removed a bunch of documentation and comments about things not working on windows, since i think they probably do now. removed files: .arch-ids/demo_windows.py.id demo_windows.py modified files: MANIFEST.in README paramiko/channel.py 2005-03-25 20:06:56 GMT Robey Pointer <robey@lag.net> patch-155 Summary: fix sending of large sftp packet sizes Revision: secsh--dev--1.0--patch-155 fix a bug where packets larger than about 12KB would cause the session to die on platforms other than osx. turns out that on most platforms, setting a socket timeout also causes timeouts to occur on writes (but not on osx). so on a huge write, once the os buffers were full, paramiko would get a socket.timeout exception when writing, and bail. since the timeout is primarily so we can periodically poll to see if the session has been killed from elsewhere, do that on a timeout but otherwise continue trying to write. large packet sizes (in sftp) should now work. modified files: paramiko/transport.py 2005-02-28 08:06:08 GMT Robey Pointer <robey@lag.net> patch-154 Summary: even better 1.2 lapras Revision: secsh--dev--1.0--patch-154 re-bump the version # to 1.2 (with a new date since i added more stuff). add 2005 to the copyright date in a bunch of files. modified files: Makefile README demo.py demo_server.py demo_simple.py demo_windows.py forward.py paramiko/__init__.py paramiko/auth_transport.py paramiko/ber.py paramiko/channel.py paramiko/common.py paramiko/dsskey.py paramiko/file.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/logging22.py paramiko/message.py paramiko/pkey.py paramiko/primes.py paramiko/rsakey.py paramiko/server.py paramiko/sftp.py paramiko/sftp_attr.py paramiko/sftp_client.py paramiko/sftp_handle.py paramiko/sftp_server.py paramiko/sftp_si.py paramiko/ssh_exception.py paramiko/transport.py paramiko/util.py setup.py test.py tests/loop.py tests/stub_sftp.py tests/test_file.py tests/test_kex.py tests/test_message.py tests/test_pkey.py tests/test_sftp.py tests/test_transport.py 2005-02-28 07:49:56 GMT Robey Pointer <robey@lag.net> patch-153 Summary: tweak sftp_file write behavior on large blocks of data Revision: secsh--dev--1.0--patch-153 BufferedFile.write() wasn't correctly dealing with the possibility that the underlying write might not write the entire data block at once (even though the docs said it would). now that it's working, make sftp_file take advantage of it in order to chop up blocks larger than 32kB (the max allowed on sftp) and add a unit test for it. modified files: paramiko/file.py paramiko/sftp_file.py tests/test_sftp.py 2005-02-28 07:17:21 GMT Robey Pointer <robey@lag.net> patch-152 Summary: little doc fixes Revision: secsh--dev--1.0--patch-152 stupid little doc fixups that didn't fit with the other patches. modified files: paramiko/auth_transport.py tests/loop.py 2005-02-28 07:16:22 GMT Robey Pointer <robey@lag.net> patch-151 Summary: fix race in transport thread startup Revision: secsh--dev--1.0--patch-151 set active=True from the methods that start the main transport thread, right before actually starting the thread. this avoids a race where the main thread could be started, but the original thread could wake up from the event.wait(0.1) before the new thread actually set the transport active. impossible, you say? no machines so slow exist? au contraire, my sad little linux box faced this problem earlier today. modified files: paramiko/transport.py 2005-02-28 07:14:11 GMT Robey Pointer <robey@lag.net> patch-150 Summary: when combining stderr with stdout on a channel, merge the buffers too Revision: secsh--dev--1.0--patch-150 when turning on combine-stderr mode on a channel, grab the channel lock and feed any existing stderr buffer into the normal buffer. this should help applications (and my unit tests) avoid races between data coming in over stderr and setting combine-stderr. _send_eof is now slightly safer too, although i don't think that really fixed anything. it just makes me feel better. modified files: paramiko/channel.py 2005-02-28 07:09:02 GMT Robey Pointer <robey@lag.net> patch-149 Summary: add thread ids to logs Revision: secsh--dev--1.0--patch-149 add a logging filter that reports the thread-id of the logger, and use that for all paramiko logging. since thread-local stuff didn't appear until python 2.4, i hacked up my own little version to assign incrementing numbers to threads as they log. modified files: paramiko/channel.py paramiko/sftp.py paramiko/sftp_client.py paramiko/sftp_server.py paramiko/transport.py paramiko/util.py 2005-02-26 21:12:43 GMT Robey Pointer <robey@lag.net> patch-148 Summary: forgot to check in stub_sftp Revision: secsh--dev--1.0--patch-148 yikes! don't forget to check this in: needed for unit tests. new files: tests/.arch-ids/stub_sftp.py.id tests/stub_sftp.py 2005-02-26 21:11:04 GMT Robey Pointer <robey@lag.net> patch-147 Summary: 1.2 (lapras) Revision: secsh--dev--1.0--patch-147 bump version stuff to 1.2 / lapras. modified files: Makefile README paramiko/__init__.py paramiko/transport.py setup.py 2005-02-15 15:48:47 GMT Robey Pointer <robey@lag.net> patch-146 Summary: raise better exception on empty key Revision: secsh--dev--1.0--patch-146 raise a clearer exception when trying to create an empty key. modified files: README paramiko/dsskey.py paramiko/rsakey.py tests/test_transport.py 2005-02-15 15:47:02 GMT Robey Pointer <robey@lag.net> patch-145 Summary: add methods for sending/receiving a channel's exit status Revision: secsh--dev--1.0--patch-145 track a channel's exit status and provide a method (recv_exit_status) to block waiting for it to arrive. also provide a convenience method for servers to send it (send_exit_status). add shutdown_read and shutdown_write. fix a bug in sending window change requests. modified files: README paramiko/channel.py paramiko/transport.py 2005-02-06 23:32:22 GMT Robey Pointer <robey@lag.net> patch-144 Summary: fix docs Revision: secsh--dev--1.0--patch-144 clean up some of the docs. modified files: README paramiko/pkey.py paramiko/sftp_attr.py 2005-02-06 23:30:40 GMT Robey Pointer <robey@lag.net> patch-143 Summary: fix an sftp unit test Revision: secsh--dev--1.0--patch-143 fix one of the sftp unit tests to actually work. modified files: tests/test_sftp.py 2005-02-05 07:45:20 GMT Robey Pointer <robey@lag.net> patch-142 Summary: fix windows sample script's HOME Revision: secsh--dev--1.0--patch-142 fix the HOME environ var to work on windows too. modified files: demo_windows.py 2005-01-25 05:17:55 GMT Robey Pointer <robey@lag.net> patch-141 Summary: misc logging fixes Revision: secsh--dev--1.0--patch-141 change the level of some log messages so interesting stuff gets logged at info instead of debug. fix an oops where channels defaulted to being in ultra debug mode, and make this mode depend on a new Transport method: "set_hexdump". modified files: paramiko/auth_transport.py paramiko/channel.py paramiko/sftp.py paramiko/sftp_client.py paramiko/sftp_server.py paramiko/transport.py 2005-01-17 10:09:09 GMT Robey Pointer <robey@lag.net> patch-140 Summary: more flexible logging Revision: secsh--dev--1.0--patch-140 some tweaks to make channels etc follow the logger setting of their parent transport, so that setting the log channel for a paramiko transport will cause all sub-logging to branch out from that channel. also, close all open file handles when the sftp server ends. modified files: paramiko/channel.py paramiko/sftp_attr.py paramiko/sftp_client.py paramiko/sftp_handle.py paramiko/sftp_server.py paramiko/transport.py 2005-01-16 21:03:15 GMT Robey Pointer <robey@lag.net> patch-139 Summary: make loopback sftp tests the default Revision: secsh--dev--1.0--patch-139 change the unit tests to default to always running the sftp tests locally, and make a -R option to force the tests to run against a remote server. the tests seem to work fine locally, and it helps test out server mode, even though there's a danger that they could get isolated from reality and only test that paramiko can talk to itself. modified files: test.py 2005-01-16 20:14:07 GMT Robey Pointer <robey@lag.net> patch-138 Summary: doc fixups Revision: secsh--dev--1.0--patch-138 little doc fixups that i did obsessively on the train one morning. modified files: paramiko/file.py 2005-01-09 05:27:07 GMT Robey Pointer <robey@lag.net> patch-137 Summary: added listdir_attr() Revision: secsh--dev--1.0--patch-137 add SFTPClient.listdir_attr() to fetch a list of files & their attributes, instead of just their filenames. artur piwko would find this useful. modified files: paramiko/sftp_attr.py paramiko/sftp_client.py 2004-12-19 19:56:48 GMT Robey Pointer <robey@lag.net> patch-136 Summary: loopback sftp test Revision: secsh--dev--1.0--patch-136 add ability to turn off more tests, and a secret (for now) -X option to do the sftp tests via loopback socket. added another symlink sftp test to see what happens with absolute symlinks. modified files: test.py tests/test_sftp.py 2004-12-19 19:50:00 GMT Robey Pointer <robey@lag.net> patch-135 Summary: more sftp cleanup Revision: secsh--dev--1.0--patch-135 oops, this should've been part of the last patch. modified files: paramiko/sftp_si.py 2004-12-19 19:43:27 GMT Robey Pointer <robey@lag.net> patch-134 Summary: cleanup & docs in sftp Revision: secsh--dev--1.0--patch-134 add some more docs to SFTPHandle, and give a default implementation for close() that's usually right. add a flush() to the default implementation of write(). document that symlink's args in the sftp protocol are out of order (the spec is wrong). modified files: paramiko/sftp_handle.py paramiko/sftp_server.py 2004-12-13 07:32:14 GMT Robey Pointer <robey@lag.net> patch-133 Summary: unit test madness Revision: secsh--dev--1.0--patch-133 add some more testy bits and fix up some other bits. modified files: tests/test_transport.py 2004-12-13 07:31:01 GMT Robey Pointer <robey@lag.net> patch-132 Summary: oops (continued) Revision: secsh--dev--1.0--patch-132 er, part 2 of that. modified files: paramiko/server.py 2004-12-13 07:29:38 GMT Robey Pointer <robey@lag.net> patch-131 Summary: move check_global_request Revision: secsh--dev--1.0--patch-131 move check_global_request into the server interface -- i missed it during the initial move (oops). modified files: paramiko/transport.py 2004-12-13 07:27:39 GMT Robey Pointer <robey@lag.net> patch-130 Summary: small fixups Revision: secsh--dev--1.0--patch-130 move _wait_for_send_window into the right place in Channel. remove outdated note from auth_transport. fix download url in setup.py. modified files: paramiko/auth_transport.py paramiko/channel.py setup.py 2004-12-12 09:58:40 GMT Robey Pointer <robey@lag.net> patch-129 Summary: 1.1 (kabuto) Revision: secsh--dev--1.0--patch-129 edit various files to bump the version to 1.1. also fix to point to the new url. modified files: Makefile README paramiko/__init__.py paramiko/transport.py setup.py 2004-12-12 09:38:24 GMT Robey Pointer <robey@lag.net> patch-128 Summary: more unit tests Revision: secsh--dev--1.0--patch-128 added unit tests for multi-part auth, exec_command, and invoke_shell. modified files: tests/test_transport.py 2004-12-12 09:32:17 GMT Robey Pointer <robey@lag.net> patch-127 Summary: doc fixups Revision: secsh--dev--1.0--patch-127 fix some typos in sftp_client docs modified files: paramiko/sftp_client.py 2004-12-12 09:25:15 GMT Robey Pointer <robey@lag.net> patch-126 Summary: server support for stderr & exec_command Revision: secsh--dev--1.0--patch-126 for the server side of my stderr blunder, add send_stderr & sendall_stderr, and make the sending side of makefile_stderr work correctly. also, call check_channel_exec_request on a server object for exec requests on a channel. modified files: paramiko/channel.py paramiko/server.py 2004-12-12 09:16:03 GMT Robey Pointer <robey@lag.net> patch-125 Summary: add client-side multi-part auth support Revision: secsh--dev--1.0--patch-125 added support for multi-part authentication (even though nobody supports it that i've seen). on a successful "partial" auth, the auth_* method will return a list of acceptable means to continue authenticating. modified files: paramiko/auth_transport.py paramiko/ssh_exception.py 2004-12-11 03:44:33 GMT Robey Pointer <robey@lag.net> patch-124 Summary: docs fixup Revision: secsh--dev--1.0--patch-124 fix a comment typo, and add @since designators to a couple of new methods. modified files: paramiko/channel.py paramiko/sftp_server.py 2004-12-11 03:43:18 GMT Robey Pointer <robey@lag.net> patch-123 Summary: clean up authentication Revision: secsh--dev--1.0--patch-123 add new exception "BadAuthenticationType", which is raised when auth fails because your auth type (password or public-key) isn't valid on the server. used this as an excuse to clean up auth_password and auth_publickey so their 'event' arg is optional, and if missing, they block until auth is finished, raising an exception on error. also, don't close the session on failed auth -- the server may let you try again. added some test cases for failed auth. modified files: paramiko/__init__.py paramiko/auth_transport.py paramiko/ssh_exception.py paramiko/transport.py tests/test_transport.py 2004-12-10 08:30:44 GMT Robey Pointer <robey@lag.net> patch-122 Summary: symlink, readlink Revision: secsh--dev--1.0--patch-122 add support for symlink command, and finish support for readlink. (i guess i started readlink a while ago but forgot to add the right method to the SFTPServerInterface class.) modified files: paramiko/sftp_server.py paramiko/sftp_si.py tests/test_sftp.py 2004-12-10 08:27:43 GMT Robey Pointer <robey@lag.net> patch-121 Summary: other part of that last patch Revision: secsh--dev--1.0--patch-121 oops, forgot this part. modified files: paramiko/transport.py 2004-12-10 08:25:28 GMT Robey Pointer <robey@lag.net> patch-120 Summary: add stderr support methods Revision: secsh--dev--1.0--patch-120 big embarrassment: i didn't read the ssh2 docs close enough, and all this time paramiko wasn't handling "extended_data" packets, which contain stderr output. so now, several new functions: recv_stderr_ready() and recv_stderr() to mirror recv_ready() and recv(), and set_combined_stderr() to force stderr to be combined into stdout. also, makefile_stderr() to create a fake file object to represent stderr. modified files: paramiko/channel.py 2004-12-10 07:55:33 GMT Robey Pointer <robey@lag.net> patch-119 Summary: reformat README Revision: secsh--dev--1.0--patch-119 reformatted the README to a slightly smaller margin, just because. modified files: README 2004-12-09 04:15:12 GMT Robey Pointer <robey@lag.net> patch-118 Summary: fix SFTPFile gettimeout/settimeout Revision: secsh--dev--1.0--patch-118 i don't think the gettimeout/settimeout calls on SFTPFile ever worked. also, simplify the implementation of _get_size() since it's nearly identical to stat(). modified files: paramiko/sftp_file.py 2004-12-09 02:42:36 GMT Robey Pointer <robey@lag.net> patch-117 Summary: readme comments Revision: secsh--dev--1.0--patch-117 add another fixme to the readme modified files: README 2004-11-26 22:07:31 GMT Robey Pointer <robey@lag.net> patch-116 Summary: doc fixups Revision: secsh--dev--1.0--patch-116 explain "recv_ready" better, and add debug descriptions for the kex codes. modified files: README paramiko/channel.py paramiko/common.py 2004-11-25 19:39:34 GMT Robey Pointer <robey@lag.net> patch-115 Summary: fix CONNECTION_FAILED_CODE Revision: secsh--dev--1.0--patch-115 oops, fix typo in channel request failed. modified files: paramiko/transport.py 2004-11-22 07:40:39 GMT Robey Pointer <robey@lag.net> patch-114 Summary: fix typo in channel Revision: secsh--dev--1.0--patch-114 fix typo that alain found: pipd_wfd -> pipe_wfd. modified files: paramiko/channel.py 2004-11-22 07:27:21 GMT Robey Pointer <robey@lag.net> patch-113 Summary: sftp server support! Revision: secsh--dev--1.0--patch-113 finally check in sftp_handle (file handle abstraction), sftp_si (server interface), and sftp_server (server implementation) -- all of which make a roughly 90% implementation of server-side sftp. new files: paramiko/.arch-ids/sftp_handle.py.id paramiko/.arch-ids/sftp_server.py.id paramiko/.arch-ids/sftp_si.py.id paramiko/sftp_handle.py paramiko/sftp_server.py paramiko/sftp_si.py modified files: README demo_windows.py paramiko/__init__.py 2004-11-22 07:07:08 GMT Robey Pointer <robey@lag.net> patch-112 Summary: add finish_subsystem() Revision: secsh--dev--1.0--patch-112 when a SubsystemHandler is being decomissioned (the client has closed the channel or transport, or the socket went away), make a callback to let the handler do any shutdown it needs to. modified files: paramiko/server.py 2004-11-22 07:04:31 GMT Robey Pointer <robey@lag.net> patch-111 Summary: fix extremely unlikely channel counter wrapping Revision: secsh--dev--1.0--patch-111 Transport's channel counter can overflow after 4 billion some channels are created. make it wrap back around after 16 million instead. also allow the logging channel to be set manually. fix some comments elsewhere. modified files: paramiko/channel.py paramiko/primes.py paramiko/transport.py 2004-11-22 07:01:43 GMT Robey Pointer <robey@lag.net> patch-110 Summary: fix Transport.get_username() to work in server mode too Revision: secsh--dev--1.0--patch-110 whenever i split the 'username' field into username and auth_username, i guess that made get_username() stop working for server mode (because the username was stored in a different field). this should fix it. modified files: paramiko/auth_transport.py 2004-11-07 03:10:53 GMT Robey Pointer <robey@lag.net> patch-109 Summary: v1.0 (jigglypuff) Revision: secsh--dev--1.0--patch-109 bump all the version numbers up to 1.0 (jigglypuff). modified files: Makefile README paramiko/__init__.py paramiko/transport.py setup.py 2004-11-07 02:51:42 GMT Robey Pointer <robey@lag.net> patch-108 Summary: add filename to SFTPAttributes Revision: secsh--dev--1.0--patch-108 add filename to the attributes stored in an SFTPAttributes object. modified files: paramiko/sftp_attr.py 2004-11-07 02:31:48 GMT Robey Pointer <robey@lag.net> patch-107 Summary: fix kex_gex Revision: secsh--dev--1.0--patch-107 fix kex_gex (group-exchange key exchange) to, *cough*, work again, and also layout kex_group1 a little more sanely. modified files: paramiko/kex_gex.py paramiko/kex_group1.py 2004-11-07 02:29:54 GMT Robey Pointer <robey@lag.net> patch-106 Summary: fix chmod +x on demo_windows.py Revision: secsh--dev--1.0--patch-106 forgot to make demo_windows +x 2004-11-07 02:29:20 GMT Robey Pointer <robey@lag.net> patch-105 Summary: move ChangeLog Revision: secsh--dev--1.0--patch-105 move ChangeLog out of the way because tla can autogenerate any useful ChangeLog. renamed files: .arch-ids/ChangeLog.id ==> .arch-ids/ChangeLog-old.id ChangeLog ==> ChangeLog-old 2004-11-07 02:28:33 GMT Robey Pointer <robey@lag.net> patch-104 Summary: fix location of SFTPError Revision: secsh--dev--1.0--patch-104 fix location of SFTPError. modified files: paramiko/__init__.py paramiko/sftp_client.py 2004-11-07 02:17:18 GMT Robey Pointer <robey@lag.net> patch-103 Summary: rename sftp constants Revision: secsh--dev--1.0--patch-103 replace oddly named sftp constants (FX_OK for example) with names that make a bit more sense when sober (SFTP_OK). modified files: paramiko/__init__.py paramiko/sftp.py paramiko/sftp_client.py 2004-11-07 02:08:11 GMT Robey Pointer <robey@lag.net> patch-102 Summary: add key exchange tests + 1 more sftp test Revision: secsh--dev--1.0--patch-102 add test suite for key-exchange protocols, since i apparently broke the "gex" protocol recently and never noticed. also add an sftp unit test for mkdir/rmdir. new files: tests/.arch-ids/test_kex.py.id tests/test_kex.py modified files: test.py tests/test_sftp.py 2004-11-07 02:00:50 GMT Robey Pointer <robey@lag.net> patch-101 Summary: remove old demo keys Revision: secsh--dev--1.0--patch-101 the keys are in tests/ now. removed files: .arch-ids/demo_dss_key.id .arch-ids/demo_rsa_key.id demo_dss_key demo_rsa_key 2004-11-06 20:32:08 GMT Robey Pointer <robey@lag.net> patch-100 Summary: don't forget demo_windows.py Revision: secsh--dev--1.0--patch-100 update MANIFEST.in to include demo_windows.py and not include the demo keys (they're in tests/ now). clean up the README to explain the demo scripts better now, since there are so many of them. then fix up the demo scripts to look in tests/ for the keys. demo_windows.py doesn't need to call get_pty() (in fact, i think that's blowing openssh's mind) and was executing the wrong command. modified files: MANIFEST.in README demo_server.py demo_simple.py demo_windows.py 2004-11-01 07:07:48 GMT Robey Pointer <robey@lag.net> patch-99 Summary: use getpass Revision: secsh--dev--1.0--patch-99 convert raw_input to getpass as suggested many weeks ago. modified files: forward.py 2004-11-01 03:54:01 GMT Robey Pointer <robey@lag.net> patch-98 Summary: don't unlink a Channel until the server closes it too Revision: secsh--dev--1.0--patch-98 when close()'ing a Channel, don't immediately unlink it from the Transport. instead, wait for the server to send a close message. this should fix a bug where doing close() on an EOF'd channel would cause the entire transport to be killed, because the server would send an 'exit-status' and 'close' message for a channel that we no longer had a record of. modified files: paramiko/channel.py 2004-11-01 03:43:28 GMT Robey Pointer <robey@lag.net> patch-97 Summary: better debugging, improve subsytem handler Revision: secsh--dev--1.0--patch-97 add a list of ssh packet names for debugging. improve the server-mode subsystem handler so it can take extra parameters (list or keyword) and pass them to the subsystem constructor. remove a misleading comment about rekeying (which was already implemented). modified files: paramiko/common.py paramiko/server.py paramiko/transport.py 2004-11-01 03:37:42 GMT Robey Pointer <robey@lag.net> patch-96 Summary: remove key.valid check Revision: secsh--dev--1.0--patch-96 oops! 'key.valid' no longer works -- catch the SSHException instead, and log it. modified files: paramiko/auth_transport.py 2004-10-23 07:36:23 GMT Robey Pointer <robey@lag.net> patch-95 Summary: ivysaur 0.9 Revision: secsh--dev--1.0--patch-95 update ivysaur release date, and add the list of changes to the README file. modified files: Makefile README paramiko/__init__.py 2004-10-20 16:52:51 GMT Robey Pointer <robey@lag.net> patch-94 Summary: start testing Transport Revision: secsh--dev--1.0--patch-94 the beginnings of tests for Transport. only the bare minimum is there right now. also started doc'ing things up to ivysaur. new files: .arch-ids/demo_windows.py.id demo_windows.py tests/.arch-ids/loop.py.id tests/.arch-ids/test_transport.py.id tests/loop.py tests/test_transport.py modified files: Makefile README paramiko/__init__.py setup.py test.py 2004-10-18 04:54:27 GMT Robey Pointer <robey@lag.net> patch-93 Summary: switch Transport.connect() to using a Pkey object for the host key Revision: secsh--dev--1.0--patch-93 i suddenly realized that passing "hostkeytype" and "hostkey" as strings to Transport.connect() was pretty silly since i went to all the effort of making a class specifically for holding keys. so Transport.connect() now just takes host-key argument: "hostkey" as a PKey object. updated the demos to use PKey objects when reading the host key file, and to use the new "hostkey" argument. modified files: demo.py demo_simple.py paramiko/pkey.py paramiko/transport.py 2004-09-25 22:07:59 GMT Robey Pointer <robey@lag.net> patch-92 Summary: add rsa/dss key object unit tests Revision: secsh--dev--1.0--patch-92 add tests for rsa/dss key objects -- yay! new files: tests/.arch-ids/test_dss.key.id tests/.arch-ids/test_pkey.py.id tests/.arch-ids/test_rsa.key.id tests/test_dss.key tests/test_pkey.py tests/test_rsa.key 2004-09-25 22:03:48 GMT Robey Pointer <robey@lag.net> patch-91 Summary: fix test.py to use options instead of env vars, sftp tests default off Revision: secsh--dev--1.0--patch-91 fix up the test framework so that the sftp unit tests aren't always run (you have to ask for them explicitly) and they take their configuration from command-line options. they still require a remote server. modified files: test.py tests/test_sftp.py 2004-09-25 21:58:11 GMT Robey Pointer <robey@lag.net> patch-90 Summary: fix __init__ Revision: secsh--dev--1.0--patch-90 fix __init__ to export BufferedFile and randpool, and to catch up with the changes from a week or 2 ago where sftp_attr & friends were split off. modified files: paramiko/__init__.py 2004-09-25 21:47:19 GMT Robey Pointer <robey@lag.net> patch-89 Summary: fix some Transport docs Revision: secsh--dev--1.0--patch-89 document that Transport also would like close() and settimeout() to exist on the socket-like object passed to the constructor. modified files: paramiko/transport.py 2004-09-25 21:32:53 GMT Robey Pointer <robey@lag.net> patch-88 Summary: add Message.rewind() Revision: secsh--dev--1.0--patch-88 add rewind() method to Message, which just resets the pointer so you can start reading from the beginning again. this is useful for some tests. modified files: paramiko/message.py tests/test_message.py 2004-09-25 21:28:23 GMT Robey Pointer <robey@lag.net> patch-87 Summary: clean up pkey interface Revision: secsh--dev--1.0--patch-87 change the pkey interface so that it's no longer possible to have a pkey that doesn't represent a valid key. (ie: no more "blank" key objects.) also add "get_bits" and "can_sign" methods to determine the key bit length and whether it can sign things (contains the "private parts") respectively. modified files: paramiko/dsskey.py paramiko/pkey.py paramiko/rsakey.py 2004-09-11 21:01:32 GMT Robey Pointer <robey@lag.net> patch-86 Summary: unit tests for Message Revision: secsh--dev--1.0--patch-86 spanking new unit tests for Message. i'm trying to fix the embarrassment of having so little of paramiko testable. next up is Transport! new files: tests/.arch-ids/test_message.py.id tests/test_message.py 2004-09-11 20:56:01 GMT Robey Pointer <robey@lag.net> patch-85 Summary: move SFTPFile and SFTPAttributes into their own files Revision: secsh--dev--1.0--patch-85 move SFTPFile and SFTPAttributes into their own files. new files: paramiko/.arch-ids/sftp_attr.py.id paramiko/.arch-ids/sftp_file.py.id paramiko/sftp_attr.py paramiko/sftp_file.py modified files: paramiko/sftp.py paramiko/sftp_client.py 2004-09-11 20:50:39 GMT Robey Pointer <robey@lag.net> patch-84 Summary: add sftp.normalize Revision: secsh--dev--1.0--patch-84 kevin c. dorff pointed out that it would be nice to expose a way to determine the server's "current working directory", so this new method (normalize) directly maps to REALPATH. modified files: paramiko/sftp_client.py 2004-09-11 20:43:09 GMT Robey Pointer <robey@lag.net> patch-83 Summary: tweak Message.add() in the key exchanges Revision: secsh--dev--1.0--patch-83 use the new Message.add() behavior to make a little code here much easier to read. modified files: paramiko/kex_gex.py paramiko/kex_group1.py 2004-09-11 20:40:08 GMT Robey Pointer <robey@lag.net> patch-82 Summary: doc fixes Revision: secsh--dev--1.0--patch-82 fix "string" -> "str" in types when documenting BufferedFile. modified files: paramiko/file.py 2004-09-11 20:37:59 GMT Robey Pointer <robey@lag.net> patch-81 Summary: more unit tests Revision: secsh--dev--1.0--patch-81 add test for BufferedFile.read(-1) and sftp.normalize(). modified files: tests/test_file.py tests/test_sftp.py 2004-09-11 20:36:49 GMT Robey Pointer <robey@lag.net> patch-80 Summary: move SubsystemHandler to server.py Revision: secsh--dev--1.0--patch-80 move SubsystemHandler into server.py where it makes more sense (it's part of the server interface). also fix up paramiko's "version string" used in ssh2 negotiation to stop saying "pyssh" and start saying "paramiko". :) modified files: paramiko/server.py paramiko/transport.py 2004-09-11 20:35:19 GMT Robey Pointer <robey@lag.net> patch-79 Summary: Message.add() can take many args Revision: secsh--dev--1.0--patch-79 a bit of cleanup to Message: add() can now take any number of params, and will add them all in order (using type guessing). modified files: paramiko/message.py 2004-09-09 01:36:45 GMT Robey Pointer <robey@lag.net> patch-78 Summary: fix rbuffer -> _rbuffer in 3 places i missed Revision: secsh--dev--1.0--patch-78 fix 3 places where "rbuffer" hadn't been converted to "_rbuffer". thanks to kevin c. dorff for the bug report. modified files: paramiko/file.py 2004-09-07 06:56:49 GMT Robey Pointer <robey@lag.net> patch-77 Summary: docs for SubsystemHandler Revision: secsh--dev--1.0--patch-77 add documentation to constructor for SubsystemHandler. modified files: paramiko/transport.py 2004-09-07 06:54:31 GMT Robey Pointer <robey@lag.net> patch-76 Summary: add sftp_client.py Revision: secsh--dev--1.0--patch-76 i retardedly forgot to import this file a few days ago: it's the split-out client mode for sftp. it now also has some changes to adapt it to the improved SFTPAttributes object API. new files: paramiko/.arch-ids/sftp_client.py.id paramiko/sftp_client.py 2004-09-07 06:51:03 GMT Robey Pointer <robey@lag.net> patch-75 Summary: clean up SFTPAttributes Revision: secsh--dev--1.0--patch-75 add english descriptions to the FX_* error codes of sftp. clean up (and document) SFTPAttributes since it's exported now, and make it simple to generate one from a python os.stat object. make "_pythonize" the default -- that is, just use the same field names as python does for os.stat. (i'm not sure why i didn't do it that way in the first place; probably ignorance.) also add str() method that converts the SFTPAttributes into a string suitable for use in ls (used in an obscure way in sftp servers). modified files: paramiko/sftp.py 2004-09-07 06:45:53 GMT Robey Pointer <robey@lag.net> patch-74 Summary: note pycrypto 2.0 in README Revision: secsh--dev--1.0--patch-74 update the README to note that pycrypto 2.0 works (i just tried it). also fix the name from pyCrypt back to pycrypto -- that project is having trouble making up its mind about naming. :) modified files: README 2004-09-05 07:44:03 GMT Robey Pointer <robey@lag.net> patch-73 Summary: split sftp into sftp, sftp_client; renamed SFTP -> SFTPClient Revision: secsh--dev--1.0--patch-73 add sftp_client file, and split out the common code (sftp) from stuff specific to client mode (sftp_client). renamed SFTP class to SFTPClient, but left an alias so old code will still work. renamed a bunch of sftp constants now that they're better hidden from epydoc. modified files: README paramiko/__init__.py paramiko/sftp.py 2004-09-05 07:41:45 GMT Robey Pointer <robey@lag.net> patch-72 Summary: some framework for adding subsystem handlers in server mode Revision: secsh--dev--1.0--patch-72 you can now register a subsystem with a Transport by passing in the name (like "sftp") and a class (like a hypothetical SFTPServer). the default ServerInterface.check_channel_request_subsystem now checks this table in Transport, and if it finds a match, it creates a new thread for the handler and calls into it. a new class SubsystemHandler is added for this purpose (to be subclassed). modified files: paramiko/server.py paramiko/transport.py 2004-09-05 07:37:40 GMT Robey Pointer <robey@lag.net> patch-71 Summary: remove redundant 'auth_complete' member Revision: secsh--dev--1.0--patch-71 remove the redundant 'auth_complete' field and just use 'authenticated' for both client and server mode. this makes the repr() string look correct in server mode instead of always claiming that the transport is un-auth'd. modified files: paramiko/auth_transport.py 2004-09-03 22:39:20 GMT Robey Pointer <robey@lag.net> patch-70 Summary: clean up server interface; no longer need to subclass Channel Revision: secsh--dev--1.0--patch-70 - export AUTH_*, OPEN_FAILED_*, and the new OPEN_SUCCEEDED into the paramiko namespace instead of making people dig into paramiko.Transport.AUTH_* etc. - move all of the check_* methods from Channel to ServerInterface so apps don't need to subclass Channel anymore just to run an ssh server - ServerInterface.check_channel_request() returns an error code now, not a new Channel object - fix demo_server.py to follow all these changes - fix a bunch of places where i used "string" in docstrings but meant "str" - added Channel.get_id() modified files: README demo_server.py paramiko/__init__.py paramiko/auth_transport.py paramiko/channel.py paramiko/common.py paramiko/server.py paramiko/sftp.py paramiko/transport.py 2004-08-31 02:44:56 GMT Robey Pointer <robey@lag.net> patch-69 Summary: clean up SecurityOptions Revision: secsh--dev--1.0--patch-69 the preferences are now tuples in Transport, and passed as tuples out of SecurityOptions, so that the options can't be modified without setting them back to the options field again. the algorithm lists in Transport are used to validate the fields. modified files: paramiko/transport.py 2004-08-30 20:22:10 GMT Robey Pointer <robey@lag.net> patch-68 Summary: added Transport.get_security_options() Revision: secsh--dev--1.0--patch-68 just something i wanted to play with: added Transport.get_security_options() which returns a SecurityOptions object. this object is a kind of proxy for the 4 "preferred_*" fields in Transport, and lets me avoid exposing those fields directly in case i change my mind later about how they should be stored. added some docs to Channel explaining that the request methods now return True/False, and fixed up docs in a few other places. modified files: paramiko/__init__.py paramiko/channel.py paramiko/server.py paramiko/sftp.py paramiko/transport.py 2004-08-28 04:21:12 GMT Robey Pointer <robey@lag.net> patch-67 Summary: replay patch 63 (missing channel changes) Revision: secsh--dev--1.0--patch-67 i'm still getting the hang of tla/arch, obviously. replay patch 63, which was meant to be part of the later mega-patch, but apparently when i reversed it, i lost it entirely. modified files: paramiko/channel.py 2004-08-27 00:57:40 GMT Robey Pointer <robey@lag.net> patch-66 Summary: new ServerInterface class, outbound rekey works, etc. Revision: secsh--dev--1.0--patch-66 a bunch of changes that i'm too lazy to split out into individual patches: * all the server overrides from transport.py have been moved into a separate class ServerInterface, so server code doesn't have to subclass the whole paramiko library * updated demo_server to subclass ServerInterface * when re-keying during a session, block other messages until the new keys are activated (openssh doensn't like any other traffic during a rekey) * re-key when outbound limits are tripped too (was only counting inbound traffic) * don't log scary things on EOF new files: paramiko/.arch-ids/server.py.id paramiko/server.py modified files: README demo_server.py paramiko/__init__.py paramiko/auth_transport.py paramiko/transport.py 2004-08-27 00:28:33 GMT Robey Pointer <robey@lag.net> patch-65 Summary: add settimeout/gettimeout/setblocking, some bugfixes. Revision: secsh--dev--1.0--patch-65 hide the command and response codes in sftp so they aren't exported. add settimeout/gettimeout/setblocking that just wrap calls to the underlying socket or channel. fix _read_all to not catch timeout exceptions. modified files: paramiko/sftp.py 2004-08-27 00:26:35 GMT Robey Pointer <robey@lag.net> patch-64 Summary: reverse messed-up patch Revision: secsh--dev--1.0--patch-64 Patches applied: * robey@lag.net--2003-public/secsh--dev--1.0--base-0 initial import * robey@lag.net--2003-public/secsh--dev--1.0--patch-1 no changes modified files: paramiko/channel.py {arch}/=tagging-method 2004-08-27 00:06:42 GMT Robey Pointer <robey@lag.net> patch-63 Summary: add settimeout/gettimeout/setblocking, some bugfixes. Revision: secsh--dev--1.0--patch-63 hide the command and response codes in sftp so they aren't exported. add settimeout/gettimeout/setblocking that just wrap calls to the underlying socket or channel. fix _read_all to not catch timeout exceptions. modified files: paramiko/channel.py 2004-06-27 20:14:15 GMT Robey Pointer <robey@lag.net> patch-62 Summary: version -> horsea Revision: secsh--dev--1.0--patch-62 up version to horsea. modified files: Makefile README paramiko/__init__.py setup.py {arch}/secsh/secsh--dev/secsh--dev--1.0/robey@lag.net--2003-public/patch-log/patch-1 2004-06-10 18:12:00 GMT Robey Pointer <robey@lag.net> patch-61 Summary: no more Foobar Revision: secsh--dev--1.0--patch-61 fix "Foobar" to be "Paramiko" in the one place i missed it in all the gpl headers. sigh. :) modified files: paramiko/__init__.py paramiko/auth_transport.py paramiko/ber.py paramiko/common.py paramiko/dsskey.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/logging22.py paramiko/message.py paramiko/pkey.py paramiko/primes.py paramiko/rsakey.py paramiko/ssh_exception.py paramiko/util.py test.py 2004-06-10 18:08:50 GMT Robey Pointer <robey@lag.net> patch-60 Summary: limit read/write requests to 32KB, advertise 32KB max packet size Revision: secsh--dev--1.0--patch-60 one of the unit tests was failing because the openssh sftp server was dropping the connection without any error. turns out they have a maximum allowed write size (possibly around 64KB). the sftp rfcs have a small hint that some servers may drop read/write requests of greater than 32KB. so, all reads are limited to 32KB, and all writes > 32KB are now chopped up and sent in 32KB chunks. this seems to keep openssh happy. also, we now advertise 32KB max packet size instead of 8KB (the speed improves a lot), and log when we read/write a packet. and sftp files are flushed on seek. modified files: paramiko/sftp.py paramiko/transport.py 2004-06-10 18:02:13 GMT Robey Pointer <robey@lag.net> patch-59 Summary: speed up parts of BufferedFile Revision: secsh--dev--1.0--patch-59 BufferedFile uses cStringIO for the write buffer now (i don't actually notice any speed difference so this might revert later) and the default buffer size has been upped from 1KB to 8KB. when scanning for linefeeds (when writing to a line-buffered file), only scan the newly-written bytes, since we know all the previously buffered data is linefeed-free. this was the #1 slowdown on the 1MB-file unit test. also, limit the buffering on line-buffered files to whatever the default buffer size is. there's no reason to buffer 1MB waiting for a linefeed. modified files: paramiko/file.py 2004-06-10 17:55:17 GMT Robey Pointer <robey@lag.net> patch-58 Summary: some Channel fixes for max packet size & blocking on zero window Revision: secsh--dev--1.0--patch-58 some clean-ups and fixes to channels: * when send() is blocked on a zero-width window, check that the channel is still open. this was causing some lockups. * set a lower bound to the "maximum packet size" we accept from the remote host. if they tell us anything less than 1KB, assume they meant 1KB. (it's not reasonable to fragment below that.) * leave a little padding instead of cutting right up to the maximum packet size: some space will be taken up by protocol overhead. * turn off some of the debug log lines unless "ultra_debug" is on (nobody cares about the feed info) modified files: paramiko/channel.py 2004-06-10 17:35:30 GMT Robey Pointer <robey@lag.net> patch-57 Summary: more unit tests Revision: secsh--dev--1.0--patch-57 add a unit test for sending a large (1MB) file with line buffering but no linefeeds (this triggered several bugs and inefficiencies), and another test to verify that the write buffer is flushed on seek. modified files: tests/test_file.py tests/test_sftp.py 2004-05-31 23:48:10 GMT Robey Pointer <robey@lag.net> patch-56 Summary: add forward.py demo script; bump to gyarados Revision: secsh--dev--1.0--patch-56 add a demo script to show how to do local port forwarding. add gyarados to all the docs and bump the version number everywhere. new files: .arch-ids/forward.py.id forward.py modified files: MANIFEST.in Makefile README paramiko/__init__.py setup.py 2004-05-29 18:58:11 GMT Robey Pointer <robey@lag.net> patch-55 Summary: add an sftp unit test for making 100 files Revision: secsh--dev--1.0--patch-55 create 100 files on the remote server, set their mode with chmod, then verify that they're all there and contain the right data. valeriy is reporting that sometimes he's getting stuck after 20 and though i'm not seeing it, i want to add a test to try to pin it down. modified files: tests/test_sftp.py 2004-05-29 18:56:10 GMT Robey Pointer <robey@lag.net> patch-54 Summary: add direct-tcpip ability to open_channel Revision: secsh--dev--1.0--patch-54 open_channel can now be given a dest_addr and src_addr, which are filled in if the channel type is "forwarded-tcpip" or "direct-tcpip". these channel types are used in remote & local port forwarding, respectively. i've only tested "direct-tcpip" but i think if one works, they both should work. also fixed a bug in connect where it was still assuming the old meaning for get_remove_server_key() (oops!) and changed the sense of a send() failure from <= 0 to < 0 since it may be possible for send() to return 0 and it not be an EOF error. modified files: paramiko/transport.py 2004-05-29 18:48:23 GMT Robey Pointer <robey@lag.net> patch-53 Summary: add note about utf8 encodings Revision: secsh--dev--1.0--patch-53 add info to the README about what to do if python complains about missing encodings. veleriy pogrebitskiy ran into this and had advice. modified files: README 2004-05-17 07:41:50 GMT Robey Pointer <robey@lag.net> patch-52 Summary: fix deadlock in closing a channel Revision: secsh--dev--1.0--patch-52 closing a channel would enter an odd codepath where the lock was grabbed, some stuff was done, then another function was called where the lock was grabbed again. unfortunately python locks aren't monitors so this would deadlock. instead, make the smaller function lock-free with an explicit notice that you must be holding the lock before calling. modified files: paramiko/channel.py 2004-05-17 00:43:43 GMT Robey Pointer <robey@lag.net> patch-51 Summary: fix utf8, raise packet size, log exceptions, be more lax with sfp servers Revision: secsh--dev--1.0--patch-51 explicitly import utf8 encodings for "freezing" (and also because not all platforms come with utf8, apparently). raise the max acceptable packet size to 8kB, cuz 2kB was too low. log exceptions at error level instead of debug level. and don't reject older sftp servers. modified files: paramiko/auth_transport.py paramiko/sftp.py paramiko/transport.py 2004-04-23 22:55:16 GMT Robey Pointer <robey@lag.net> patch-50 Summary: fearow date and last-minute fixes Revision: secsh--dev--1.0--patch-50 update release date of fearow to 23apr. fix channel._set_closed() to grab the lock before notifying the in/out buffers that the channel is closed. try roger's trick for finding the home folder on windows. modified files: Makefile README paramiko/__init__.py paramiko/channel.py paramiko/common.py 2004-04-08 06:31:08 GMT Robey Pointer <robey@lag.net> patch-49 Summary: fix doc typos Revision: secsh--dev--1.0--patch-49 modified files: paramiko/dsskey.py paramiko/rsakey.py paramiko/transport.py 2004-04-08 05:48:16 GMT Robey Pointer <robey@lag.net> patch-48 Summary: set version number to fearow Revision: secsh--dev--1.0--patch-48 set version number to fearow. modified files: Makefile README paramiko/__init__.py setup.py 2004-04-08 05:12:20 GMT Robey Pointer <robey@lag.net> patch-47 Summary: add socket.timeout for py22 Revision: secsh--dev--1.0--patch-47 oops, forgot this vital part of the py22 patches. roger binns sent me a code patch that included this snip. modified files: paramiko/common.py 2004-04-07 16:05:48 GMT Robey Pointer <robey@lag.net> patch-46 Summary: README update notes Revision: secsh--dev--1.0--patch-46 added notes on what's new, what to watch out for in py22. added a "since: fearow" to all the relevant API calls that are new. modified files: README paramiko/auth_transport.py paramiko/dsskey.py paramiko/pkey.py paramiko/rsakey.py paramiko/transport.py 2004-04-07 15:52:07 GMT Robey Pointer <robey@lag.net> patch-45 Summary: add set_keepalive() Revision: secsh--dev--1.0--patch-45 add set_keepalive() to set an automatic keepalive mechanism. (while waiting for a packet on a connection, we periodically check if it's time to send a keepalive packet.) modified files: paramiko/transport.py 2004-04-07 06:07:29 GMT Robey Pointer <robey@lag.net> patch-44 Summary: add get_username() method for remembering who you auth'd as Revision: secsh--dev--1.0--patch-44 add get_username() method for remembering who you auth'd as. also, fix these bugs: * "continue" auth response counted as a failure (in server mode). * try to import 'logging' in py22 before falling back to the fake logger, in case they have a backported version of 'logger' * raise the right exception when told to read a private key from a file that isn't a private key file * tell channels to close when the transport dies modified files: paramiko/auth_transport.py paramiko/channel.py paramiko/common.py paramiko/pkey.py paramiko/transport.py 2004-04-06 22:03:21 GMT Robey Pointer <robey@lag.net> patch-43 Summary: fix encrypted private key files Revision: secsh--dev--1.0--patch-43 the random byte padding on private key files' BER data was confusing openssh, so switch to null-byte padding, which is slightly less secure but works with crappy old openssh. also, enforce the mode when writing the private key file. we really really want it to be 0600. (python seems to ignore the mode normally.) modified files: paramiko/pkey.py 2004-04-06 08:16:02 GMT Robey Pointer <robey@lag.net> patch-42 Summary: support py22, more or less Revision: secsh--dev--1.0--patch-42 add roger binns' patches for supporting python 2.2. i hedged a bit on the logging stuff and just added some trickery to let logging be stubbed out for python 2.2. this changed a lot of import statements but i managed to avoid hacking at any of the existing logging. socket timeouts are required for the threads to notice when they've been deactivated. worked around it by using the 'select' module on py22. also fixed the sftp unit tests to cope with a password-protected private key. new files: paramiko/.arch-ids/logging22.py.id paramiko/logging22.py modified files: README demo.py demo_server.py demo_simple.py paramiko/__init__.py paramiko/auth_transport.py paramiko/channel.py paramiko/common.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/message.py paramiko/sftp.py paramiko/transport.py paramiko/util.py tests/test_sftp.py 2004-04-05 22:32:03 GMT Robey Pointer <robey@lag.net> patch-41 Summary: make get_remote_server_key() return a PKey object Revision: secsh--dev--1.0--patch-41 a good suggestion from roger binns: make get_remote_server_key() just return a pkey object instead of a tuple of strings. all the strings can be extracted from the pkey object, as well as other potentially useful things. modified files: demo.py paramiko/transport.py 2004-04-05 19:36:40 GMT Robey Pointer <robey@lag.net> patch-40 Summary: add dss key generation too, and fix some bugs Revision: secsh--dev--1.0--patch-40 added the ability to generate dss keys and write private dss key files, similar to rsa. in the process, fixed a couple of bugs with ber encoding and writing password-encrypted key files. the key has to be padded to the iblock size of the cipher -- it's very difficult to determine how the others do this, so i just add random bytes to the end. fixed the simple demo to use Transport's (host, port) constructor for simplicity, and fixed a bug where the standard demo's DSS login wouldn't work. also, move the common logfile setup crap into util so all the demos can just call that one. modified files: demo.py demo_simple.py paramiko/ber.py paramiko/dsskey.py paramiko/pkey.py paramiko/rsakey.py paramiko/util.py 2004-04-05 10:37:18 GMT Robey Pointer <robey@lag.net> patch-39 Summary: add global request mechanism Revision: secsh--dev--1.0--patch-39 add transport.global_request() to make a global-style request (usually an extension to the protocol -- like keepalives) and handle requests from the remote host. incoming requests are now handled and responded to correctly, which should make openssh-style keepalives work. (before, we would silently ignore them, which was wrong.) modified files: paramiko/common.py paramiko/message.py paramiko/transport.py 2004-04-05 10:24:33 GMT Robey Pointer <robey@lag.net> patch-38 Summary: add common.py file Revision: secsh--dev--1.0--patch-38 missing from previous change because tla doesn't like to add files in some situations. (frown) new files: paramiko/.arch-ids/common.py.id paramiko/common.py 2004-04-05 10:16:31 GMT Robey Pointer <robey@lag.net> patch-37 Summary: can now generate rsa keys (not dss yet) Revision: secsh--dev--1.0--patch-37 added functionality to ber to create ber streams. added some common methods to PKey to allow dumping the key to base64 (the format used by openssh for public key files and host key lists), and a factory for creating a key from a private key file, and a common way to save private keys. RSAKey luckily didn't have to change that much. also added a factory method to RSAKey to generate a new key. modified files: paramiko/ber.py paramiko/pkey.py paramiko/rsakey.py 2004-04-05 10:12:59 GMT Robey Pointer <robey@lag.net> patch-36 Summary: add common.py for commonly used constants and globals Revision: secsh--dev--1.0--patch-36 common.py now stores the constants and globals. lots of renaming because of this. modified files: paramiko/auth_transport.py paramiko/channel.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/transport.py paramiko/util.py 2004-04-02 02:41:43 GMT Robey Pointer <robey@lag.net> patch-35 Summary: add send_ignore Revision: secsh--dev--1.0--patch-35 add send_ignore() call to allow for sending garbage ignored packets to the remote side. modified files: paramiko/transport.py 2004-03-16 07:33:09 GMT Robey Pointer <robey@lag.net> patch-34 Summary: fix some arcana in unpacking private keys Revision: secsh--dev--1.0--patch-34 "!= type([])" is a pretty obscure way to say it. let's try "is not list" which is a lot more readable. (mostly this is a test to make sure tla is working okay on my laptop.) modified files: paramiko/dsskey.py paramiko/rsakey.py 2004-03-09 01:09:17 GMT Robey Pointer <robey@lag.net> patch-33 Summary: include tests in manifest Revision: secsh--dev--1.0--patch-33 include the tests in the manifest for dist, and remove some outdated notes in NOTES about the exported API (this is doc'd wayyy better in epydoc now). modified files: MANIFEST.in NOTES 2004-03-08 17:54:19 GMT Robey Pointer <robey@lag.net> patch-32 Summary: add unit tests Revision: secsh--dev--1.0--patch-32 add unit tests for BufferedFile and SFTP (it's a start). remove the demo sftp client because it was 99% copied from the other demos, which makes it kinda confusing. the unit tests are a much better example. new files: .arch-ids/test.py.id test.py tests/.arch-ids/=id tests/.arch-ids/test_file.py.id tests/.arch-ids/test_sftp.py.id tests/test_file.py tests/test_sftp.py removed files: .arch-ids/demo_sftp.py.id demo_sftp.py new directories: tests tests/.arch-ids 2004-03-08 17:52:25 GMT Robey Pointer <robey@lag.net> patch-31 Summary: bump version number to eevee Revision: secsh--dev--1.0--patch-31 bump the version number to eevee in a few places and talk about the unit tests. modified files: Makefile README paramiko/__init__.py setup.py 2004-03-08 17:50:49 GMT Robey Pointer <robey@lag.net> patch-30 Summary: finish up client sftp support Revision: secsh--dev--1.0--patch-30 added 'stat' to SFTPFile and SFTP, documented 'open' and 'listdir', and added 'rmdir', 'lstat', 'symlink', 'chmod', 'chown', 'utime', 'readlink'. turned off ultra debugging now that the unit tests are all working. modified files: paramiko/sftp.py 2004-03-08 17:45:44 GMT Robey Pointer <robey@lag.net> patch-29 Summary: fix some docs and BufferedFile.readline Revision: secsh--dev--1.0--patch-29 fix some documentation and fix readline()'s universal newline support to always return strings ending with '\n', regardless of how they were in the original file. (this is an obvious feature of python's universal newline support that i somehow missed before.) modified files: paramiko/file.py paramiko/message.py 2004-03-08 09:47:47 GMT Robey Pointer <robey@lag.net> patch-28 Summary: fix lingering thread bug Revision: secsh--dev--1.0--patch-28 this bug has been in there forever and i could never figure out a workaround till now. when the python interpreter exits, it doesn't necessarily destroy the remaining objects or call __del__ on anything, and it will lock up until all threads finish running. how the threads are supposed to notice the exiting interpreter has always been sort of a mystery to me. tonight i figured out how to use the 'atexit' module to register a handler that runs when the interpreter exits. now we keep a list of active threads and ask them all to exit on shutdown. no more going to another shell to kill -9 python! yeah!! modified files: paramiko/transport.py 2004-03-04 08:21:45 GMT Robey Pointer <robey@lag.net> patch-27 Summary: add BufferedFile abstraction Revision: secsh--dev--1.0--patch-27 SFTP client mode is mostly functional. there are probably still some bugs but most of the operations on "file" objects have survived my simple tests. BufferedFile wraps a simpler stream in something that looks like a python file (and can even handle seeking if the stream underneath supports it). it's meant to be subclassed. most of it is ripped out of what used to be ChannelFile so i can reuse it for sftp -- ChannelFile is now tiny. SFTP and Message are now exported. fixed util.format_binary_line to not quote spaces. new files: .arch-ids/demo_sftp.py.id demo_sftp.py paramiko/.arch-ids/file.py.id paramiko/.arch-ids/sftp.py.id paramiko/file.py paramiko/sftp.py modified files: paramiko/__init__.py paramiko/channel.py paramiko/message.py paramiko/util.py 2004-01-27 02:04:59 GMT Robey Pointer <robey@lag.net> patch-26 Summary: Transport constructor can take hostname or address tuple Revision: secsh--dev--1.0--patch-26 part of an ongoing attempt to make "simple" versions of some of the API calls, so you can do common-case operations with just a few calls: Transport's constructor will now let you pass in a string or tuple instead of a socket-like object. if you pass in a string, it assumes the string is a hostname (with optional ":port" segment) and turns that into an address tuple. if you pass in a tuple, it assumes it's an address tuple. in both cases, it then creates a socket, connects to the given address, and then continues as if that was the socket passed in. the idea being that you can call Transport('example.com') and it will do the right thing. modified files: paramiko/transport.py 2004-01-27 02:00:19 GMT Robey Pointer <robey@lag.net> patch-25 Summary: pkey no longer raises binascii.Error Revision: secsh--dev--1.0--patch-25 catch binascii.Error in the private key decoder and convert it into an SSHException. there's no reason people should have to care that it was a decoding error vs. any of the other million things that could be wrong in a corrupt key file. modified files: paramiko/pkey.py 2004-01-27 01:45:44 GMT Robey Pointer <robey@lag.net> patch-24 Summary: document more of Message; add get_int64 Revision: secsh--dev--1.0--patch-24 all of the get_* methods are now documented, but there's a bit more to do. get_int64 added for eventual sftp support. modified files: paramiko/message.py 2004-01-04 10:33:05 GMT Robey Pointer <robey@lag.net> patch-23 Summary: quick doc fix. Revision: secsh--dev--1.0--patch-23 fix broken cross-link in kex_gex docs. modified files: paramiko/kex_gex.py 2004-01-04 10:26:00 GMT Robey Pointer <robey@lag.net> patch-22 Summary: fix MANIFEST.in, change version numbers to 0.9-doduo, fix LPGL notices Revision: secsh--dev--1.0--patch-22 fixed MANIFEST.in to include the demo scripts, LICENSE, and ChangeLog. upped everything to version 0.9-doduo. fixed the copyright notice, and added the LGPL banner to the top of every python file. modified files: MANIFEST.in Makefile NOTES README paramiko/__init__.py paramiko/auth_transport.py paramiko/ber.py paramiko/channel.py paramiko/dsskey.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/message.py paramiko/pkey.py paramiko/primes.py paramiko/rsakey.py paramiko/ssh_exception.py paramiko/transport.py paramiko/util.py setup.py 2004-01-04 10:07:35 GMT Robey Pointer <robey@lag.net> patch-21 Summary: MANIFEST -> MANIFEST.in, fix setup.py. Revision: secsh--dev--1.0--patch-21 out with MANIFEST, in with MANIFEST.in. new files: .arch-ids/MANIFEST.in.id MANIFEST.in removed files: .arch-ids/MANIFEST.id MANIFEST modified files: setup.py 2004-01-04 09:29:13 GMT Robey Pointer <robey@lag.net> patch-20 Summary: more docs, and password-protected key files can now be read Revision: secsh--dev--1.0--patch-20 lots more documentation, some of it moved out of the README file, which is now much smaller and less rambling. repr(Transport) now reports the number of bits used in the cipher. cleaned up BER to use util functions, and throw a proper exception (the new BERException) on error. it doesn't ever have to be a full BER decoder, but it can at least comb its hair and tuck in its shirt. lots of stuff added to PKey.read_private_key_file so it can try to decode password-protected key files. right now it only understands "DES-EDE3-CBC" format, but this is the only format i've seen openssh make so far. if the key is password-protected, but no password was given, a new exception (PasswordRequiredException) is raised so an outer layer can ask for a password and try again. modified files: README demo.py demo_server.py paramiko/__init__.py paramiko/auth_transport.py paramiko/ber.py paramiko/channel.py paramiko/dsskey.py paramiko/pkey.py paramiko/primes.py paramiko/rsakey.py paramiko/ssh_exception.py paramiko/transport.py paramiko/util.py 2003-12-31 06:31:43 GMT Robey Pointer <robey@lag.net> patch-19 Summary: renamed auth_key -> auth_publickey; more docs. Revision: secsh--dev--1.0--patch-19 renamed Transport.auth_key to auth_publickey for consistency. and lots more documentation. modified files: README demo.py demo_server.py paramiko/__init__.py paramiko/auth_transport.py paramiko/transport.py 2003-12-30 22:24:21 GMT Robey Pointer <robey@lag.net> patch-18 Summary: added public-key support to server mode, more docs Revision: secsh--dev--1.0--patch-18 added public-key support to server mode (it can now verify a client signature) and added a demo of that to the demo_server.py script (user_rsa_key). in the process, cleaned up the API of PKey so that now it only has to know about signing and verifying ssh2 blobs, and can be hashed and compared with other keys (comparing & hashing only the public parts of the key). keys can also be created from strings now too. some more documentation and hiding private methods. new files: .arch-ids/user_rsa_key.id .arch-ids/user_rsa_key.pub.id user_rsa_key user_rsa_key.pub modified files: Makefile demo_server.py paramiko/__init__.py paramiko/auth_transport.py paramiko/dsskey.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/pkey.py paramiko/rsakey.py paramiko/transport.py 2003-12-30 07:18:20 GMT Robey Pointer <robey@lag.net> patch-17 Summary: lots more documentation, and added Transport.connect() Revision: secsh--dev--1.0--patch-17 renamed demo_host_key to demo_rsa_key. moved changelog to a separate file, and indicated that future changelog entries should be fetched from tla. tried to clean up "__all__" in a way that makes epydoc still work. added lots more documentation, and renamed many methods and vars to hide them as private non-exported API. Transport's ModulusPack is now a static member, so it only has to be loaded once, and can then be used by any future Transport object. added Transport.connect(), which tries to wrap all the SSH2 negotiation and authentication into one method. you should be able to create a Transport, call connect(), and then create channels. new files: .arch-ids/ChangeLog.id .arch-ids/demo_simple.py.id ChangeLog demo_simple.py paramiko/.arch-ids/pkey.py.id paramiko/pkey.py removed files: .arch-ids/paramiko.py.id paramiko.py modified files: Makefile NOTES README demo.py demo_server.py paramiko/__init__.py paramiko/auth_transport.py paramiko/channel.py paramiko/dsskey.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/rsakey.py paramiko/transport.py setup.py {arch}/=tagging-method renamed files: .arch-ids/demo_host_key.id ==> .arch-ids/demo_rsa_key.id demo_host_key ==> demo_rsa_key 2003-12-28 03:20:42 GMT Robey Pointer <robey@lag.net> patch-16 Summary: hook up server-side kex-gex; add more documentation Revision: secsh--dev--1.0--patch-16 group-exchange kex should work now on the server side. it will only be advertised if a "moduli" file has been loaded (see the -gasp- docs) so we don't spend hours (literally. hours.) computing primes. some of the logic was previously wrong, too, since it had never been tested. fixed repr() string for Transport/BaseTransport. moved is_authenticated to Transport where it belongs. added lots of documentation (but still only about 10% documented). lots of methods were made private finally. new files: paramiko/.arch-ids/primes.py.id paramiko/primes.py modified files: NOTES demo.py demo_server.py paramiko/__init__.py paramiko/auth_transport.py paramiko/channel.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/transport.py paramiko/util.py 2003-12-27 02:03:44 GMT Robey Pointer <robey@lag.net> patch-15 Summary: fix up new paramiko/ folder. Revision: secsh--dev--1.0--patch-15 moved SSHException to a new file (ssh_exception.py) and turned paramiko.py into an __init__.py file. i'm still not entirely sure how this normally works, so i may have done something wrong, but it's supposed to work the same as before. new files: paramiko/.arch-ids/__init__.py.id paramiko/.arch-ids/ssh_exception.py.id paramiko/__init__.py paramiko/ssh_exception.py modified files: paramiko/auth_transport.py paramiko/channel.py paramiko/dsskey.py paramiko/kex_gex.py paramiko/kex_group1.py paramiko/transport.py 2003-12-27 01:49:19 GMT Robey Pointer <robey@lag.net> patch-14 Summary: move the paramiko files into a paramiko/ folder. Revision: secsh--dev--1.0--patch-14 just moving the files into a folder. it won't build this way yet. new files: paramiko/.arch-ids/=id renamed files: .arch-ids/auth_transport.py.id ==> paramiko/.arch-ids/auth_transport.py.id .arch-ids/ber.py.id ==> paramiko/.arch-ids/ber.py.id .arch-ids/channel.py.id ==> paramiko/.arch-ids/channel.py.id .arch-ids/dsskey.py.id ==> paramiko/.arch-ids/dsskey.py.id .arch-ids/kex_gex.py.id ==> paramiko/.arch-ids/kex_gex.py.id .arch-ids/kex_group1.py.id ==> paramiko/.arch-ids/kex_group1.py.id .arch-ids/message.py.id ==> paramiko/.arch-ids/message.py.id .arch-ids/rsakey.py.id ==> paramiko/.arch-ids/rsakey.py.id .arch-ids/transport.py.id ==> paramiko/.arch-ids/transport.py.id .arch-ids/util.py.id ==> paramiko/.arch-ids/util.py.id auth_transport.py ==> paramiko/auth_transport.py ber.py ==> paramiko/ber.py channel.py ==> paramiko/channel.py dsskey.py ==> paramiko/dsskey.py kex_gex.py ==> paramiko/kex_gex.py kex_group1.py ==> paramiko/kex_group1.py message.py ==> paramiko/message.py rsakey.py ==> paramiko/rsakey.py transport.py ==> paramiko/transport.py util.py ==> paramiko/util.py new directories: paramiko paramiko/.arch-ids 2003-12-24 22:09:43 GMT Robey Pointer <robey@lag.net> patch-13 Summary: fix a deadlock/race in handle_eof & close Revision: secsh--dev--1.0--patch-13 (patch from fred gansevles) add locking around the eof handler and the close() call, so we can't be in both simultaneously. modified files: channel.py 2003-12-24 20:49:38 GMT Robey Pointer <robey@lag.net> patch-12 Summary: fix dss key signing Revision: secsh--dev--1.0--patch-12 (expanded on a patch from fred gansevles) add a demo dss key for server mode, and fix some bugs that had caused the dss signing stuff to never work before. the demo_server is a bit more verbose now, too. both key types (RSAKey & DSSKey) now have a function to return the fingerprint of the key, and both versions of read_private_key_file() now raise exceptions on failure, instead of just silently setting "valid" to false. new files: .arch-ids/demo_dss_key.id demo_dss_key modified files: demo_server.py dsskey.py kex_gex.py kex_group1.py paramiko.py rsakey.py transport.py 2003-12-23 06:44:56 GMT Robey Pointer <robey@lag.net> patch-11 Summary: in server mode, don't offer keys we don't have Revision: secsh--dev--1.0--patch-11 (from Paolo Losi) in server mode, when advertising which key methods we support, don't list methods that we don't have any existing keys for. modified files: transport.py 2003-12-23 06:36:27 GMT Robey Pointer <robey@lag.net> patch-10 Summary: add logfiles and .pyc files to the "junk" list Revision: secsh--dev--1.0--patch-10 add *.log and *.pyc to the explicit junk list. modified files: {arch}/=tagging-method 2003-11-10 08:49:50 GMT Robey Pointer <robey@lag.net> patch-9 Summary: rename secsh -> paramiko Revision: secsh--dev--1.0--patch-9 also, rename SecshException back to SSHException. sigh. :) modified files: ./MANIFEST ./Makefile ./NOTES ./README ./auth_transport.py ./channel.py ./demo.py ./demo_server.py ./kex_gex.py ./kex_group1.py ./message.py ./paramiko.py ./setup.py ./transport.py renamed files: ./.arch-ids/secsh.py.id ==> ./.arch-ids/paramiko.py.id ./secsh.py ==> ./paramiko.py 2003-11-10 06:52:35 GMT Robey Pointer <robey@lag.net> patch-8 Summary: doc changes Revision: secsh--dev--1.0--patch-8 modified files: ./README ./demo_server.py ./secsh.py 2003-11-10 04:54:02 GMT Robey Pointer <robey@lag.net> patch-7 Summary: cleaned up server code, renamed some files & classes Revision: secsh--dev--1.0--patch-7 renamed demo-server.py and demo-host-key to demo_server.py and demo_host_key, just to be consistent. renamed SSHException -> SecshException. generalized the mechanism where Channel decides whether to allow different channel requests: 4 of the main ones (pty, window-change, shell, and subsystem) go through easily override-able methods now. you could probably make an actual ssh shell server. gave ChannelFile a repr(). turned off ultra debugging in the demos. demo_server creates a subclass of Channel to allow pty/shell and sets an event when the shell request is made, so that it knows when it can start sending the fake bbs. renamed to charmander and updated some of the distutils files. modified files: ./MANIFEST ./NOTES ./auth_transport.py ./channel.py ./demo.py ./demo_server.py ./kex_gex.py ./kex_group1.py ./secsh.py ./setup.py ./transport.py renamed files: ./.arch-ids/demo-host-key.id ==> ./.arch-ids/demo_host_key.id ./.arch-ids/demo-server.py.id ==> ./.arch-ids/demo_server.py.id ./demo-host-key ==> ./demo_host_key ./demo-server.py ==> ./demo_server.py 2003-11-09 21:16:35 GMT Robey Pointer <robey@lag.net> patch-6 Summary: notes about the exported api Revision: secsh--dev--1.0--patch-6 just wrote some quick notes (for a few of the classes) about which methods are intended to be the exported API. python has no decent way of distinguishing private vs public. modified files: ./NOTES 2003-11-09 21:14:21 GMT Robey Pointer <robey@lag.net> patch-5 Summary: big chunk of work which makes server code 95% done Revision: secsh--dev--1.0--patch-5 fixed auth check methods to return just a result (failed, succeeded, partially succeeded) and always use get_allowed_auths to determine the list of allowed auth methods to return. channel's internal API changed a bit to allow for client-side vs. server-side channels. we now honor the "want-reply" bit from channel requests. in server mode (for now), we automatically allow pty-req and shell requests without doing anything. ChannelFile was fixed up a bit to support universal newlines. readline got rewritten: the old way used the "greedy" read call from ChannelFile, which won't work if the socket doesn't have that much data buffered and ready. now it uses recv directly, and tracks the different newlines. demo-server.py now answers to a single shell request (like a CLI ssh tool will make) and does a very simple demo pretending to be a BBS. transport: fixed a bug with parsing the remote side's banner. channel requests are passed to another method in server mode, to determine if we should allow it. new allowed channels are added to an accept queue, and a new method 'accept' (with timeout) will block until the next incoming channel is ready. modified files: ./auth_transport.py ./channel.py ./demo-server.py ./demo.py ./transport.py 2003-11-09 20:59:51 GMT Robey Pointer <robey@lag.net> patch-4 Summary: change kex-gex server code to generate primes by hand Revision: secsh--dev--1.0--patch-4 added a util function "generate_prime" to compare to the incredibly slow C version, but it's no faster of course. i think kex-gex from the server is just not going to be feasible without having a separate thread generate some primes in the background to have handy when a request comes in. so in short, this still doesn't work. also i put bit_length into util and a tb_strings function which gets stack traceback info and splits it into a list of strings. modified files: ./kex_gex.py ./util.py 2003-11-07 10:36:42 GMT Robey Pointer <robey@lag.net> patch-3 Summary: remove some leftover garbage from dsskey Revision: secsh--dev--1.0--patch-3 leftover from a cut & paste i was doing a few days ago. bad robey. modified files: ./dsskey.py 2003-11-06 07:34:27 GMT Robey Pointer <robey@lag.net> patch-2 Summary: add a demo host key and point demo-server at it. Revision: secsh--dev--1.0--patch-2 also, temporarily comment out the nonfunctional kex-gex method. new files: ./.arch-ids/demo-host-key.id ./demo-host-key modified files: ./demo-server.py ./transport.py 2003-11-04 08:50:22 GMT Robey Pointer <robey@lag.net> patch-1 Summary: no changes Revision: secsh--dev--1.0--patch-1 why aren't my log messages kept? modified files: ./kex_gex.py new patches: robey@lag.net--2003/secsh--dev--1.0--patch-1 2003-11-04 08:34:24 GMT Robey Pointer <robey@lag.net> base-0 Summary: initial import Revision: secsh--dev--1.0--base-0 (automatically generated log message) new files: ./LICENSE ./MANIFEST ./Makefile ./NOTES ./README ./auth_transport.py ./ber.py ./channel.py ./demo-server.py ./demo.py ./dsskey.py ./kex_gex.py ./kex_group1.py ./message.py ./rsakey.py ./secsh.py ./setup.py ./transport.py ./util.py new patches: robey@lag.net--2003/secsh--dev--1.0--base-0