OLD | NEW |
(Empty) | |
| 1 # Copyright (c) 2006,2007 Jon Colverson |
| 2 # |
| 3 # Permission is hereby granted, free of charge, to any person obtaining a |
| 4 # copy of this software and associated documentation files (the |
| 5 # "Software"), to deal in the Software without restriction, including |
| 6 # without limitation the rights to use, copy, modify, merge, publish, dis- |
| 7 # tribute, sublicense, and/or sell copies of the Software, and to permit |
| 8 # persons to whom the Software is furnished to do so, subject to the fol- |
| 9 # lowing conditions: |
| 10 # |
| 11 # The above copyright notice and this permission notice shall be included |
| 12 # in all copies or substantial portions of the Software. |
| 13 # |
| 14 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| 15 # OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL- |
| 16 # ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT |
| 17 # SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
| 18 # WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
| 19 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS |
| 20 # IN THE SOFTWARE. |
| 21 |
| 22 """ |
| 23 This module was contributed by Jon Colverson. It provides a couple of helper |
| 24 functions that allow you to use M2Crypto's implementation of HTTPSConnection |
| 25 rather than the default version in httplib.py. The main benefit is that |
| 26 M2Crypto's version verifies the certificate of the server. |
| 27 |
| 28 To use this feature, do something like this: |
| 29 |
| 30 from boto.ec2.connection import EC2Connection |
| 31 |
| 32 ec2 = EC2Connection(ACCESS_KEY_ID, SECRET_ACCESS_KEY, |
| 33 https_connection_factory=https_connection_factory(cafile=CA_FILE)) |
| 34 |
| 35 See http://code.google.com/p/boto/issues/detail?id=57 for more details. |
| 36 """ |
| 37 from M2Crypto import SSL |
| 38 from M2Crypto.httpslib import HTTPSConnection |
| 39 |
| 40 def secure_context(cafile=None, capath=None): |
| 41 ctx = SSL.Context() |
| 42 ctx.set_verify(SSL.verify_peer | SSL.verify_fail_if_no_peer_cert, depth=9) |
| 43 if ctx.load_verify_locations(cafile=cafile, capath=capath) != 1: |
| 44 raise Exception("Couldn't load certificates") |
| 45 return ctx |
| 46 |
| 47 def https_connection_factory(cafile=None, capath=None): |
| 48 def factory(*args, **kwargs): |
| 49 return HTTPSConnection( |
| 50 ssl_context=secure_context(cafile=cafile, capath=capath), |
| 51 *args, **kwargs) |
| 52 return (factory, (SSL.SSLError,)) |
OLD | NEW |