/gateau

:cookie: Use your cookies from browsers in your curl, wget and httpie requests!

Primary LanguageRustGNU General Public License v3.0GPL-3.0

gateau 🍰

Demo

Latest release GitHub Workflow Status License

Piping your cookies will be a piece of cake 🍰!

gateau is a command line tool to use your cookies from browsers (Chromium/Chrome and Firefox) in your curl, wget and httpie* requests or export them to a file.

Installation

gateau supports all platforms supported by the browsers and the Rust toolchain, including Linux, macOS and Windows.

SQLite dependency

Please note that if you download one of the pre-built releases, SQLite will be bundled with the executable and gateau will not require SQLite to be installed. If you want to use the system's SQLite instead, you will have to build gateau from source.

From source

# You can remove the `--feautures=bundled` flag if you have SQLite installed
# on your system and want to use the system's SQLite instead of the bundled one.
cargo install --git github.com/musikid/gateau --features=bundled

From binaries

Download the latest release from here.

Usage

gateau can be used to output cookies in different formats, notably netscape format which is used by curl and wget to import cookies from a file, and httpie sessions. It can also be used to wrap commands (curl, wget, httpie) and import cookies directly without having to use shell's process substitution or manually create temporary files. It imports cookies from Firefox by default if the --browser flag is not specified.

Support

Browsers

  • Google Chrome
  • Chromium
  • Microsoft Edge
  • Firefox

Note: Since almost all other browsers are Chrome derivatives, it should be straightforward to add support for them. Please open an issue if you would like to add one!

Output formats

  • Netscape "cookies.txt"
  • httpie session (experimental)

Output (piping) cookies

cookies.txt format (curl, wget)

Since curl and wget can import cookies from a file in Netscape "cookies.txt" format, gateau can be used to output cookies in this format and pipe them to curl/wget.

curl -b <(gateau output --format netscape) https://example.com

In this example, gateau will output cookies from Firefox in Netscape format, and curl will import those which match the requested domains and use them for the request.

wget --load-cookies <(gateau output --browser=chrome --format netscape) https://example.com

Since wget can also import cookies from a file in Netscape "cookies.txt" format, gateau can be used to output cookies in this format and pipe them to wget.

httpie sessions

gateau can also output cookies in httpie sessions format. The support is experimental though, as httpie session format is neither documented nor stable. The current implementation should be compatible with httpie 3.2.0+, but it could change if httpie stop supporting this format in the future.

http --session-read-only <(gateau output --format httpie-session example.com) example.com

In this example, gateau will output cookies from Firefox in httpie session format, and httpie will import it as an anonymous session.

You can also save named sessions, by writing them to file which can be then used with https --session:

# TODO: Maybe add a dedicated feature?
# Just an example, should be changed
HOST=adventofcode.com
SESSION_NAME=aoc
# Usual path for httpie sessions on Unix systems, see https://httpie.io/docs#sessions
# and https://httpie.io/docs/cli/config-file-directory
CONFIG_PATH=${XDG_CONFIG_HOME:-$HOME/.config}
gateau output --format=httpie-session $HOST > $CONFIG_PATH/httpie/sessions/$HOST/$SESSION_NAME.json
https --session=$SESSION_NAME $HOST

Browser session

It is possible to use gateau to create a browser session within a new context, and export the cookies after the session termination.

gateau wrap --browser=chromium --session -- curl https://example.com
gateau output --session https://example.com

Windows users

If you are using Windows, you can either use a shell which supports process substitution (bash, zsh, fish, etc.) or use the wrap command.

Wrapping commands

gateau can also wrap commands (curl, wget, httpie) and import cookies for them.

gateau wrap curl https://example.com

This will wrap the command curl https://example.com and import cookies for the request.

cat data | gateau wrap curl --bypass-lock -- -X POST -d @- httpbin.org/post

This will wrap the command curl -X POST -d @- httpbin.org/post and import cookies for the request. The arguments and standard input are directly forwarded to the wrapped command, so you can use them as usual. They are separated from the gateau arguments by --, so gateau will not parse them. Note that it is optional if you do not use gateau arguments after the wrapped command, e.g:

cat data | gateau wrap curl --bypass-lock -- -X POST -d @- httpbin.org/post

is equivalent to:

cat data | gateau --bypass-lock wrap curl -X POST -d @- httpbin.org/post

httpie is also supported (experimental, as stated in httpie sessions):

gateau wrap --browser=chromium http GET https://example.com

Piping vs wrapping

gateau can be used mostly in two ways to import cookies: piping or wrapping.

Piping with process substitution

Piping is the most common way to use gateau, as it is the most flexible. It allows you to use gateau with any command, as long as the used shell supports process substitution. It is the most secure, as it does not use a temporary file to pass the cookies to the command. However, it is not always possible to use process substitution, as it is not supported by all shells (cmd.exe or Powershell for example).

Wrapping

Wrapping allows you to use gateau with a command without process substitution and avoids having to manually create temporary files, as long as the command is supported by gateau.

Bypass database file locking

Be aware that this flag is not recommended, as it could cause read errors if the database is being modified at the same time, especially with Chrome. The best solution is to wait for the browser to finish its operations and close it.

When Firefox is running, or when Chrome saves its cookies, they lock their database files, so gateau cannot access them. To bypass this, you can use the --bypass-lock flag. Although, the database files are opened in read-only mode, so your cookies should not be altered if an error occurs.

Aliases

You can define aliases to make gateau easier to use. For example, you can add the following aliases to your shell configuration file:

alias curlfire="curl -b <(gateau output --format netscape)"
alias chrul="curl -b <(gateau output --format netscape --browser chromium)"
alias wgetfire="wget --load-cookies <(gateau output --format netscape)"
alias wgetchr="wget --load-cookies <(gateau output --format netscape --browser chromium)"
alias httpfire="http --session-read-only <(gateau output --format httpie-session)"
alias httpchr="http --session-read-only <(gateau output --format httpie-session --browser chromium)"
alias httpsfire="https --session-read-only <(gateau output --format httpie-session)"
alias httpschr="https --session-read-only <(gateau output --format httpie-session --browser chromium)"

Please note that this would probably not work as intended if you use curl with -: and multiple URLs, as the cookies would be imported for the first request only.

Help

> gateau --help

A simple wrapper to import cookies from browsers for curl, wget and httpie.

Usage: gateau [-r=ARG] [--session] [--session-urls=ARG]... [-b=ARG] [--bypass-lock] COMMAND ...

Available options:
    -r, --root-path=ARG     Browser root path
        --session           Open the browser in a new context and use the saved cookies when it
                            closes
        --session-urls=ARG  URLs to open in the session
    -b, --browser=ARG       Browser(s) to import cookies from
        --bypass-lock       Bypass the lock on the database (can cause read errors)
    -h, --help              Prints help information
    -V, --version           Prints version information

Available commands:
    output                  Output cookies to stdout in the specified format
    wrap                    Wrap a command with the imported cookies


> gateau output --help

Output cookies to stdout in the specified format

Usage: [--format ARG] <HOSTS>...

Available positional items:
    <HOSTS>  Hosts to filter cookies by

Available options:
        --format <ARG>  Output format
                        Supported formats: netscape, httpie-session
    -h, --help          Prints help information

> gateau wrap --help

Wrap a command with the imported cookies

Usage: <COMMAND> <ARGS>...

Available positional items:
    <COMMAND>  Command which should be wrapped
               Supported commands: curl, wget, http, https
    <ARGS>     Arguments for the wrapped command

Available options:
    -h, --help  Prints help information

Performance

gateau is written in Rust, so it should be pretty fast, even if it is not really optimized yet. Here are some non-rigorous benchmarks:

Benchmark 1: gateau wrap --bypass-lock curl localhost:8000
  Time (mean ± σ):      10.9 ms ±   2.4 ms    [User: 5.4 ms, System: 5.5 ms]
  Range (min … max):     7.0 ms …  16.6 ms    1000 runs

Benchmark 2: curl -b <(gateau --bypass-lock output) localhost:8000
  Time (mean ± σ):       8.3 ms ±   2.6 ms    [User: 4.3 ms, System: 4.0 ms]
  Range (min … max):     4.1 ms …  15.3 ms    1000 runs

  Warning: Command took less than 5 ms to complete. Note that the results might be inaccurate because hyperfine can not calibrate the shell startup time much more precise than this limit. You can try to use the `-N`/`--shell=none` option to disable the shell completely.

Benchmark 3: curl localhost:8000
  Time (mean ± σ):       7.3 ms ±   2.5 ms    [User: 4.0 ms, System: 3.5 ms]
  Range (min … max):     3.7 ms …  12.3 ms    1000 runs

  Warning: Command took less than 5 ms to complete. Note that the results might be inaccurate because hyperfine can not calibrate the shell startup time much more precise than this limit. You can try to use the `-N`/`--shell=none` option to disable the shell completely.

Summary
  'curl localhost:8000' ran
    1.15 ± 0.54 times faster than 'curl -b <(gateau --bypass-lock output) localhost:8000'
    1.50 ± 0.62 times faster than 'gateau wrap --bypass-lock curl localhost:8000'

The benchmarks were done with hyperfine, with a Firefox cookie database containing around 1000 cookies and most importantly, with a laptop.

The results are not really consistent, as the benchmarks were done on a laptop, but it seems that gateau incurs only a tiny overhead which is not really noticeable in most cases.

Note that it takes more time to import cookies from Chrome than Firefox, since Chrome encrypts its cookies while Firefox does not.