Beast [![Join the chat at https://gitter.im/vinniefalco/Beast](https://badges.gitter.im/vinniefalco/Beast.svg)](https://gitter.im/vinniefalco/Beast?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) [![Build Status] (https://travis-ci.org/vinniefalco/Beast.svg?branch=master)](https://travis-ci.org/vinniefalco/Beast) [![codecov] (https://codecov.io/gh/vinniefalco/Beast/branch/master/graph/badge.svg)](https://codecov.io/gh/vinniefalco/Beast) [![coveralls] (https://coveralls.io/repos/github/vinniefalco/Beast/badge.svg?branch=master)](https://coveralls.io/github/vinniefalco/Beast?branch=master) [![Documentation] (https://img.shields.io/badge/documentation-master-brightgreen.svg)](http://vinniefalco.github.io/beast/) [![License] (https://img.shields.io/badge/license-boost-brightgreen.svg)](LICENSE_1_0.txt) # HTTP and WebSocket implementations built on Boost.Asio --- ## CppCon 2016 I will be giving a lightning talk on Beast at CppCon 2016 in Bellevue, Washington from September 18 to September 22. If you'd like to meet me and hear the talk or ask questions about Beast feel free to approach me in person or send me an email at vinnie.falco@gmail.com to schedule some time. Beast is used in [rippled](https://github.com/ripple/rippled), an open source server application that implements a decentralized cryptocurrency system. About CppCon 2016: http://cppcon.org --- Beast provides implementations of the HTTP and WebSocket protocols built on top of Boost.Asio and other parts of boost. Requirements: * Boost * C++11 or greater * OpenSSL (optional) This software is currently in beta: interfaces are subject to change. For recent changes see [CHANGELOG](CHANGELOG). The library has been submitted to the [Boost Library Incubator](http://rrsd.com/blincubator.com/bi_library/beast-2/?gform_post_id=1579) Example WebSocket program: ```C++ #include #include #include #include #include int main() { // Normal boost::asio setup std::string const host = "echo.websocket.org"; boost::asio::io_service ios; boost::asio::ip::tcp::resolver r(ios); boost::asio::ip::tcp::socket sock(ios); boost::asio::connect(sock, r.resolve(boost::asio::ip::tcp::resolver::query{host, "80"})); // WebSocket connect and send message using beast beast::websocket::stream ws(sock); ws.handshake(host, "/"); ws.write(boost::asio::buffer("Hello, world!")); // Receive WebSocket message, print and close using beast beast::streambuf sb; beast::websocket::opcode op; ws.read(op, sb); ws.close(beast::websocket::close_code::normal); std::cout << to_string(sb.data()) << "\n"; } ``` Example HTTP program: ```C++ #include #include #include #include int main() { // Normal boost::asio setup std::string const host = "boost.org"; boost::asio::io_service ios; boost::asio::ip::tcp::resolver r(ios); boost::asio::ip::tcp::socket sock(ios); boost::asio::connect(sock, r.resolve(boost::asio::ip::tcp::resolver::query{host, "http"})); // Send HTTP request using beast beast::http::request_v1 req; req.method = "GET"; req.url = "/"; req.version = 11; req.headers.replace("Host", host + ":" + std::to_string(sock.remote_endpoint().port())); req.headers.replace("User-Agent", "Beast"); beast::http::prepare(req); beast::http::write(sock, req); // Receive and print HTTP response using beast beast::streambuf sb; beast::http::response_v1 resp; beast::http::read(sock, sb, resp); std::cout << resp; } ``` Links: * [Home](http://vinniefalco.github.io/) * [Repository](https://github.com/vinniefalco/Beast) * [Documentation](http://vinniefalco.github.io/beast/) * [Autobahn.testsuite results](http://vinniefalco.github.io/autobahn/index.html) Please report issues or questions here: https://github.com/vinniefalco/Beast/issues