| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | ======== | 
					
						
							|  |  |  | paramiko | 
					
						
							|  |  |  | ======== | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | :Paramiko: Python SSH module | 
					
						
							|  |  |  | :Copyright: Copyright (c) 2003-2007  Robey Pointer <robey@lag.net> | 
					
						
							|  |  |  | :License: LGPL | 
					
						
							|  |  |  | :Homepage: http://www.lag.net/paramiko/ | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | paramiko 1.7.1 | 
					
						
							|  |  |  | ============== | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | "Amy" release, 10 june 2007 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | What | 
					
						
							|  |  |  | ---- | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  | "paramiko" is a combination of the esperanto words for "paranoid" and | 
					
						
							|  |  |  | "friend".  it's a module for python 2.2+ that implements the SSH2 protocol | 
					
						
							|  |  |  | for secure (encrypted and authenticated) connections to remote machines. | 
					
						
							|  |  |  | unlike SSL (aka TLS), SSH2 protocol does not require heirarchical | 
					
						
							|  |  |  | certificates signed by a powerful central authority. you may know SSH2 as | 
					
						
							|  |  |  | the protocol that replaced telnet and rsh for secure access to remote | 
					
						
							|  |  |  | shells, but the protocol also includes the ability to open arbitrary | 
					
						
							|  |  |  | channels to remote services across the encrypted tunnel (this is how sftp | 
					
						
							|  |  |  | works, for example). | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | it is written entirely in python (no C or platform-dependent code) and is | 
					
						
							|  |  |  | released under the GNU LGPL (lesser GPL).  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  | the package and its API is fairly well documented in the "doc/" folder | 
					
						
							|  |  |  | that should have come with this archive. | 
					
						
							| 
									
										
										
										
											2004-01-04 04:29:13 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | Requirements | 
					
						
							|  |  |  | ------------ | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  |   - python 2.3	<http://www.python.org/> | 
					
						
							| 
									
										
										
										
											2004-09-05 03:44:03 -04:00
										 |  |  |     (python 2.2 is also supported, but not recommended) | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  |   - pycrypto 1.9+	<http://www.amk.ca/python/code/crypto.html> | 
					
						
							| 
									
										
										
										
											2004-09-07 02:45:53 -04:00
										 |  |  |     (2.0 works too) | 
					
						
							| 
									
										
										
										
											2004-01-04 04:29:13 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-07 02:45:53 -04:00
										 |  |  | pycrypto compiled for Win32 can be downloaded from the HashTar homepage: | 
					
						
							| 
									
										
										
										
											2004-01-04 04:29:13 -05:00
										 |  |  |     http://nitace.bsd.uchicago.edu:8080/hashtar | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-08 01:48:16 -04:00
										 |  |  | you can also build it yourself using the free MinGW tools and this command | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | line (thanks to Roger Binns for the info):: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-08 01:48:16 -04:00
										 |  |  |     python setup.py build --compiler=mingw32 bdist_wininst | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-16 12:59:05 -05:00
										 |  |  | If you have setuptools, you can build and install paramiko and all its | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | dependencies with this command (as root):: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-16 12:59:05 -05:00
										 |  |  |     easy_install ./ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | Portability | 
					
						
							|  |  |  | ----------- | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | i code and test this library on Linux and MacOS X.  for that reason, i'm | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | pretty sure that it works for all posix platforms, including MacOS.  it | 
					
						
							|  |  |  | should also work on Windows, though i don't test it as frequently there. | 
					
						
							|  |  |  | if you run into Windows problems, send me a patch: portability is important | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  | to me. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | python 2.2 may work, thanks to some patches from Roger Binns.  things to | 
					
						
							|  |  |  | watch out for: | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     * sockets in 2.2 don't support timeouts, so the 'select' module is | 
					
						
							|  |  |  |       imported to do polling.   | 
					
						
							|  |  |  |     * logging is mostly stubbed out.  it works just enough to let paramiko | 
					
						
							|  |  |  |       create log files for debugging, if you want them.  to get real logging, | 
					
						
							|  |  |  |       you can backport python 2.3's logging package.  Roger has done that | 
					
						
							|  |  |  |       already: | 
					
						
							|  |  |  |       http://sourceforge.net/project/showfiles.php?group_id=75211&package_id=113804 | 
					
						
							| 
									
										
										
										
											2004-04-07 12:05:48 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | you really should upgrade to python 2.3.  laziness is no excuse! :) | 
					
						
							| 
									
										
										
										
											2004-04-06 04:16:02 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  | some python distributions don't include the utf-8 string encodings, for | 
					
						
							|  |  |  | reasons of space (misdirected as that is).  if your distribution is | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | missing encodings, you'll see an error like this:: | 
					
						
							| 
									
										
										
										
											2004-05-29 14:48:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  |     LookupError: no codec search functions registered: can't find encoding | 
					
						
							| 
									
										
										
										
											2004-05-29 14:48:23 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | this means you need to copy string encodings over from a working system. | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  | (it probably only happens on embedded systems, not normal python | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | installls.)  Valeriy Pogrebitskiy says the best place to look is | 
					
						
							|  |  |  | ``.../lib/python*/encodings/__init__.py``. | 
					
						
							| 
									
										
										
										
											2004-05-29 14:48:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | Bugs & Support | 
					
						
							|  |  |  | -------------- | 
					
						
							| 
									
										
										
										
											2006-07-31 02:56:04 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | there's a launchpage page for paramiko, with a bug tracker: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  |     https://launchpad.net/paramiko/ | 
					
						
							| 
									
										
										
										
											2006-07-31 02:56:04 -04:00
										 |  |  |      | 
					
						
							|  |  |  | this is the primary place to file and browse bug reports. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | there's also a low-traffic mailing list for support and discussions: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     http://www.lag.net/mailman/listinfo/paramiko | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | Demo | 
					
						
							|  |  |  | ---- | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  | several demo scripts come with paramiko to demonstrate how to use it. | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | probably the simplest demo of all is this:: | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     import paramiko, base64 | 
					
						
							|  |  |  |     key = paramiko.RSAKey(data=base64.decodestring('AAA...')) | 
					
						
							| 
									
										
										
										
											2006-05-10 21:33:13 -04:00
										 |  |  |     client = paramiko.SSHClient() | 
					
						
							|  |  |  |     client.get_host_keys().add('ssh.example.com', 'ssh-rsa', key) | 
					
						
							|  |  |  |     client.connect('ssh.example.com', username='strongbad', password='thecheat') | 
					
						
							|  |  |  |     stdin, stdout, stderr = client.exec_command('ls') | 
					
						
							|  |  |  |     for line in stdout: | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  |         print '... ' + line.strip('\n') | 
					
						
							| 
									
										
										
										
											2006-05-10 21:33:13 -04:00
										 |  |  |     client.close() | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | ...which prints out the results of executing ``ls`` on a remote server. | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  | (the host key 'AAA...' should of course be replaced by the actual base64 | 
					
						
							|  |  |  | encoding of the host key.  if you skip host key verification, the | 
					
						
							|  |  |  | connection is not secure!) | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-05-10 21:33:13 -04:00
										 |  |  | the following example scripts (in demos/) get progressively more detailed: | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | :demo_simple.py: | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  |     calls invoke_shell() and emulates a terminal/tty through which you can | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  |     execute commands interactively on a remote server.  think of it as a | 
					
						
							| 
									
										
										
										
											2005-03-26 00:53:00 -05:00
										 |  |  |     poor man's ssh command-line client. | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | :demo.py: | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  |     same as demo_simple.py, but allows you to authenticiate using a | 
					
						
							| 
									
										
										
										
											2005-07-18 02:40:30 -04:00
										 |  |  |     private key, attempts to use an SSH-agent if present, and uses the long | 
					
						
							|  |  |  |     form of some of the API calls. | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | :forward.py: | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  |     command-line script to set up port-forwarding across an ssh transport. | 
					
						
							| 
									
										
										
										
											2005-03-26 00:53:00 -05:00
										 |  |  |     (requires python 2.3.) | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | :demo_sftp.py: | 
					
						
							| 
									
										
										
										
											2006-02-20 02:23:03 -05:00
										 |  |  |     opens an sftp session and does a few simple file operations. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | :demo_server.py: | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  |     an ssh server that listens on port 2200 and accepts a login for | 
					
						
							|  |  |  |     'robey' (password 'foo'), and pretends to be a BBS.  meant to be a | 
					
						
							| 
									
										
										
										
											2005-03-26 00:53:00 -05:00
										 |  |  |     very simple demo of writing an ssh server. | 
					
						
							| 
									
										
										
										
											2003-11-10 01:52:35 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | Use | 
					
						
							|  |  |  | --- | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-11-06 15:32:08 -05:00
										 |  |  | the demo scripts are probably the best example of how to use this package. | 
					
						
							|  |  |  | there is also a lot of documentation, generated with epydoc, in the doc/ | 
					
						
							| 
									
										
										
										
											2004-12-10 02:55:33 -05:00
										 |  |  | folder.  point your browser there.  seriously, do it.  mad props to | 
					
						
							|  |  |  | epydoc, which actually motivated me to write more documentation than i | 
					
						
							|  |  |  | ever would have before. | 
					
						
							| 
									
										
										
										
											2003-11-10 01:52:35 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | there are also unit tests here:: | 
					
						
							| 
									
										
										
										
											2003-11-04 03:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  |     $ python ./test.py | 
					
						
							| 
									
										
										
										
											2007-03-26 03:58:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-11 00:44:47 -04:00
										 |  |  | which will verify that most of the core components are working correctly. |