summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--service/pixelated/config/arguments.py1
-rw-r--r--service/pixelated/register.py70
-rw-r--r--service/test/unit/config/test_register.py26
3 files changed, 66 insertions, 31 deletions
diff --git a/service/pixelated/config/arguments.py b/service/pixelated/config/arguments.py
index b5f2101a..01152a34 100644
--- a/service/pixelated/config/arguments.py
+++ b/service/pixelated/config/arguments.py
@@ -66,6 +66,7 @@ def parse_register_args():
parser.add_argument('-lc', '--leap-provider-cert', metavar='<leap-provider.crt>', default=None, help='use specified file for LEAP provider cert authority certificate (url https://<LEAP-provider-domain>/ca.crt)')
parser.add_argument('-lf', '--leap-provider-cert-fingerprint', metavar='<leap provider certificate fingerprint>', default=None, help='use specified fingerprint to validate connection with LEAP provider', dest='leap_provider_cert_fingerprint')
parser.add_argument('--leap-home', help='The folder where the user agent stores its data. Defaults to ~/.leap', dest='leap_home', default=os.path.join(os.path.expanduser("~"), '.leap'))
+ parser.add_argument('--invite-code', help='invite code to register a user, if required', dest='invite_code', default=None)
return parser.parse_args()
diff --git a/service/pixelated/register.py b/service/pixelated/register.py
index 994842e9..58798476 100644
--- a/service/pixelated/register.py
+++ b/service/pixelated/register.py
@@ -15,18 +15,16 @@
# along with Pixelated. If not, see <http://www.gnu.org/licenses/>.
import getpass
import re
-import sys
from collections import namedtuple
from leap.bitmask.bonafide.provider import Api
from leap.bitmask.bonafide.session import Session
-from leap.common.events import server as events_server
from pixelated.bitmask_libraries.certs import LeapCertificate
from pixelated.bitmask_libraries.provider import LeapProvider
from pixelated.config import arguments
+from pixelated.config import leap_config
from pixelated.config import logger as logger_config
-from pixelated.authentication import Authentication
-from pixelated.config.sessions import LeapSessionFactory
+from twisted.internet import reactor
from twisted.internet.defer import inlineCallbacks
from twisted.logger import Logger
@@ -36,16 +34,14 @@ logger = Logger()
def _validate(username, password):
- try:
- validate_username(username)
- validate_password(password)
- except ValueError, e:
- print(e.message)
- sys.exit(1)
+ validate_username(username)
+ validate_password(password)
-def _set_provider(provider_cert, provider_cert_fingerprint, server_name):
- events_server.ensure_server()
+def _set_provider(provider_cert, provider_cert_fingerprint, server_name, leap_home=None):
+ if leap_home:
+ leap_config.set_leap_home(leap_home)
+
LeapCertificate.set_cert_and_fingerprint(provider_cert, provider_cert_fingerprint)
provider = LeapProvider(server_name)
provider.setup_ca()
@@ -59,26 +55,25 @@ def _bonafide_session(username, password, provider):
return Session(credentials, srp_provider, provider.local_ca_crt)
-@inlineCallbacks
-def _bootstrap_leap_session(username, password, leap_provider, srp_auth):
- auth = Authentication(username, srp_auth.token, srp_auth.uuid, 'session_id', {'is_admin': False})
- yield LeapSessionFactory(leap_provider).create(username, password, auth)
+def log_results(created, username, server_name):
+ if created:
+ logger.info('User %s@%s successfully registered' % (username, server_name))
+ else:
+ logger.error("Register failed")
@inlineCallbacks
-def register(server_name, username, password, leap_home, provider_cert, provider_cert_fingerprint):
+def register(server_name, username, password, leap_home, provider_cert, provider_cert_fingerprint, invite=None):
if not password:
password = getpass.getpass('Please enter password for %s: ' % username)
_validate(username, password)
- leap_provider = _set_provider(provider_cert, provider_cert_fingerprint, server_name)
+ logger.info('password validated...')
+ leap_provider = _set_provider(provider_cert, provider_cert_fingerprint, server_name, leap_home)
srp_auth = _bonafide_session(username, password, leap_provider)
- created, user = yield srp_auth.signup(username, password, invite=None)
- if created:
- yield _bootstrap_leap_session(username, password, leap_provider, srp_auth)
- else:
- logger.error("Register failed")
+ created, user = yield srp_auth.signup(username, password, invite)
+ log_results(created, username, server_name)
def validate_username(username):
@@ -89,16 +84,31 @@ def validate_username(username):
def validate_password(password):
if len(password) < 8:
+ logger.info('password not validated...')
raise ValueError('The password must have at least 8 characters')
def initialize():
logger_config.init(debug=False)
args = arguments.parse_register_args()
- register(
- args.provider,
- args.username,
- args.password,
- args.leap_home,
- args.leap_provider_cert,
- args.leap_provider_cert_fingerprint)
+
+ def show_error(err):
+ logger.info('error: %s' % err)
+
+ def shut_down(_):
+ reactor.stop()
+
+ def _register():
+ d = register(
+ args.provider,
+ args.username,
+ args.password,
+ args.leap_home,
+ args.leap_provider_cert,
+ args.leap_provider_cert_fingerprint,
+ args.invite_code)
+ d.addErrback(show_error)
+ d.addBoth(shut_down)
+
+ reactor.callWhenRunning(_register)
+ reactor.run()
diff --git a/service/test/unit/config/test_register.py b/service/test/unit/config/test_register.py
index 08cf56f0..d3999dfd 100644
--- a/service/test/unit/config/test_register.py
+++ b/service/test/unit/config/test_register.py
@@ -1,6 +1,8 @@
import unittest
-from pixelated.register import validate_username, validate_password
+from mock import patch, Mock
+from pixelated.register import validate_username, validate_password, _set_provider, register
+from twisted.internet.defer import inlineCallbacks
class TestRegister(unittest.TestCase):
@@ -22,3 +24,25 @@ class TestRegister(unittest.TestCase):
validate_username('a.valid_username-123')
except:
self.fail('Valid username should not raise an exception')
+
+ def test_sets_provider(self):
+ mock_provider = Mock()
+ with patch('pixelated.register.LeapProvider', return_value=mock_provider) as mock_instantiate_provider:
+ provider = _set_provider('mocked_provider_cert', 'mocked_provider_cert_fingerprint', 'mocked_server_name')
+ mock_instantiate_provider.assert_called_once_with('mocked_server_name')
+ self.assertEqual(provider, mock_provider)
+ self.assertTrue(mock_provider.setup_ca.called)
+ self.assertTrue(mock_provider.download_settings.called)
+
+ @patch('pixelated.register._set_provider')
+ @inlineCallbacks
+ def test_register_uses_bonafide_auth(self, mock_set_provider):
+ mock_provider = Mock()
+ mock_provider.api_uri = 'https://pro.vi.der'
+ mock_set_provider.return_value = mock_provider
+ mock_bonafide_session = Mock()
+ mock_bonafide_session.signup.return_value = ('created', 'user')
+ with patch('pixelated.register.Session', return_value=mock_bonafide_session) as mock_instantiate_bonafide_session:
+ yield register('server_name', 'username', 'password', 'leap_home', 'provider_cert', 'provider_cert_fingerprint', 'invite')
+ mock_instantiate_bonafide_session.assert_called_once()
+ mock_bonafide_session.signup.assert_called_once_with('username', 'password', 'invite')