A Proof of concept of a modern python CLI with click, pydantic, rich and anyio

Overview

httpcli

This project is a proof of concept of a modern python networking cli which can be simple and easy to maintain using some of the best packages in the python ecosystem:

  • click for the foundation of a CLI application. There is also asyncclick that I used in this project which is a tiny wrapper around click to provide asynchronous support.
  • rich for pretty printing in the terminal.
  • httpx for HTTP protocol stuff.
  • anyio for concurrency.
  • pytest and pytest-trio for easy testing.

This is not a complete and mature project like httpie but I want to implement some features not present in this beautiful package like:

  • HTTP2 support
  • more authentication scheme support like digest and oauth2
  • easy cookies support
  • support of posix signals like SIGINT and SIGTERM
  • completion feature
  • git "did you mean" like feature
  • sse support

Evolution

I'm not quite sure if I will continue improving it without any motivation (sponsoring?) but it is already useful if you want to test it, you just need to have poetry dependency manager and install the project locally (poetry install). This will install two commands:

  • http useful when you don't want the cli to verify server certificate.
  • https when you need to verify server certificate.

Usage

Hopefully subcommand usage should be straightforward, but I will point some specific cases.

Usage: http [OPTIONS] COMMAND [ARGS]...

  HTTP CLI

Options:
  --config-file FILENAME          A configuration file with options used to
                                  set the cli. Note that the file takes
                                  precedence over the other options.
  -t, --timeout FLOAT             Time for request to complete, a negative
                                  value means there is no timeout.
  --follow-redirects / -N, --no-follow-redirects
                                  flag to decide if http redirections must be
                                  followed
  --auth JSON_AUTH                A json string representing authentication
                                  information.
  --http-version [h1|h2]          Version of http used to make the request.
  --proxy URL                     Proxy url.
  --version                       Show the version and exit.
  --help                          Show this message and exit.

Commands:
  delete              Performs http DELETE request.
  download            Process download of urls given as arguments.
  get                 Performs http GET request.
  head                Performs http HEAD request.
  install-completion  Install completion script for bash, zsh and fish...
  options             Performs http OPTIONS request.
  patch               Performs http PATCH request.
  post                Performs http POST request.
  put                 Performs http PUT request.
  sse                 Reads and print SSE events on a given url.

Global cli configuration

There are some options that can be configured on the root command. These options can be read from a yaml file using option --config-file. The config file looks lie the following:

# all options have default values, no need to specify them all
httpcli:
  http_version: h2
  follow_redirects: true
  proxy: https://proxy.com
  # timeout may be null to specify that you don't want a timeout
  timeout: 5.0
  auth:
    type: oauth2
    flow: password
    username: user
    password: pass
  # for https you also have the verify option to pass a custom certificate used to authenticate the server
  verify: /path/to/certificate

Those options can also be configured via environment variables. They are all prefixed with HTTP_CLI_ and they can be in lowercase or uppercase. Here is the same configuration as above but using environment variables:

HTTP_CLI_HTTP_VERSION=h2
HTTP_CLI_FOLLOW_REDIRECTS=true
HTTP_CLI_PROXY=https://proxy.com
HTTP_CLI_TIMEOUT=5.0
# here value is passed as json
HTTP_CLI_AUTH={"type": "oauth2", "flow": "password", "username": "user", "password": "pass"}
HTTP_CLI_VERIFY=/path/to/certificate

Commands

install-completion

This is obviously the first command you will want to use to have subcommand and option autocompletion. You don't need to do that for the two cli http and https. Doing it with one will install the other. The current shells supported are bash, zsh and fish. To use autocompletion for subcommands, just enter the first letter and use TAB key twice. For option autocompletion, enter the first dash and use TAB twice.

get, head, option, delete

The usage should be pretty straightforward for these commands.

http get --help
Usage: http get [OPTIONS] URL

  Performs http GET request.

  URL is the target url.

Options:
  -c, --cookie COOKIE  Cookie passed to the request, can by passed multiple
                       times.
  -H, --header HEADER  Header passed to the request, can by passed multiple
                       times.
  -q, --query QUERY    Querystring argument passed to the request, can by
                       passed multiple times.
  --help               Show this message and exit.

You can play with it using https://pie.dev. Here is a simple example:

http get https://pie.dev/get -c my:cookie -q my:query -H X-MY:HEADER

post, put, patch

There are some subtleties with these commands. I will use post in the following examples but the same apply to put and patch.

json data

If you play with json, in case you only have string values, you can do this:

# here we are sending {"foo": "bar", "hello": "world"} to https://pie.dev/post
http post https://pie.dev/post -j foo:bar -j hello:world

If you need to send other values than strings, you will need to pass the json encoded value with a slightly different syntax, := instead of =.

http post https://pie.dev/post -j number:='2' -j boolean:='true' -j fruits:='["apple", "pineapple"]'

If you have a deeply nested structure you can't write simple in the terminal, you can use of json file instead. Considering we have a file fruits.json with the following content:

[
  "apple",
  "pineapple"
]

You can use the file like it:

http post https://pie.dev/post -j fruits:@fruits.json

form data

First you need to know that you can't pass form data and json data in the same request. You must choose between the two methods. The basic usage is the following:

https post https://pie.dev/post -f foo:bar -f number:2

If you need to send files, here is what you can do:

# this will send the key "foo" with the value "bar" and the key "photo" with the file photo.jpg
https post https://pie.dev/post -f foo:bar -f photo:@photo.jpg

If you want to send raw data, use the following form:

https post https://pie.dev/post --raw 'raw content'

You can also pass the raw content in a file:

# you can put what you want in your file, just be sure to set the correct content-type
https post https://pie.dev/post --raw @hello.txt

download

You can pass urls as arguments. Files will be downloaded in the current directory. If you wish to change the directory where files should be put, pass the -d option with the path of the desired destination folder.

# this will downloads two files and put them in the downloads directory of the current user
https download https://pie.dev/image/jpeg https://pie.dev/image/png -d ~/downloads

You can use a file to specify all the resources to download. There should be one url per line. Consider a file urls.txt having the following content:

https://pie.dev/image/svg
https://pie.def/image/webp

You can download urls from the file and urls from the command line at the same time:

https download https://pie.dev/image/jpeg -f urls.txt

sse

If you want to listen sse events from an endpoint, you can simply do this:

# The sse command will not stop if the data are sent without interruption, which is almost always the case
# with sse, so if you want to stop it, just Ctrl + C ;)
https sse https://endpoint.com/sse

What needs to be improved?

If I were to continue the development of the project, here are the points to review/enhance:

  • adapt code to support httpx 1.0 . At the moment of writing it is still in beta, but there is at least one breaking change concerning allow_redirects option.
  • add more authentication schemes, mainly all the oauth2 flows, but may be some others like macaroon...
  • support multiple proxy values
  • session support
  • add CI/CD
  • improve code coverage (not 100% yet)
  • refactor a bit the code, currently I don't like the structure of my helpers modules. Also auth support can be refactored using this technique I was not aware of when starting this project.
  • add autocompletion featurefor other shells like ksh, powershell or powercore
  • and probably more... :)
Owner
Kevin Tewouda
Passionate about python programming and more specifically what affects the web and computer networks. Structured concurrency enthusiast
Kevin Tewouda
Useful additions to Django's default TestCase

django-test-plus Useful additions to Django's default TestCase from REVSYS Rationale Let's face it, writing tests isn't always fun. Part of the reason

REVSYS 546 Dec 22, 2022
Obsei is a low code AI powered automation tool.

Obsei is a low code AI powered automation tool. It can be used in various business flows like social listening, AI based alerting, brand image analysis, comparative study and more .

Obsei 782 Dec 31, 2022
A small automated test structure using python to test *.cpp codes

Get Started Insert C++ Codes Add Test Code Run Test Samples Check Coverages Insert C++ Codes you can easily add c++ files in /inputs directory there i

Alireza Zahiri 2 Aug 03, 2022
A simple asynchronous TCP/IP Connect Port Scanner in Python 3

Python 3 Asynchronous TCP/IP Connect Port Scanner A simple pure-Python TCP Connect port scanner. This application leverages the use of Python's Standa

70 Jan 03, 2023
输入Google Hacking语句,自动调用Chrome浏览器爬取结果

Google-Hacking-Crawler 该脚本可输入Google Hacking语句,自动调用Chrome浏览器爬取结果 环境配置 python -m pip install -r requirements.txt 下载Chrome浏览器

Jarcis 4 Jun 21, 2022
A mocking library for requests

httmock A mocking library for requests for Python 2.7 and 3.4+. Installation pip install httmock Or, if you are a Gentoo user: emerge dev-python/httm

Patryk Zawadzki 452 Dec 28, 2022
Object factory for Django

Model Bakery: Smart fixtures for better tests Model Bakery offers you a smart way to create fixtures for testing in Django. With a simple and powerful

Model Bakers 632 Jan 08, 2023
buX Course Enrollment Automation

buX automation BRACU - buX course enrollment automation Features: Automatically enroll into multiple courses at a time. Find courses just entering cou

Mohammad Shakib 1 Oct 06, 2022
Automação de Processos (obtenção de informações com o Selenium), atualização de Planilha e Envio de E-mail.

Automação de Processo: Código para acompanhar o valor de algumas ações na B3. O código entra no Google Drive, puxa os valores das ações (pré estabelec

Hemili Beatriz 1 Jan 08, 2022
pytest plugin for a better developer experience when working with the PyTorch test suite

pytest-pytorch What is it? pytest-pytorch is a lightweight pytest-plugin that enhances the developer experience when working with the PyTorch test sui

Quansight 39 Nov 18, 2022
Connexion-faker - Auto-generate mocks from your Connexion API using OpenAPI

Connexion Faker Get Started Install With poetry: poetry add connexion-faker # a

Erle Carrara 6 Dec 19, 2022
The Social-Engineer Toolkit (SET) repository from TrustedSec - All new versions of SET will be deployed here.

💼 The Social-Engineer Toolkit (SET) 💼 Copyright 2020 The Social-Engineer Toolkit (SET) Written by: David Kennedy (ReL1K) @HackingDave Company: Trust

trustedsec 8.4k Dec 31, 2022
Code coverage measurement for Python

Coverage.py Code coverage testing for Python. Coverage.py measures code coverage, typically during test execution. It uses the code analysis tools and

Ned Batchelder 2.3k Jan 04, 2023
A configurable set of panels that display various debug information about the current request/response.

Django Debug Toolbar The Django Debug Toolbar is a configurable set of panels that display various debug information about the current request/respons

Jazzband 7.3k Jan 02, 2023
Automated tests for OKAY websites in Python (Selenium) - user friendly version

Okay Selenium Testy Aplikace určená k testování produkčních webů společnosti OKAY s.r.o. Závislosti K běhu aplikace je potřeba mít v počítači nainstal

Viktor Bem 0 Oct 01, 2022
Language-agnostic HTTP API Testing Tool

Dredd — HTTP API Testing Framework Dredd is a language-agnostic command-line tool for validating API description document against backend implementati

Apiary 4k Jan 05, 2023
Cloint India Pvt. Ltd's (ClointFusion) Pythonic RPA (Automation) Platform

Welcome to , Made in India with ❤️ Description Cloint India Pvt. Ltd - Python functions for Robotic Process Automation shortly RPA. What is ClointFusi

Cloint India Pvt. Ltd 31 Apr 12, 2022
Python Rest Testing

pyresttest Table of Contents What Is It? Status Installation Sample Test Examples Installation How Do I Use It? Running A Simple Test Using JSON Valid

Sam Van Oort 1.1k Dec 28, 2022
This package is a python library with tools for the Molecular Simulation - Software Gromos.

This package is a python library with tools for the Molecular Simulation - Software Gromos. It allows you to easily set up, manage and analyze simulations in python.

14 Sep 28, 2022
Automated Security Testing For REST API's

Astra REST API penetration testing is complex due to continuous changes in existing APIs and newly added APIs. Astra can be used by security engineers

Flipkart Incubator 2.1k Dec 31, 2022