mirror of
https://github.com/httpie/cli.git
synced 2025-01-17 02:58:32 +01:00
Merge pull request #197 from matleh/master
add support for client SSL certificate and key
This commit is contained in:
commit
2c885b0981
@ -30,3 +30,4 @@ Patches and ideas
|
|||||||
* `cido <https://github.com/cido>`_
|
* `cido <https://github.com/cido>`_
|
||||||
* `Justin Bonnar <https://github.com/jargonjustin>`_
|
* `Justin Bonnar <https://github.com/jargonjustin>`_
|
||||||
* `Nathan LaFreniere <https://github.com/nlf>`_
|
* `Nathan LaFreniere <https://github.com/nlf>`_
|
||||||
|
* `Matthias Lehmann <https://github.com/matleh>`
|
||||||
|
@ -615,6 +615,10 @@ To skip the host's SSL certificate verification, you can pass ``--verify=no``
|
|||||||
path. The path can also be configured via the environment variable
|
path. The path can also be configured via the environment variable
|
||||||
``REQUESTS_CA_BUNDLE``.
|
``REQUESTS_CA_BUNDLE``.
|
||||||
|
|
||||||
|
To use a client side certificate for the SSL communication, you can pass the
|
||||||
|
path of the cert file with ``--cert``. If the private key is not contained
|
||||||
|
in the cert file you may pass the path of the key file with ``--certkey``.
|
||||||
|
|
||||||
|
|
||||||
==============
|
==============
|
||||||
Output Options
|
Output Options
|
||||||
@ -1265,6 +1269,8 @@ Changelog
|
|||||||
*You can click a version name to see a diff with the previous one.*
|
*You can click a version name to see a diff with the previous one.*
|
||||||
|
|
||||||
* `0.9.0-dev`_
|
* `0.9.0-dev`_
|
||||||
|
* Added ``--cert`` and ``--certkey`` parameters to specify a client side
|
||||||
|
certificate and private key for SSL
|
||||||
* `0.8.0`_ (2014-01-25)
|
* `0.8.0`_ (2014-01-25)
|
||||||
* Added ``field=@file.txt`` and ``field:=@file.json`` for embedding
|
* Added ``field=@file.txt`` and ``field:=@file.json`` for embedding
|
||||||
the contents of text and JSON files into request data.
|
the contents of text and JSON files into request data.
|
||||||
|
@ -18,7 +18,8 @@ from .input import (Parser, AuthCredentialsArgType, KeyValueArgType,
|
|||||||
SEP_PROXY, SEP_CREDENTIALS, SEP_GROUP_ALL_ITEMS,
|
SEP_PROXY, SEP_CREDENTIALS, SEP_GROUP_ALL_ITEMS,
|
||||||
OUT_REQ_HEAD, OUT_REQ_BODY, OUT_RESP_HEAD,
|
OUT_REQ_HEAD, OUT_REQ_BODY, OUT_RESP_HEAD,
|
||||||
OUT_RESP_BODY, OUTPUT_OPTIONS, OUTPUT_OPTIONS_DEFAULT,
|
OUT_RESP_BODY, OUTPUT_OPTIONS, OUTPUT_OPTIONS_DEFAULT,
|
||||||
PRETTY_MAP, PRETTY_STDOUT_TTY_ONLY, SessionNameValidator)
|
PRETTY_MAP, PRETTY_STDOUT_TTY_ONLY, SessionNameValidator,
|
||||||
|
readable_file_arg)
|
||||||
|
|
||||||
|
|
||||||
class HTTPieHelpFormatter(RawDescriptionHelpFormatter):
|
class HTTPieHelpFormatter(RawDescriptionHelpFormatter):
|
||||||
@ -465,6 +466,29 @@ network.add_argument(
|
|||||||
"""
|
"""
|
||||||
)
|
)
|
||||||
|
|
||||||
|
network.add_argument(
|
||||||
|
'--cert',
|
||||||
|
default=None,
|
||||||
|
type=readable_file_arg,
|
||||||
|
help="""
|
||||||
|
You can specify a local cert to use as client side SSL certificate.
|
||||||
|
This file may either contain both private key and certificate or you may
|
||||||
|
specify --certkey separately.
|
||||||
|
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
|
network.add_argument(
|
||||||
|
'--certkey',
|
||||||
|
default=None,
|
||||||
|
type=readable_file_arg,
|
||||||
|
help="""
|
||||||
|
The private key to use with SSL. Only needed if --cert is given and the
|
||||||
|
certificate file does not contain the private key.
|
||||||
|
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
network.add_argument(
|
network.add_argument(
|
||||||
'--timeout',
|
'--timeout',
|
||||||
type=float,
|
type=float,
|
||||||
|
@ -73,6 +73,12 @@ def get_requests_kwargs(args):
|
|||||||
auth_plugin = plugin_manager.get_auth_plugin(args.auth_type)()
|
auth_plugin = plugin_manager.get_auth_plugin(args.auth_type)()
|
||||||
credentials = auth_plugin.get_auth(args.auth.key, args.auth.value)
|
credentials = auth_plugin.get_auth(args.auth.key, args.auth.value)
|
||||||
|
|
||||||
|
cert = None
|
||||||
|
if args.cert:
|
||||||
|
cert = args.cert
|
||||||
|
if args.certkey:
|
||||||
|
cert = (cert, args.certkey)
|
||||||
|
|
||||||
kwargs = {
|
kwargs = {
|
||||||
'stream': True,
|
'stream': True,
|
||||||
'method': args.method.lower(),
|
'method': args.method.lower(),
|
||||||
@ -83,6 +89,7 @@ def get_requests_kwargs(args):
|
|||||||
'yes': True,
|
'yes': True,
|
||||||
'no': False
|
'no': False
|
||||||
}.get(args.verify, args.verify),
|
}.get(args.verify, args.verify),
|
||||||
|
'cert': cert,
|
||||||
'timeout': args.timeout,
|
'timeout': args.timeout,
|
||||||
'auth': credentials,
|
'auth': credentials,
|
||||||
'proxies': dict((p.key, p.value) for p in args.proxy),
|
'proxies': dict((p.key, p.value) for p in args.proxy),
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
"""Parsing and processing of CLI input (args, auth credentials, files, stdin).
|
"""Parsing and processing of CLI input (args, auth credentials, files, stdin).
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
import argparse
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import re
|
import re
|
||||||
@ -630,3 +631,12 @@ def parse_items(items, data=None, headers=None, files=None, params=None):
|
|||||||
target[item.key] = value
|
target[item.key] = value
|
||||||
|
|
||||||
return headers, data, files, params
|
return headers, data, files, params
|
||||||
|
|
||||||
|
|
||||||
|
def readable_file_arg(filename):
|
||||||
|
try:
|
||||||
|
open(filename, 'rb')
|
||||||
|
except IOError as ex:
|
||||||
|
raise argparse.ArgumentTypeError(
|
||||||
|
'%s: %s' % (filename, ex.args[1]))
|
||||||
|
return filename
|
||||||
|
@ -44,3 +44,4 @@ def humanize_bytes(n, precision=2):
|
|||||||
break
|
break
|
||||||
|
|
||||||
return '%.*f %s' % (precision, n / factor, suffix)
|
return '%.*f %s' % (precision, n / factor, suffix)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user