Add --disable-https flag

This commit is contained in:
Erica Ehrhardt 2018-12-24 17:20:30 -08:00
parent c2af5a879c
commit fde84295e0
5 changed files with 28 additions and 11 deletions

View file

@ -58,6 +58,15 @@ You will be redirected to your Mastodon instance to log in and authorize toot to
The application and user access tokens will be saved in the configuration file located at ``~/.config/toot/instances/config.json``.
Disabling HTTPS
~~~~~~~~~~~~~~~
You may pass the ``--disable-https`` flag to use unencrypted HTTP instead of HTTPS for a given instance. This is inherently insecure and should be used only when connecting to local development instances.
.. code-block:: sh
toot login --disable-https --instance localhost:8080
Using multiple accounts
~~~~~~~~~~~~~~~~~~~~~~~

View file

@ -17,8 +17,8 @@ def _account_action(app, user, account, action):
return http.post(app, user, url).json()
def create_app(domain):
url = 'https://{}/api/v1/apps'.format(domain)
def create_app(domain, scheme='https'):
url = '{}://{}/api/v1/apps'.format(scheme, domain)
data = {
'client_name': CLIENT_NAME,

View file

@ -10,7 +10,7 @@ from toot.exceptions import ApiError, ConsoleError
from toot.output import print_out
def register_app(domain):
def register_app(domain, scheme='https'):
print_out("Looking up instance info...")
instance = api.get_instance(domain)
@ -19,11 +19,11 @@ def register_app(domain):
try:
print_out("Registering application...")
response = api.create_app(domain)
response = api.create_app(domain, scheme)
except ApiError:
raise ConsoleError("Registration failed.")
base_url = 'https://' + domain
base_url = scheme + '://' + domain
app = App(domain, base_url, response['client_id'], response['client_secret'])
config.save_app(app)
@ -33,14 +33,14 @@ def register_app(domain):
return app
def create_app_interactive(instance=None):
def create_app_interactive(instance=None, scheme='https'):
if not instance:
print_out("Choose an instance [<green>{}</green>]: ".format(DEFAULT_INSTANCE), end="")
instance = input()
if not instance:
instance = DEFAULT_INSTANCE
return config.load_app(instance) or register_app(instance)
return config.load_app(instance) or register_app(instance, scheme)
def create_user(app, access_token):

View file

@ -96,7 +96,7 @@ def auth(app, user, args):
def login_cli(app, user, args):
app = create_app_interactive(instance=args.instance)
app = create_app_interactive(instance=args.instance, scheme=args.scheme)
login_interactive(app, args.email)
print_out()
@ -104,7 +104,7 @@ def login_cli(app, user, args):
def login(app, user, args):
app = create_app_interactive(instance=args.instance)
app = create_app_interactive(instance=args.instance, scheme=args.scheme)
login_browser_interactive(app)
print_out()

View file

@ -56,18 +56,26 @@ email_arg = (["-e", "--email"], {
"help": 'email address to log in with',
})
scheme_arg = (["--disable-https"], {
"help": "disable HTTPS and use insecure HTTP",
"dest": "scheme",
"default": "https",
"action": "store_const",
"const": "http",
})
AUTH_COMMANDS = [
Command(
name="login",
description="Log into a mastodon instance using your browser (recommended)",
arguments=[instance_arg],
arguments=[instance_arg, scheme_arg],
require_auth=False,
),
Command(
name="login_cli",
description="Log in from the console, does NOT support two factor authentication",
arguments=[instance_arg, email_arg],
arguments=[instance_arg, email_arg, scheme_arg],
require_auth=False,
),
Command(