README.md revision aff2a1d8
19918a066SDmitri Tikhonov[![Build Status](https://travis-ci.org/litespeedtech/lsquic-client.svg?branch=master)](https://travis-ci.org/litespeedtech/lsquic-client) 21fc8f998SDmitri Tikhonov 350aadb33SDmitri TikhonovLiteSpeed QUIC (LSQUIC) Client Library README 450aadb33SDmitri Tikhonov============================================= 550aadb33SDmitri Tikhonov 650aadb33SDmitri TikhonovDescription 750aadb33SDmitri Tikhonov----------- 850aadb33SDmitri Tikhonov 950aadb33SDmitri TikhonovLiteSpeed QUIC (LSQUIC) Client Library is an open-source implementation 1050aadb33SDmitri Tikhonovof QUIC functionality for clients. It is released in the hope to speed 1150aadb33SDmitri Tikhonovthe adoption of QUIC. Most of the code in this distribution is used in 1250aadb33SDmitri Tikhonovour own products: LiteSpeed Web Server and ADC. We think it is free of 1350aadb33SDmitri Tikhonovmajor problems. Nevertheless, do not hesitate to report bugs back to us. 1450aadb33SDmitri TikhonovEven better, send us fixes and improvements! 1550aadb33SDmitri Tikhonov 16aff2a1d8SDmitri TikhonovCurrently supported QUIC versions are Q035, Q037, Q038, Q039, Q041, 17aff2a1d8SDmitri Tikhonovand Q042. Support for newer versions will be added soon after they 18aff2a1d8SDmitri Tikhonovare released. The version(s) specified by IETF QUIC WG will be added 19aff2a1d8SDmitri Tikhonovonce the IETF version of the protocol settles down a little. 2050aadb33SDmitri Tikhonov 2150aadb33SDmitri TikhonovDocumentation 2250aadb33SDmitri Tikhonov------------- 2350aadb33SDmitri Tikhonov 2450aadb33SDmitri TikhonovThe documentation for this module is admittedly sparse. The API is 2550aadb33SDmitri Tikhonovdocumented in include/lsquic.h. If you have doxygen, you can run 26e0197994SDmitri Tikhonov`doxygen dox.cfg` or `make docs`. The example program is 2750aadb33SDmitri Tikhonovtest/http_client.c: a bare-bones, but working, QUIC client. Have a look 2850aadb33SDmitri Tikhonovin EXAMPLES.txt to see how it can be used. 2950aadb33SDmitri Tikhonov 30e0197994SDmitri TikhonovRequirements 31e0197994SDmitri Tikhonov------------ 3250aadb33SDmitri Tikhonov 33e0197994SDmitri TikhonovTo build LSQUIC, you need CMake, zlib, and BoringSSL. The example program 34e0197994SDmitri Tikhonovuses libevent to provide the event loop. 3550aadb33SDmitri Tikhonov 36e0197994SDmitri TikhonovBuilding BoringSSL 37e0197994SDmitri Tikhonov------------------ 38e0197994SDmitri Tikhonov 39e0197994SDmitri TikhonovBoringSSL is not packaged; you have to build it yourself. The process is 40e0197994SDmitri Tikhonovstraightforward. You will need `go` installed. 41e0197994SDmitri Tikhonov 42e0197994SDmitri Tikhonov1. Clone BoringSSL by issuing the following command: 43e0197994SDmitri Tikhonov 44e0197994SDmitri Tikhonov``` 45e0197994SDmitri Tikhonovgit clone https://boringssl.googlesource.com/boringssl 46e0197994SDmitri Tikhonovcd boringssl 47e0197994SDmitri Tikhonov``` 48e0197994SDmitri Tikhonov 49e0197994SDmitri Tikhonov2. Check out stable branch: 50e0197994SDmitri Tikhonov 51e0197994SDmitri Tikhonov``` 5267b0dc15SDmitri Tikhonovgit checkout chromium-stable 53e0197994SDmitri Tikhonov``` 54e0197994SDmitri Tikhonov 55e0197994SDmitri Tikhonov3. Compile the library 56e0197994SDmitri Tikhonov 57e0197994SDmitri Tikhonov``` 58e0197994SDmitri Tikhonovcmake . && make 59e0197994SDmitri Tikhonov``` 60e0197994SDmitri Tikhonov 61e0197994SDmitri TikhonovIf you want to turn on optimizations, do 62e0197994SDmitri Tikhonov 63e0197994SDmitri Tikhonov``` 64e0197994SDmitri Tikhonovcmake -DCMAKE_BUILD_TYPE=Release . && make 65e0197994SDmitri Tikhonov``` 66e0197994SDmitri Tikhonov 67e0197994SDmitri Tikhonov4. Install the library 68e0197994SDmitri Tikhonov 69e0197994SDmitri TikhonovThis is the manual step. You will need to copy library files manually. 70e0197994SDmitri TikhonovLSQUIC client library needs two: `ssl/libssl.a` and `crypto/libcrypto.a`. 71e0197994SDmitri TikhonovTo install these in `/usr/local/lib`, you should do the following: 72e0197994SDmitri Tikhonov 73e0197994SDmitri Tikhonov``` 74e0197994SDmitri TikhonovBORINGSSL_SOURCE=$PWD 75e0197994SDmitri Tikhonovcd /usr/local/lib 7667b0dc15SDmitri Tikhonovsudo cp $BORINGSSL_SOURCE/ssl/libssl.a . 7767b0dc15SDmitri Tikhonovsudo cp $BORINGSSL_SOURCE/crypto/libcrypto.a . 78e0197994SDmitri Tikhonov``` 79e0197994SDmitri Tikhonov 80e0197994SDmitri TikhonovIf you do not want to install the library (or do not have root), you 81e0197994SDmitri Tikhonovcan do this instead: 82e0197994SDmitri Tikhonov 83e0197994SDmitri Tikhonov``` 84e0197994SDmitri TikhonovBORINGSSL_SOURCE=$PWD 85e0197994SDmitri Tikhonovmkdir -p $HOME/tmp/boringssl-libs 86e0197994SDmitri Tikhonovcd $HOME/tmp/boringssl-libs 87e0197994SDmitri Tikhonovln -s $BORINGSSL_SOURCE/ssl/libssl.a 88e0197994SDmitri Tikhonovln -s $BORINGSSL_SOURCE/crypto/libcrypto.a 89e0197994SDmitri Tikhonov``` 90e0197994SDmitri Tikhonov 91e0197994SDmitri TikhonovBuilding LSQUIC Client Library 92e0197994SDmitri Tikhonov------------------------------ 93e0197994SDmitri Tikhonov 94e0197994SDmitri TikhonovLSQUIC's `http_client` and the tests link BoringSSL libraries statically. 95e0197994SDmitri TikhonovFollowing previous section, you can build LSQUIC as follows: 96e0197994SDmitri Tikhonov 9767b0dc15SDmitri Tikhonov1. Get the source code 9867b0dc15SDmitri Tikhonov 9967b0dc15SDmitri Tikhonov``` 10067b0dc15SDmitri Tikhonovgit clone https://github.com/litespeedtech/lsquic-client.git 10167b0dc15SDmitri Tikhonovcd lsquic-client 10267b0dc15SDmitri Tikhonov``` 10367b0dc15SDmitri Tikhonov 10467b0dc15SDmitri Tikhonov2. Compile the library 10567b0dc15SDmitri Tikhonov 10667b0dc15SDmitri Tikhonov 107e0197994SDmitri Tikhonov``` 108e0197994SDmitri Tikhonovcmake -DBORINGSSL_INCLUDE=$BORINGSSL_SOURCE/include \ 109e0197994SDmitri Tikhonov -DBORINGSSL_LIB=$HOME/tmp/boringssl-libs . 110e0197994SDmitri Tikhonovmake 111e0197994SDmitri Tikhonov``` 112e0197994SDmitri Tikhonov 11367b0dc15SDmitri Tikhonov3. Run tests 114e0197994SDmitri Tikhonov 115e0197994SDmitri Tikhonov``` 116e0197994SDmitri Tikhonovmake test 117e0197994SDmitri Tikhonov``` 118e0197994SDmitri Tikhonov 119306ecefeSBrian ProdoehlBuilding with Docker 120306ecefeSBrian Prodoehl--------- 121306ecefeSBrian ProdoehlThe library and http_client example can be built with Docker. 122306ecefeSBrian Prodoehl``` 123306ecefeSBrian Prodoehldocker build -t lsquic-client . 124306ecefeSBrian Prodoehl``` 125306ecefeSBrian Prodoehl 126306ecefeSBrian ProdoehlThen you can use the http_client example from the command line. 127306ecefeSBrian Prodoehl``` 128306ecefeSBrian Prodoehldocker run -it --rm lsquic-client http_client -H www.google.com -s 74.125.22.106:443 -p / 129306ecefeSBrian Prodoehl``` 130306ecefeSBrian Prodoehl 131e0197994SDmitri TikhonovPlatforms 132e0197994SDmitri Tikhonov--------- 133e0197994SDmitri Tikhonov 134e0197994SDmitri TikhonovThe client library has been tested on the following platforms: 135e0197994SDmitri Tikhonov- Linux 136aff2a1d8SDmitri Tikhonov - i386 137e0197994SDmitri Tikhonov - x86_64 138e0197994SDmitri Tikhonov - ARM (Raspberry Pi 3) 139e0197994SDmitri Tikhonov- FreeBSD 140e0197994SDmitri Tikhonov - i386 141da710addSDmitri Tikhonov- Windows 142da710addSDmitri Tikhonov - x86_64 143e0197994SDmitri Tikhonov- MacOS 144e0197994SDmitri Tikhonov - x86_64 14550aadb33SDmitri Tikhonov 14650aadb33SDmitri TikhonovHave fun, 14750aadb33SDmitri Tikhonov 14850aadb33SDmitri TikhonovLiteSpeed QUIC Team. 14950aadb33SDmitri Tikhonov 1505296a94bSDmitri TikhonovCopyright (c) 2017 - 2018 LiteSpeed Technologies Inc 151