HTTPStream
HTTPStream is a tiny, tiny package that wraps HTTP requests into a Stream so
that you can manage data on the fly, without keeping everything in memory.
Downloading an image:
HTTPStream.get(large_image_url)
|> Stream.into(File.stream!("large_image.png"))
|> Stream.run()Streaming multiple images into a ZIP archive (using zstream)
[
Zstream.entry("a.png", HTTPStream.get(a_url))
Zstream.entry("b.png", HTTPStream.get(b_url))
]
|> Zstream.zip()
|> Stream.into(File.stream!("archive.zip"))
|> Stream.run()Table of Contents
Installation
First, you need to add http_stream to your list of dependencies on mix.exs:
def deps do
[
{:http_stream, "~> 1.0.0"},
# if using the Mint adapter:
{:castore, "~> 0.1.7"},
{:mint, "~> 1.1.0"}
# if using the HTTPoison adapter:
{:httpoison, "~> 1.7.0"}
]
endHTTPStream comes with two adapters: Mint and HTTPoison.
By default Mint is configured but you need to include it in your dependencies.
To use HTTPoison, set in your config/config.exs:
config :http_stream, adapter: HTTPStream.Adapter.HTTPoisonThat's it! For more intricate API details, refer to the documentation.
Development
If you want to setup the project for local development, you can just run the following commands.
git clone git@github.com:subvisual/http_stream.git
cd http_stream
bin/setupPRs and issues welcome.
Contributing
Feel free to contribute!
If you found a bug, open an issue. You can also open a PR for bugs or new features. Your PRs will be reviewed and subjected to our styleguide and linters.
All contributions must follow the Code of Conduct and Subvisual's guides.
About
HTTPStream is maintained with ❤️ by Subvisual.
