2011-01-20 21:36:10 -08:00
# Note: please minimize imports in this file. In particular, do not import
# any module from Tahoe-LAFS or its dependencies, and do not import any
# modules at all at global level. That includes setuptools and pkg_resources.
# It is ok to import modules from the Python Standard Library if they are
# always available, or the import is protected by try...except ImportError.
2015-01-20 10:52:02 -08:00
# The semantics for requirement specs changed incompatibly in setuptools 8,
# which now follows PEP 440. The requirements used in this file must be valid
# under both the old and new semantics. That can be achieved by limiting
# requirement specs to one of the following forms:
#
# * >= X, <= Y where X < Y
# * >= X, != Y, != Z, ... where X < Y < Z...
#
# (In addition, check_requirement in allmydata/__init__.py only supports
# >=, <= and != operators.)
2011-01-20 21:36:10 -08:00
install_requires = [
2014-09-30 19:03:25 +01:00
# We require newer versions of setuptools (actually
# zetuptoolz) to build, but can handle older versions to run.
2011-01-21 17:24:42 -08:00
" setuptools >= 0.6c6 " ,
2011-01-20 21:36:10 -08:00
" zfec >= 1.1.0 " ,
# Feisty has simplejson 1.4
" simplejson >= 1.4 " ,
2013-04-25 19:33:55 +01:00
# zope.interface >= 3.6.0 is required for Twisted >= 12.1.0.
2011-08-14 19:53:47 -07:00
# zope.interface 3.6.3 and 3.6.4 are incompatible with Nevow (#1435).
2015-01-20 10:52:02 -08:00
" zope.interface >= 3.6.0, != 3.6.3, != 3.6.4 " ,
2011-01-20 21:36:10 -08:00
2012-06-24 12:10:24 -07:00
# * foolscap < 0.5.1 had a performance bug which spent O(N**2) CPU for
# transferring large mutable files of size N.
# * foolscap < 0.6 is incompatible with Twisted 10.2.0.
# * foolscap 0.6.1 quiets a DeprecationWarning.
2014-10-07 21:04:40 +01:00
# * foolscap < 0.6.3 is incompatible with Twisted 11.1.0 and newer.
2015-04-28 17:21:31 +01:00
# * foolscap 0.8.0 generates 2048-bit RSA-with-SHA-256 signatures,
# rather than 1024-bit RSA-with-MD5. This also allows us to work
# with a FIPS build of OpenSSL.
" foolscap >= 0.8.0 " ,
2011-01-20 21:36:10 -08:00
2014-09-30 19:03:25 +01:00
# Needed for SFTP.
# pycrypto 2.2 doesn't work due to <https://bugs.launchpad.net/pycrypto/+bug/620253>
# pycrypto 2.4 doesn't work due to <https://bugs.launchpad.net/pycrypto/+bug/881130>
2015-01-20 10:52:02 -08:00
" pycrypto >= 2.1.0, != 2.2, != 2.4 " ,
2011-01-20 21:36:10 -08:00
2012-03-13 23:13:51 -07:00
# pycryptopp-0.6.0 includes ed25519
" pycryptopp >= 0.6.0 " ,
2015-04-21 21:15:54 +01:00
" service-identity " , # this is needed to suppress complaints about being unable to verify certs
" characteristic >= 14.0.0 " , # latest service-identity depends on this version
2015-07-16 15:38:06 +01:00
" pyasn1 >= 0.1.8 " , # latest pyasn1-modules depends on this version
2015-04-21 21:15:54 +01:00
" pyasn1-modules >= 0.0.5 " , # service-identity depends on this
2011-01-20 21:36:10 -08:00
]
# Includes some indirect dependencies, but does not include allmydata.
# These are in the order they should be listed by --version, etc.
package_imports = [
2014-09-01 19:39:57 +01:00
# package name module name
( ' foolscap ' , ' foolscap ' ) ,
( ' pycryptopp ' , ' pycryptopp ' ) ,
( ' zfec ' , ' zfec ' ) ,
( ' Twisted ' , ' twisted ' ) ,
( ' Nevow ' , ' nevow ' ) ,
( ' zope.interface ' , ' zope.interface ' ) ,
( ' python ' , None ) ,
( ' platform ' , None ) ,
( ' pyOpenSSL ' , ' OpenSSL ' ) ,
2015-06-02 18:07:20 +01:00
( ' OpenSSL ' , None ) ,
2014-09-01 19:39:57 +01:00
( ' simplejson ' , ' simplejson ' ) ,
( ' pycrypto ' , ' Crypto ' ) ,
( ' pyasn1 ' , ' pyasn1 ' ) ,
2015-04-21 21:15:54 +01:00
( ' service-identity ' , ' service_identity ' ) ,
( ' characteristic ' , ' characteristic ' ) ,
( ' pyasn1-modules ' , ' pyasn1_modules ' ) ,
2011-01-20 21:36:10 -08:00
]
2014-09-25 18:54:14 +01:00
# Dependencies for which we don't know how to get a version number at run-time.
not_import_versionable = [
' zope.interface ' ,
]
# Dependencies reported by pkg_resources that we can safely ignore.
ignorable = [
' argparse ' ,
' pyutil ' ,
' zbase32 ' ,
' distribute ' ,
' twisted-web ' ,
' twisted-core ' ,
' twisted-conch ' ,
]
2014-10-07 19:06:14 +01:00
import sys
2011-01-20 21:36:10 -08:00
2014-10-07 19:06:14 +01:00
# Don't try to get the version number of setuptools in frozen builds, because
# that triggers 'site' processing that causes failures. Note that frozen
# builds still (unfortunately) import pkg_resources in .tac files, so the
# entry for setuptools in install_requires above isn't conditional.
if not hasattr ( sys , ' frozen ' ) :
package_imports . append ( ( ' setuptools ' , ' setuptools ' ) )
2011-01-20 21:36:10 -08:00
2014-10-07 21:04:40 +01:00
2015-05-02 21:38:48 +01:00
# * On Linux we need at least Twisted 10.1.0 for inotify support
# used by the drop-upload frontend.
# * We also need Twisted 10.1.0 for the FTP frontend in order for
# Twisted's FTP server to support asynchronous close.
# * The SFTP frontend depends on Twisted 11.0.0 to fix the SSH server
# rekeying bug <https://twistedmatrix.com/trac/ticket/4395>
# * The FTP frontend depends on Twisted >= 11.1.0 for
# filepath.Permissions
#
# On Windows, Twisted >= 12.2.0 has a dependency on pywin32.
# Since pywin32 can only be installed manually, we fall back to
# requiring earlier versions of Twisted and Nevow if it is not
# already installed.
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/2028>
#
2015-05-02 22:26:39 +01:00
# When the fallback is used we also need to work around the fact
# that Nevow imports itself when building, which causes Twisted
# and zope.interface to be imported; therefore, we need to set
# setup_requires to make sure that the versions of Twisted and
# zope.interface used at build time satisfy Nevow's requirements.
#
2015-05-02 21:38:48 +01:00
# In cases where this fallback isn't needed, we prefer Nevow >= 0.11.1
# which can be installed using pip, and Twisted >= 13.0.0 which
2015-05-02 22:26:39 +01:00
# Nevow 0.11.1 depends on. In this case we should *not* use the
# setup_requires hack, because if we do then the build will break
# when Twisted < 13.0.0 is already installed (even though it could
# have succeeded by building a later version under support/ ).
#
2015-05-02 21:38:48 +01:00
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/2032>
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/2249>
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/2291>
2015-05-02 22:26:39 +01:00
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/2286>
setup_requires = [ ]
2014-10-07 21:04:40 +01:00
2015-05-02 21:38:05 +01:00
_use_old_Twisted_and_Nevow = False
2014-10-07 19:11:00 +01:00
if sys . platform == " win32 " :
2015-05-02 21:38:05 +01:00
try :
import win32api
2015-05-13 14:20:13 +01:00
[ win32api ]
2015-05-02 21:38:05 +01:00
except ImportError :
_use_old_Twisted_and_Nevow = True
if _use_old_Twisted_and_Nevow :
2014-10-07 19:11:00 +01:00
install_requires + = [
2015-03-31 09:41:55 -07:00
" Twisted >= 11.1.0, <= 12.1.0 " ,
2015-01-20 10:52:02 -08:00
" Nevow >= 0.9.33, <= 0.10 " ,
2014-10-07 19:11:00 +01:00
]
2015-05-02 22:26:39 +01:00
setup_requires + = [ req for req in install_requires if req . startswith ( ' Twisted ' )
or req . startswith ( ' zope.interface ' ) ]
2014-10-07 19:11:00 +01:00
else :
install_requires + = [
" Twisted >= 13.0.0 " ,
" Nevow >= 0.11.1 " ,
]
2011-01-20 21:36:10 -08:00
2014-10-07 21:04:40 +01:00
# * pyOpenSSL is required in order for foolscap to provide secure connections.
# Since foolscap doesn't reliably declare this dependency in a machine-readable
# way, we need to declare a dependency on pyOpenSSL ourselves. Tahoe-LAFS does
# not *directly* depend on pyOpenSSL.
#
# * pyOpenSSL >= 0.13 is needed in order to avoid
2015-06-02 18:07:20 +01:00
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/2005>, and also to check the
# version of OpenSSL that pyOpenSSL is using.
2014-10-07 21:04:40 +01:00
#
# * pyOpenSSL >= 0.14 is built on the 'cryptography' package which depends
# on 'cffi' (and indirectly several other packages). Unfortunately cffi
# attempts to compile code dynamically, which causes problems on many systems.
# It also depends on the libffi OS package which may not be installed.
# <https://bitbucket.org/cffi/cffi/issue/109/enable-sane-packaging-for-cffi>
# <https://bitbucket.org/cffi/cffi/issue/70/cant-install-cffi-using-pip-on-windows>
#
# So, if pyOpenSSL 0.14 has *already* been installed and is importable, we
# want to accept it; otherwise we ask for pyOpenSSL 0.13 or 0.13.1.
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/2193>
#
# We don't rely on pkg_resources to tell us the installed pyOpenSSL version
# number, because pkg_resources telling us that we have 0.14 is not sufficient
# evidence that 0.14 will be the imported version (or will work correctly).
# One possible reason why it might not be is explained in
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/1246#comment:6> and
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/1258>.
2014-10-07 19:11:13 +01:00
_can_use_pyOpenSSL_0_14 = False
try :
import OpenSSL
pyOpenSSL_ver = OpenSSL . __version__ . split ( ' . ' )
if int ( pyOpenSSL_ver [ 0 ] ) > 0 or int ( pyOpenSSL_ver [ 1 ] ) > = 14 :
_can_use_pyOpenSSL_0_14 = True
except Exception :
pass
if _can_use_pyOpenSSL_0_14 :
install_requires + = [
2014-10-07 21:04:40 +01:00
# Although we checked for pyOpenSSL >= 0.14 above, we only actually
# need pyOpenSSL >= 0.13; requiring 0.14 here cannot help.
2014-10-07 19:11:13 +01:00
" pyOpenSSL >= 0.13 " ,
# ... and now all the new stuff that pyOpenSSL 0.14 transitively
# depends on. We specify these explicitly because setuptools is
# bad at correctly resolving indirect dependencies (e.g. see
# <https://tahoe-lafs.org/trac/tahoe-lafs/ticket/2286>).
#
" cryptography " ,
" cffi >= 0.8 " , # latest cryptography depends on this version
" six >= 1.4.1 " , # latest cryptography depends on this version
2014-12-26 22:29:42 +00:00
" enum34 " , # latest cryptography depends on this
2014-10-07 19:11:13 +01:00
" pycparser " , # cffi depends on this
]
package_imports + = [
( ' cryptography ' , ' cryptography ' ) ,
( ' cffi ' , ' cffi ' ) ,
( ' six ' , ' six ' ) ,
2014-12-26 22:29:42 +00:00
( ' enum34 ' , ' enum ' ) ,
2014-10-07 19:11:13 +01:00
( ' pycparser ' , ' pycparser ' ) ,
]
else :
install_requires + = [
2015-01-20 10:52:02 -08:00
" pyOpenSSL >= 0.13, <= 0.13.1 " ,
2014-10-07 19:11:13 +01:00
]
2012-06-14 21:23:08 +00:00
# These are suppressed globally:
global_deprecation_messages = [
" BaseException.message has been deprecated as of Python 2.6 " ,
" twisted.internet.interfaces.IFinishableConsumer was deprecated in Twisted 11.1.0: Please use IConsumer (and IConsumer.unregisterProducer) instead. " ,
2014-09-01 21:12:53 +01:00
" twisted.internet.interfaces.IStreamClientEndpointStringParser was deprecated in Twisted 14.0.0: This interface has been superseded by IStreamClientEndpointStringParserWithReactor. " ,
2012-06-14 21:23:08 +00:00
]
# These are suppressed while importing dependencies:
2011-01-20 21:36:10 -08:00
deprecation_messages = [
" the sha module is deprecated; use the hashlib module instead " ,
" object.__new__ \ ( \ ) takes no parameters " ,
" The popen2 module is deprecated. Use the subprocess module. " ,
" the md5 module is deprecated; use hashlib instead " ,
" twisted.web.error.NoResource is deprecated since Twisted 9.0. See twisted.web.resource.NoResource. " ,
" the sets module is deprecated " ,
]
2012-05-14 03:23:52 +00:00
runtime_warning_messages = [
" Not using mpz_powm_sec. You should rebuild using libgmp >= 5 to avoid timing attack vulnerability. " ,
]
2011-08-17 21:07:49 -07:00
warning_imports = [
2011-01-20 21:36:10 -08:00
' nevow ' ,
' twisted.persisted.sob ' ,
' twisted.python.filepath ' ,
' Crypto.Hash.SHA ' ,
]