[tor-commits] [bridgedb/develop] Make which pluggable transports are distributed easily configurable.
isis at torproject.org
isis at torproject.org
Thu Mar 26 04:40:22 UTC 2015
commit 0a6bea1ddae7e9a3885b2d4486e625c2b3f7f7ac
Author: Isis Lovecruft <isis at torproject.org>
Date: Thu Mar 26 03:03:15 2015 +0000
Make which pluggable transports are distributed easily configurable.
* REMOVE bridgedb.strings.CURRENT_TRANSPORTS.
* ADD b.strings.SUPPORTED_TRANSPORTS, which can be get/set with
b.strings._getSupportedTransports() and
_setSupportedTransports(). There is also a new SUPPORTED_TRANSPORTS
option in bridgedb.conf; the setting at
bridgedb.strings.SUPPORTED_TRANSPORTS is now automatically configured
via the bridgedb.conf file.
* ADD b.strings.DEFAULT_TRANSPORT, which can be get/set with
b.strings._getDefaultTransport() and _setDefaultTransport(). There is
also a new DEFAULT_TRANSPORT option in bridgedb.conf; the setting at
bridgedb.strings.DEFAULT_TRANSPORT is now automatically configured
via the bridgedb.conf file.
* CHANGE options.html template to automatically populate the list of
available transports. The DEFAULT_TRANSPORT is automatically the
selected default.
* FIXES #12504: https://bugs.torproject.org/12504
---
bridgedb.conf | 18 +++++++
lib/bridgedb/configure.py | 14 ++++++
lib/bridgedb/email/templates.py | 2 +-
lib/bridgedb/strings.py | 90 +++++++++++++++++++++++++++++++----
lib/bridgedb/templates/options.html | 13 +++--
5 files changed, 121 insertions(+), 16 deletions(-)
diff --git a/bridgedb.conf b/bridgedb.conf
index e0b25f0..c91cc73 100644
--- a/bridgedb.conf
+++ b/bridgedb.conf
@@ -20,6 +20,9 @@
#
# CHANGELOG:
# ~~~~~~~~~~
+# Changed in version 0.0.15 - 2015-03-26
+# * ADD new SUPPORTED_TRANSPORTS and DEFAULT_TRANSPORT settings.
+#
# Changes in version 0.0.14 - 2015-02-22
# * ADD new OpenPGP-related options:
# - EMAIL_GPG_HOMEDIR
@@ -237,6 +240,21 @@ TASKS = {
'GET_TOR_EXIT_LIST': 3 * 60 * 60,
}
+# SUPPORTED_TRANSPORTS is a dictionary mapping Pluggable Transport methodnames
+# to booleans. If ``True``, the PT is distributed; if ``False``, it isn't.
+SUPPORTED_TRANSPORTS = {
+ 'obfs2': True,
+ 'obfs3': True,
+ 'obfs4': True,
+ 'scramblesuit': True,
+ 'fte': True,
+}
+
+# DEFAULT_TRANSPORT is a string. It should be the PT methodname of the
+# transport which is selected by default (e.g. in the webserver dropdown
+# menu).
+DEFAULT_TRANSPORT = 'obfs4'
+
#-------------------------------
# HTTP(S) Distribution Options \
#------------------------------------------------------------------------------
diff --git a/lib/bridgedb/configure.py b/lib/bridgedb/configure.py
index 90c5e2f..4fb6cc0 100644
--- a/lib/bridgedb/configure.py
+++ b/lib/bridgedb/configure.py
@@ -14,6 +14,9 @@
import logging
import os
+# Used to set the SUPPORTED_TRANSPORTS:
+from bridgedb import strings
+
def loadConfig(configFile=None, configCls=None):
"""Load configuration settings on top of the current settings.
@@ -116,6 +119,17 @@ def loadConfig(configFile=None, configCls=None):
setting = getattr(config, attr, []) # Default to empty lists
setattr(config, attr, setting)
+ for attr in ["SUPPORTED_TRANSPORTS"]:
+ setting = getattr(config, attr, {}) # Default to emtpy dicts
+ setattr(config, attr, setting)
+
+ # Set the SUPPORTED_TRANSPORTS to populate the webserver and email options:
+ strings._setSupportedTransports(getattr(config, "SUPPORTED_TRANSPORTS", {}))
+ strings._setDefaultTransport(getattr(config, "DEFAULT_TRANSPORT", ""))
+ logging.info("Currently supported transports: %s" %
+ " ".join(strings._getSupportedTransports()))
+ logging.info("Default transport: %s" % strings._getDefaultTransport())
+
for domain in config.EMAIL_DOMAINS:
config.EMAIL_DOMAIN_MAP[domain] = domain
diff --git a/lib/bridgedb/email/templates.py b/lib/bridgedb/email/templates.py
index e81283e..ae85e8f 100644
--- a/lib/bridgedb/email/templates.py
+++ b/lib/bridgedb/email/templates.py
@@ -53,7 +53,7 @@ def addCommands(template):
# And include the currently supported transports:
commands += template.gettext(strings.EMAIL_MISC_TEXT.get(5))
commands += "\n"
- for pt in strings.CURRENT_TRANSPORTS:
+ for pt in strings._getSupportedTransports():
commands += ' ' + pt + "\n"
return commands
diff --git a/lib/bridgedb/strings.py b/lib/bridgedb/strings.py
index 5a9c528..1f38e4b 100644
--- a/lib/bridgedb/strings.py
+++ b/lib/bridgedb/strings.py
@@ -1,4 +1,4 @@
-# -*- coding: utf-8 -*-
+# -*- coding: utf-8 ; test-case-name: bridgedb.test.test_strings ; -*-
#
# This file is part of BridgeDB, a Tor bridge distribution system.
#
@@ -10,6 +10,12 @@
from __future__ import unicode_literals
+# This won't work on Python2.6, however
+# 1) We don't use Python2.6, and
+# 2) We don't care about supporting Python2.6, because Python 2.6 (and,
+# honestly, all of Python2) should die.
+from collections import OrderedDict
+
def _(text):
"""This is necessary because strings are translated when they're imported.
@@ -166,21 +172,85 @@ EMAIL_COMMANDS = {
# All of the following containers are untranslated!
#-----------------------------------------------------------------------------
-#: A list of all currently available pluggable transports. By "currently
-#: available" we mean:
+#: SUPPORTED TRANSPORTS is dictionary mapping all Pluggable Transports
+#: methodname to whether or not we actively distribute them. The ones which we
+#: distribute SHOULD have the following properties:
#:
#: 1. The PT is in a widely accepted, usable state for most Tor users.
#: 2. The PT is currently publicly deployed *en masse*".
#: 3. The PT is included within the transports which Tor Browser offers in
#: the stable releases.
#:
-CURRENT_TRANSPORTS = [
- "obfs2",
- "obfs3",
- "obfs4",
- "scramblesuit",
- "fte",
-]
+#: These will be sorted by methodname in alphabetical order.
+#:
+#: ***Don't change this setting here; change it in :file:`bridgedb.conf`.***
+SUPPORTED_TRANSPORTS = {}
+
+#: DEFAULT_TRANSPORT is a string. It should be the PT methodname of the
+#: transport which is selected by default (e.g. in the webserver dropdown
+#: menu).
+#:
+#: ***Don't change this setting here; change it in :file:`bridgedb.conf`.***
+DEFAULT_TRANSPORT = ''
+
+def _getSupportedTransports():
+ """Get the list of currently supported transports.
+
+ :rtype: list
+ :returns: A list of strings, one for each supported Pluggable Transport
+ methodname, sorted in alphabetical order.
+ """
+ supported = [name.lower() for name,w00t in SUPPORTED_TRANSPORTS.items() if w00t]
+ supported.sort()
+ return supported
+
+def _setDefaultTransport(transport):
+ global DEFAULT_TRANSPORT
+ DEFAULT_TRANSPORT = transport
+
+def _getDefaultTransport():
+ return DEFAULT_TRANSPORT
+
+def _setSupportedTransports(transports):
+ """Set the list of currently supported transports.
+
+ .. note: You shouldn't need to touch this. This is used by the config file
+ parser. You should change the SUPPORTED_TRANSPORTS dictionary in
+ :file:`bridgedb.conf`.
+
+ :param dict transports: A mapping of Pluggable Transport methodnames
+ (strings) to booleans. If the boolean is ``True``, then the Pluggable
+ Transport is one which we will (more easily) distribute to clients.
+ If ``False``, then we (sort of) don't distribute it.
+ """
+ global SUPPORTED_TRANSPORTS
+ SUPPORTED_TRANSPORTS = transports
+
+def _getSupportedAndDefaultTransports():
+ """Get a dictionary of currently supported transports, along with a boolean
+ marking which transport is the default.
+
+ It is returned as a :class:`collections.OrderedDict`, because if it is a
+ regular dict, then the dropdown menu would populated in random order each
+ time the page is rendered. It is sorted in alphabetical order.
+
+ :rtype: :class:`collections.OrderedDict`
+ :returns: An :class:`~collections.OrderedDict` of the Pluggable Transport
+ methodnames from :data:`SUPPORTED_TRANSPORTS` whose value in
+ ``SUPPORTED_TRANSPORTS`` is ``True``. If :data:`DEFAULT_TRANSPORT` is
+ set, then the PT methodname in the ``DEFAULT_TRANSPORT`` setting is
+ added to the :class:`~collections.OrderedDict`, with the value
+ ``True``. Every other transport in the returned ``OrderedDict`` has
+ its value set to ``False``, so that only the one which should be the
+ default PT is ``True``.
+ """
+ supported = _getSupportedTransports()
+ transports = OrderedDict(zip(supported, [False for _ in range(len(supported))]))
+
+ if DEFAULT_TRANSPORT:
+ transports[DEFAULT_TRANSPORT] = True
+
+ return transports
EMAIL_SPRINTF = {
# Goes into the "%s types of Pluggable Transports %s" part of ``WELCOME[0]``
diff --git a/lib/bridgedb/templates/options.html b/lib/bridgedb/templates/options.html
index e765ce7..9486199 100644
--- a/lib/bridgedb/templates/options.html
+++ b/lib/bridgedb/templates/options.html
@@ -87,11 +87,14 @@
accesskey="t">
${_("""No""")}
<option label="none" value="0" >${_("none")}</option>
-<option label="obfs2" value="obfs2" >obfs2</option>
-<option label="obfs3" value="obfs3" selected >obfs3</option>
-<option label="obfs4" value="obfs4" >obfs4</option>
-<option label="scramblesuit" value="scramblesuit">scramblesuit</option>
-<option label="fte" value="fte" >fteproxy</option>
+% for methodname, default in strings._getSupportedAndDefaultTransports().items():
+ <option label=${methodname}
+ value=${methodname}
+ % if default:
+ selected
+ % endif
+ > ${methodname} </option>
+% endfor
</select>
</div>
</div>
More information about the tor-commits
mailing list