laag-libzmq 4.2.3.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +57 -0
- data/LICENSE.txt +181 -0
- data/README.org +34 -0
- data/ext/laag/libzmq/extconf.rb +22 -0
- data/laag-libzmq.gemspec +21 -0
- data/lib/laag/libzmq.rb +31 -0
- data/vendor/github.com/zeromq/libzmq/.github/PULL_REQUEST_TEMPLATE.md +28 -0
- data/vendor/github.com/zeromq/libzmq/.github/issue_template.md +22 -0
- data/vendor/github.com/zeromq/libzmq/.gitignore +180 -0
- data/vendor/github.com/zeromq/libzmq/.hgeol +2 -0
- data/vendor/github.com/zeromq/libzmq/.mailmap +81 -0
- data/vendor/github.com/zeromq/libzmq/.travis.yml +115 -0
- data/vendor/github.com/zeromq/libzmq/AUTHORS +151 -0
- data/vendor/github.com/zeromq/libzmq/CMakeLists.txt +1104 -0
- data/vendor/github.com/zeromq/libzmq/COPYING +674 -0
- data/vendor/github.com/zeromq/libzmq/COPYING.LESSER +181 -0
- data/vendor/github.com/zeromq/libzmq/Dockerfile +11 -0
- data/vendor/github.com/zeromq/libzmq/Doxygen.cfg +2320 -0
- data/vendor/github.com/zeromq/libzmq/FindSodium.cmake +40 -0
- data/vendor/github.com/zeromq/libzmq/INSTALL +311 -0
- data/vendor/github.com/zeromq/libzmq/Jenkinsfile +369 -0
- data/vendor/github.com/zeromq/libzmq/Makefile.am +908 -0
- data/vendor/github.com/zeromq/libzmq/NEWS +1582 -0
- data/vendor/github.com/zeromq/libzmq/README.cygwin.md +15 -0
- data/vendor/github.com/zeromq/libzmq/README.doxygen.md +48 -0
- data/vendor/github.com/zeromq/libzmq/README.md +102 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/AndreLouisCaron.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/Asmod4n.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/BerndPrager.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/Bklyn.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/BrianBuchanan.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ChuckRemes.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/FrancoFichtner.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/GavinMcNiff.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/GhislainPutois.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/GiuseppeCorbelli.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/HaraldAchitz.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/Hugne.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/JimHague.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/JohanMabille.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/LeonardMichelet +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/LeonardoConsoni.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/LionelOrry.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/OsirisPedroso.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/README.md +23 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/RobGagnon.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/SebastienRombauts.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/StoianIvanov.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/SylvainCorlay.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/TimotheeBesset.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/VincentTellier.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/VolodymyrKorniichuk.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/abbradar.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/agronholm.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/amuraru.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/arsenm.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/aseering.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/bjorntopel.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/bjovke.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/brocade_communications_systems.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/brunobodin.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/c-rack.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/camachat.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/cdolan.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/chrisstaite.md +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/chugga_fan.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/cjuniet.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ckamm.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/clkao.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/danielhtshih.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/danriegsecker.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/dfons.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/djelenc.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/drodri.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/eburkitt.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/egomotion.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/evoskuil.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/febeling.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/fidlej.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/flub.md +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/gena-moscow.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/gonzus.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/goodfella_ltd.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/google.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ianbarber.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/imatix.md +23 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jakecobb.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jemc.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jimklimov.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jkryl.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/johntconklin.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jruffin.md +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/kentzo.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/kevinsapper.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/kobolog.md +12 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/kurdybacha.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/linville.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/loachfish.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/lodagro.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/madebr.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mattconnolly.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mauri-melato.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mditzel.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/meox.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/michael-fox.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/michicc.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/minrk.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mipaaa.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mkluwe.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/montoyaedu.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/naos_ltd.md +19 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/natano.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/olafmandel.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/pijyoi.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ptroja.md +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/reunanen.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/reza-ebrahimi.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/rikvdh.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/rlenferink.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/roalz.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/rodgert.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/rotty.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/sabae.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/scemama.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/sheremetyev.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/shripchenko.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/sigiesec.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/soulik.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/swansontec.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/t-b.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/tSed.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/tabe.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/tailhook.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/taotetek.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2-any-osi.txt +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2-share-alike-osi.txt +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2.txt +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/thompsa.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/torehalvorsen.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/twhittock.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ulikoehler.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/vyskocilm.md +7 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/willstrang.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/xaqq.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/yuvallanger.md +15 -0
- data/vendor/github.com/zeromq/libzmq/ZeroMQConfig.cmake.in +25 -0
- data/vendor/github.com/zeromq/libzmq/acinclude.m4 +1122 -0
- data/vendor/github.com/zeromq/libzmq/appveyor.yml +97 -0
- data/vendor/github.com/zeromq/libzmq/autogen.sh +49 -0
- data/vendor/github.com/zeromq/libzmq/branding.bmp +0 -0
- data/vendor/github.com/zeromq/libzmq/builds/Makefile.am +31 -0
- data/vendor/github.com/zeromq/libzmq/builds/README +4 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/Dockerfile +22 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/README.md +78 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/android_build_helper.sh +316 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/build.sh +70 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/ci_build.sh +30 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/FindAsciiDoc.cmake +26 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/TestZMQVersion.cmake +8 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/ZMQSourceRunChecks.cmake +301 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/NSIS.template32.in +952 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/NSIS.template64.in +960 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/ci_build.sh +34 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/platform.hpp.in +104 -0
- data/vendor/github.com/zeromq/libzmq/builds/coverage/ci_build.sh +32 -0
- data/vendor/github.com/zeromq/libzmq/builds/cygwin/Makefile.cygwin +48 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/.gitignore +5 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/build.bat +4 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/platform.hpp +80 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.gsl +19 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.gypi +895 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.xml +83 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/project.gyp +295 -0
- data/vendor/github.com/zeromq/libzmq/builds/mingw32/Makefile.mingw32 +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/mingw32/platform.hpp +43 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/.gitignore +256 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/Makefile.am +94 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/build/build.bat +33 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/build/buildall.bat +16 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/build/buildbase.bat +73 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/errno.cpp +32 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/errno.hpp +56 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/platform.hpp +14 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Common.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DLL.props +16 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Debug.props +29 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugDEXE.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugDLL.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLEXE.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLIB.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLTCG.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugSEXE.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/EXE.props +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/LIB.props +16 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/LTCG.props +13 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Link.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Messages.props +15 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Output.props +30 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Release.props +41 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseDEXE.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseDLL.props +19 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLEXE.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLIB.props +19 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLTCG.props +19 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseSEXE.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Win32.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/x64.props +23 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/readme.txt +27 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/resource.h +14 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/resource.rc +0 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/inproc_lat/inproc_lat.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/inproc_thr/inproc_thr.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/libzmq.sln +95 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/libzmq/libzmq.vcproj +338 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/local_lat/local_lat.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/local_thr/local_thr.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/remote_lat/remote_lat.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/remote_thr/remote_thr.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.sln +206 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.sln +206 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.sln +208 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.sln +208 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/libzmq.vcxproj +258 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/platform.hpp +15 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/test_zmq/test_multithread.cpp +229 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/test_zmq/test_zmq.vcxproj +155 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.sln +208 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/nuget/libzmq.autopkg +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/nuget/readme.nuget +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/openwrt/Makefile +70 -0
- data/vendor/github.com/zeromq/libzmq/builds/valgrind/ci_build.sh +30 -0
- data/vendor/github.com/zeromq/libzmq/builds/valgrind/valgrind.supp +22 -0
- data/vendor/github.com/zeromq/libzmq/builds/valgrind/vg +1 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/README.md +463 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/cxxall +62 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/makeclean +36 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/makelibzmq +54 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/maketests +102 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/platform.hpp +300 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/runtests +188 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/test_fork.cpp +95 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/zc++ +42 -0
- data/vendor/github.com/zeromq/libzmq/ci_build.sh +66 -0
- data/vendor/github.com/zeromq/libzmq/ci_deploy.sh +34 -0
- data/vendor/github.com/zeromq/libzmq/configure.ac +827 -0
- data/vendor/github.com/zeromq/libzmq/doc/Makefile.am +64 -0
- data/vendor/github.com/zeromq/libzmq/doc/asciidoc.conf +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq.txt +276 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_dec.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_destroy.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_inc.txt +61 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_new.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_set.txt +61 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_value.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_bind.txt +103 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_close.txt +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_connect.txt +101 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_destroy.txt +67 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_get.txt +105 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_new.txt +50 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_set.txt +184 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_shutdown.txt +52 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_term.txt +68 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_curve.txt +92 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_curve_keypair.txt +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_curve_public.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_disconnect.txt +75 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_errno.txt +50 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_getsockopt.txt +944 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_gssapi.txt +78 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_has.txt +44 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_init.txt +52 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_inproc.txt +88 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ipc.txt +106 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_close.txt +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_copy.txt +72 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_data.txt +48 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_get.txt +83 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_gets.txt +81 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init.txt +64 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init_data.txt +89 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init_size.txt +58 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_more.txt +65 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_move.txt +52 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_recv.txt +124 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_routing_id.txt +61 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_send.txt +127 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_set.txt +46 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_set_routing_id.txt +46 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_size.txt +48 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_null.txt +27 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_pgm.txt +164 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_plain.txt +37 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_poll.txt +135 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_proxy.txt +99 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_proxy_steerable.txt +111 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_recv.txt +91 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_recvmsg.txt +121 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_send.txt +104 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_send_const.txt +103 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_sendmsg.txt +121 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_setsockopt.txt +1318 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_socket.txt +609 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_socket_monitor.txt +294 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_strerror.txt +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_tcp.txt +118 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_term.txt +66 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_tipc.txt +83 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_udp.txt +99 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_unbind.txt +90 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_version.txt +54 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_vmci.txt +97 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_z85_decode.txt +51 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_z85_encode.txt +58 -0
- data/vendor/github.com/zeromq/libzmq/include/zmq.h +708 -0
- data/vendor/github.com/zeromq/libzmq/include/zmq_utils.h +48 -0
- data/vendor/github.com/zeromq/libzmq/installer.ico +0 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_check_compile_flag.m4 +74 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_code_coverage.m4 +264 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_cxx_compile_stdcxx.m4 +562 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_cxx_compile_stdcxx_11.m4 +40 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_valgrind_check.m4 +233 -0
- data/vendor/github.com/zeromq/libzmq/packaging/README +4 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/changelog +5 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/compat +1 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/control +64 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/copyright +93 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq3-dev.install +4 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq3-dev.manpages +2 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq5.docs +2 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq5.install +1 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/rules +67 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/source/format +1 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/zeromq.dsc.obs +15 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.bat +14 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.config +6 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.gsl +264 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.nuspec +98 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.targets +129 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.xml +22 -0
- data/vendor/github.com/zeromq/libzmq/packaging/obs/_service +98 -0
- data/vendor/github.com/zeromq/libzmq/packaging/redhat/zeromq.spec +234 -0
- data/vendor/github.com/zeromq/libzmq/perf/inproc_lat.cpp +240 -0
- data/vendor/github.com/zeromq/libzmq/perf/inproc_thr.cpp +250 -0
- data/vendor/github.com/zeromq/libzmq/perf/local_lat.cpp +116 -0
- data/vendor/github.com/zeromq/libzmq/perf/local_thr.cpp +160 -0
- data/vendor/github.com/zeromq/libzmq/perf/remote_lat.cpp +129 -0
- data/vendor/github.com/zeromq/libzmq/perf/remote_thr.cpp +135 -0
- data/vendor/github.com/zeromq/libzmq/src/address.cpp +134 -0
- data/vendor/github.com/zeromq/libzmq/src/address.hpp +77 -0
- data/vendor/github.com/zeromq/libzmq/src/array.hpp +167 -0
- data/vendor/github.com/zeromq/libzmq/src/atomic_counter.hpp +249 -0
- data/vendor/github.com/zeromq/libzmq/src/atomic_ptr.hpp +227 -0
- data/vendor/github.com/zeromq/libzmq/src/blob.hpp +186 -0
- data/vendor/github.com/zeromq/libzmq/src/client.cpp +116 -0
- data/vendor/github.com/zeromq/libzmq/src/client.hpp +81 -0
- data/vendor/github.com/zeromq/libzmq/src/clock.cpp +253 -0
- data/vendor/github.com/zeromq/libzmq/src/clock.hpp +83 -0
- data/vendor/github.com/zeromq/libzmq/src/command.hpp +188 -0
- data/vendor/github.com/zeromq/libzmq/src/condition_variable.hpp +279 -0
- data/vendor/github.com/zeromq/libzmq/src/config.hpp +98 -0
- data/vendor/github.com/zeromq/libzmq/src/ctx.cpp +644 -0
- data/vendor/github.com/zeromq/libzmq/src/ctx.hpp +242 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_client.cpp +297 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_client.hpp +87 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_client_tools.hpp +307 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_mechanism_base.cpp +181 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_mechanism_base.hpp +79 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_server.cpp +492 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_server.hpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/dbuffer.hpp +144 -0
- data/vendor/github.com/zeromq/libzmq/src/dealer.cpp +143 -0
- data/vendor/github.com/zeromq/libzmq/src/dealer.hpp +89 -0
- data/vendor/github.com/zeromq/libzmq/src/decoder.hpp +198 -0
- data/vendor/github.com/zeromq/libzmq/src/decoder_allocators.cpp +144 -0
- data/vendor/github.com/zeromq/libzmq/src/decoder_allocators.hpp +155 -0
- data/vendor/github.com/zeromq/libzmq/src/devpoll.cpp +205 -0
- data/vendor/github.com/zeromq/libzmq/src/devpoll.hpp +119 -0
- data/vendor/github.com/zeromq/libzmq/src/dgram.cpp +177 -0
- data/vendor/github.com/zeromq/libzmq/src/dgram.hpp +81 -0
- data/vendor/github.com/zeromq/libzmq/src/dish.cpp +360 -0
- data/vendor/github.com/zeromq/libzmq/src/dish.hpp +125 -0
- data/vendor/github.com/zeromq/libzmq/src/dist.cpp +235 -0
- data/vendor/github.com/zeromq/libzmq/src/dist.hpp +120 -0
- data/vendor/github.com/zeromq/libzmq/src/encoder.hpp +189 -0
- data/vendor/github.com/zeromq/libzmq/src/epoll.cpp +206 -0
- data/vendor/github.com/zeromq/libzmq/src/epoll.hpp +119 -0
- data/vendor/github.com/zeromq/libzmq/src/err.cpp +447 -0
- data/vendor/github.com/zeromq/libzmq/src/err.hpp +173 -0
- data/vendor/github.com/zeromq/libzmq/src/fd.hpp +52 -0
- data/vendor/github.com/zeromq/libzmq/src/fq.cpp +163 -0
- data/vendor/github.com/zeromq/libzmq/src/fq.hpp +92 -0
- data/vendor/github.com/zeromq/libzmq/src/gather.cpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/gather.hpp +75 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_client.cpp +237 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_client.hpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_mechanism_base.cpp +402 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_mechanism_base.hpp +134 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_server.cpp +249 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_server.hpp +95 -0
- data/vendor/github.com/zeromq/libzmq/src/i_decoder.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/i_encoder.hpp +60 -0
- data/vendor/github.com/zeromq/libzmq/src/i_engine.hpp +68 -0
- data/vendor/github.com/zeromq/libzmq/src/i_mailbox.hpp +60 -0
- data/vendor/github.com/zeromq/libzmq/src/i_poll_events.hpp +55 -0
- data/vendor/github.com/zeromq/libzmq/src/io_object.cpp +117 -0
- data/vendor/github.com/zeromq/libzmq/src/io_object.hpp +89 -0
- data/vendor/github.com/zeromq/libzmq/src/io_thread.cpp +114 -0
- data/vendor/github.com/zeromq/libzmq/src/io_thread.hpp +99 -0
- data/vendor/github.com/zeromq/libzmq/src/ip.cpp +235 -0
- data/vendor/github.com/zeromq/libzmq/src/ip.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_address.cpp +106 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_address.hpp +74 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_connecter.cpp +278 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_connecter.hpp +135 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_listener.cpp +427 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_listener.hpp +123 -0
- data/vendor/github.com/zeromq/libzmq/src/kqueue.cpp +227 -0
- data/vendor/github.com/zeromq/libzmq/src/kqueue.hpp +127 -0
- data/vendor/github.com/zeromq/libzmq/src/lb.cpp +173 -0
- data/vendor/github.com/zeromq/libzmq/src/lb.hpp +88 -0
- data/vendor/github.com/zeromq/libzmq/src/libzmq.pc.cmake.in +11 -0
- data/vendor/github.com/zeromq/libzmq/src/libzmq.pc.in +11 -0
- data/vendor/github.com/zeromq/libzmq/src/libzmq.vers +4 -0
- data/vendor/github.com/zeromq/libzmq/src/likely.hpp +42 -0
- data/vendor/github.com/zeromq/libzmq/src/macros.hpp +12 -0
- data/vendor/github.com/zeromq/libzmq/src/mailbox.cpp +101 -0
- data/vendor/github.com/zeromq/libzmq/src/mailbox.hpp +90 -0
- data/vendor/github.com/zeromq/libzmq/src/mailbox_safe.cpp +117 -0
- data/vendor/github.com/zeromq/libzmq/src/mailbox_safe.hpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/mechanism.cpp +285 -0
- data/vendor/github.com/zeromq/libzmq/src/mechanism.hpp +152 -0
- data/vendor/github.com/zeromq/libzmq/src/mechanism_base.cpp +70 -0
- data/vendor/github.com/zeromq/libzmq/src/mechanism_base.hpp +53 -0
- data/vendor/github.com/zeromq/libzmq/src/metadata.cpp +62 -0
- data/vendor/github.com/zeromq/libzmq/src/metadata.hpp +70 -0
- data/vendor/github.com/zeromq/libzmq/src/msg.cpp +578 -0
- data/vendor/github.com/zeromq/libzmq/src/msg.hpp +268 -0
- data/vendor/github.com/zeromq/libzmq/src/mtrie.cpp +434 -0
- data/vendor/github.com/zeromq/libzmq/src/mtrie.hpp +102 -0
- data/vendor/github.com/zeromq/libzmq/src/mutex.hpp +213 -0
- data/vendor/github.com/zeromq/libzmq/src/norm_engine.cpp +736 -0
- data/vendor/github.com/zeromq/libzmq/src/norm_engine.hpp +190 -0
- data/vendor/github.com/zeromq/libzmq/src/null_mechanism.cpp +220 -0
- data/vendor/github.com/zeromq/libzmq/src/null_mechanism.hpp +77 -0
- data/vendor/github.com/zeromq/libzmq/src/object.cpp +476 -0
- data/vendor/github.com/zeromq/libzmq/src/object.hpp +156 -0
- data/vendor/github.com/zeromq/libzmq/src/options.cpp +1089 -0
- data/vendor/github.com/zeromq/libzmq/src/options.hpp +251 -0
- data/vendor/github.com/zeromq/libzmq/src/own.cpp +216 -0
- data/vendor/github.com/zeromq/libzmq/src/own.hpp +154 -0
- data/vendor/github.com/zeromq/libzmq/src/pair.cpp +142 -0
- data/vendor/github.com/zeromq/libzmq/src/pair.hpp +78 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_receiver.cpp +307 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_receiver.hpp +147 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_sender.cpp +257 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_sender.hpp +124 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_socket.cpp +712 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_socket.hpp +128 -0
- data/vendor/github.com/zeromq/libzmq/src/pipe.cpp +547 -0
- data/vendor/github.com/zeromq/libzmq/src/pipe.hpp +253 -0
- data/vendor/github.com/zeromq/libzmq/src/plain_client.cpp +220 -0
- data/vendor/github.com/zeromq/libzmq/src/plain_client.hpp +79 -0
- data/vendor/github.com/zeromq/libzmq/src/plain_server.cpp +253 -0
- data/vendor/github.com/zeromq/libzmq/src/plain_server.hpp +71 -0
- data/vendor/github.com/zeromq/libzmq/src/poll.cpp +193 -0
- data/vendor/github.com/zeromq/libzmq/src/poll.hpp +121 -0
- data/vendor/github.com/zeromq/libzmq/src/poller.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/poller_base.cpp +110 -0
- data/vendor/github.com/zeromq/libzmq/src/poller_base.hpp +95 -0
- data/vendor/github.com/zeromq/libzmq/src/pollset.cpp +254 -0
- data/vendor/github.com/zeromq/libzmq/src/pollset.hpp +121 -0
- data/vendor/github.com/zeromq/libzmq/src/precompiled.cpp +30 -0
- data/vendor/github.com/zeromq/libzmq/src/precompiled.hpp +120 -0
- data/vendor/github.com/zeromq/libzmq/src/proxy.cpp +622 -0
- data/vendor/github.com/zeromq/libzmq/src/proxy.hpp +42 -0
- data/vendor/github.com/zeromq/libzmq/src/pub.cpp +67 -0
- data/vendor/github.com/zeromq/libzmq/src/pub.hpp +63 -0
- data/vendor/github.com/zeromq/libzmq/src/pull.cpp +78 -0
- data/vendor/github.com/zeromq/libzmq/src/pull.hpp +75 -0
- data/vendor/github.com/zeromq/libzmq/src/push.cpp +77 -0
- data/vendor/github.com/zeromq/libzmq/src/push.hpp +73 -0
- data/vendor/github.com/zeromq/libzmq/src/radio.cpp +252 -0
- data/vendor/github.com/zeromq/libzmq/src/radio.hpp +112 -0
- data/vendor/github.com/zeromq/libzmq/src/random.cpp +118 -0
- data/vendor/github.com/zeromq/libzmq/src/random.hpp +52 -0
- data/vendor/github.com/zeromq/libzmq/src/raw_decoder.cpp +74 -0
- data/vendor/github.com/zeromq/libzmq/src/raw_decoder.hpp +74 -0
- data/vendor/github.com/zeromq/libzmq/src/raw_encoder.cpp +51 -0
- data/vendor/github.com/zeromq/libzmq/src/raw_encoder.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/reaper.cpp +142 -0
- data/vendor/github.com/zeromq/libzmq/src/reaper.hpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/rep.cpp +134 -0
- data/vendor/github.com/zeromq/libzmq/src/rep.hpp +73 -0
- data/vendor/github.com/zeromq/libzmq/src/req.cpp +323 -0
- data/vendor/github.com/zeromq/libzmq/src/req.hpp +121 -0
- data/vendor/github.com/zeromq/libzmq/src/router.cpp +551 -0
- data/vendor/github.com/zeromq/libzmq/src/router.hpp +147 -0
- data/vendor/github.com/zeromq/libzmq/src/scatter.cpp +83 -0
- data/vendor/github.com/zeromq/libzmq/src/scatter.hpp +73 -0
- data/vendor/github.com/zeromq/libzmq/src/select.cpp +567 -0
- data/vendor/github.com/zeromq/libzmq/src/select.hpp +184 -0
- data/vendor/github.com/zeromq/libzmq/src/server.cpp +184 -0
- data/vendor/github.com/zeromq/libzmq/src/server.hpp +96 -0
- data/vendor/github.com/zeromq/libzmq/src/session_base.cpp +716 -0
- data/vendor/github.com/zeromq/libzmq/src/session_base.hpp +173 -0
- data/vendor/github.com/zeromq/libzmq/src/signaler.cpp +682 -0
- data/vendor/github.com/zeromq/libzmq/src/signaler.hpp +91 -0
- data/vendor/github.com/zeromq/libzmq/src/socket_base.cpp +1778 -0
- data/vendor/github.com/zeromq/libzmq/src/socket_base.hpp +307 -0
- data/vendor/github.com/zeromq/libzmq/src/socket_poller.cpp +697 -0
- data/vendor/github.com/zeromq/libzmq/src/socket_poller.hpp +145 -0
- data/vendor/github.com/zeromq/libzmq/src/socks.cpp +286 -0
- data/vendor/github.com/zeromq/libzmq/src/socks.hpp +135 -0
- data/vendor/github.com/zeromq/libzmq/src/socks_connecter.cpp +482 -0
- data/vendor/github.com/zeromq/libzmq/src/socks_connecter.hpp +163 -0
- data/vendor/github.com/zeromq/libzmq/src/stdint.hpp +77 -0
- data/vendor/github.com/zeromq/libzmq/src/stream.cpp +321 -0
- data/vendor/github.com/zeromq/libzmq/src/stream.hpp +107 -0
- data/vendor/github.com/zeromq/libzmq/src/stream_engine.cpp +1110 -0
- data/vendor/github.com/zeromq/libzmq/src/stream_engine.hpp +233 -0
- data/vendor/github.com/zeromq/libzmq/src/sub.cpp +87 -0
- data/vendor/github.com/zeromq/libzmq/src/sub.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp.cpp +356 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp.hpp +69 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_address.cpp +897 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_address.hpp +117 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_connecter.cpp +426 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_connecter.hpp +134 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_listener.cpp +357 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_listener.hpp +98 -0
- data/vendor/github.com/zeromq/libzmq/src/thread.cpp +238 -0
- data/vendor/github.com/zeromq/libzmq/src/thread.hpp +102 -0
- data/vendor/github.com/zeromq/libzmq/src/timers.cpp +199 -0
- data/vendor/github.com/zeromq/libzmq/src/timers.hpp +110 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_address.cpp +124 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_address.hpp +75 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_connecter.cpp +268 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_connecter.hpp +137 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_listener.cpp +190 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_listener.hpp +107 -0
- data/vendor/github.com/zeromq/libzmq/src/trie.cpp +340 -0
- data/vendor/github.com/zeromq/libzmq/src/trie.hpp +86 -0
- data/vendor/github.com/zeromq/libzmq/src/tweetnacl.c +988 -0
- data/vendor/github.com/zeromq/libzmq/src/tweetnacl.h +75 -0
- data/vendor/github.com/zeromq/libzmq/src/udp_address.cpp +172 -0
- data/vendor/github.com/zeromq/libzmq/src/udp_address.hpp +78 -0
- data/vendor/github.com/zeromq/libzmq/src/udp_engine.cpp +394 -0
- data/vendor/github.com/zeromq/libzmq/src/udp_engine.hpp +73 -0
- data/vendor/github.com/zeromq/libzmq/src/v1_decoder.cpp +153 -0
- data/vendor/github.com/zeromq/libzmq/src/v1_decoder.hpp +69 -0
- data/vendor/github.com/zeromq/libzmq/src/v1_encoder.cpp +76 -0
- data/vendor/github.com/zeromq/libzmq/src/v1_encoder.hpp +59 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_decoder.cpp +161 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_decoder.hpp +74 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_encoder.cpp +78 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_encoder.hpp +59 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_protocol.hpp +49 -0
- data/vendor/github.com/zeromq/libzmq/src/version.rc.in +93 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci.cpp +88 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci.hpp +60 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_address.cpp +170 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_address.hpp +71 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_connecter.cpp +307 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_connecter.hpp +136 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_listener.cpp +262 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_listener.hpp +102 -0
- data/vendor/github.com/zeromq/libzmq/src/windows.hpp +93 -0
- data/vendor/github.com/zeromq/libzmq/src/wire.hpp +108 -0
- data/vendor/github.com/zeromq/libzmq/src/xpub.cpp +340 -0
- data/vendor/github.com/zeromq/libzmq/src/xpub.hpp +126 -0
- data/vendor/github.com/zeromq/libzmq/src/xsub.cpp +251 -0
- data/vendor/github.com/zeromq/libzmq/src/xsub.hpp +103 -0
- data/vendor/github.com/zeromq/libzmq/src/ypipe.hpp +218 -0
- data/vendor/github.com/zeromq/libzmq/src/ypipe_base.hpp +54 -0
- data/vendor/github.com/zeromq/libzmq/src/ypipe_conflate.hpp +137 -0
- data/vendor/github.com/zeromq/libzmq/src/yqueue.hpp +225 -0
- data/vendor/github.com/zeromq/libzmq/src/zap_client.cpp +305 -0
- data/vendor/github.com/zeromq/libzmq/src/zap_client.hpp +100 -0
- data/vendor/github.com/zeromq/libzmq/src/zmq.cpp +1527 -0
- data/vendor/github.com/zeromq/libzmq/src/zmq_draft.h +178 -0
- data/vendor/github.com/zeromq/libzmq/src/zmq_utils.cpp +318 -0
- data/vendor/github.com/zeromq/libzmq/tests/CMakeLists.txt +218 -0
- data/vendor/github.com/zeromq/libzmq/tests/README.md +28 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_abstract_ipc.cpp +67 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_ancillaries.cpp +51 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_atomics.cpp +48 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_base85.cpp +162 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_bind_after_connect_tcp.cpp +97 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_bind_src_address.cpp +57 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_capabilities.cpp +82 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_client_server.cpp +106 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_conflate.cpp +86 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_connect_delay_tipc.cpp +238 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_connect_resolve.cpp +70 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_connect_rid.cpp +199 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_ctx_destroy.cpp +110 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_ctx_options.cpp +204 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_dgram.cpp +99 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_diffserv.cpp +85 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_disconnect_inproc.cpp +136 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_filter_ipc.cpp +166 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_fork.cpp +99 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_getsockopt_memset.cpp +64 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_heartbeats.cpp +341 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_hwm.cpp +312 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_hwm_pubsub.cpp +253 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_immediate.cpp +250 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_inproc_connect.cpp +536 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_invalid_rep.cpp +98 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_iov.cpp +157 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_ipc_wildcard.cpp +65 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_issue_566.cpp +99 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_last_endpoint.cpp +66 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_many_sockets.cpp +100 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_metadata.cpp +134 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_monitor.cpp +116 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_msg_ffn.cpp +145 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_msg_flags.cpp +127 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_inproc.cpp +81 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_ipc.cpp +60 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_tcp.cpp +64 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_tipc.cpp +62 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_vmci.cpp +68 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_poller.cpp +404 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_probe_router.cpp +86 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_proxy.cpp +486 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_proxy_single_socket.cpp +121 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_proxy_terminate.cpp +132 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pub_invert_matching.cpp +136 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_radio_dish.cpp +191 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_rebind_ipc.cpp +84 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reconnect_ivl.cpp +149 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_req_correlate.cpp +140 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_req_relaxed.cpp +220 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_device.cpp +153 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_device_tipc.cpp +146 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_inproc.cpp +60 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_ipc.cpp +112 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_tcp.cpp +336 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_tipc.cpp +61 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_vmci.cpp +68 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_router_handover.cpp +116 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory.cpp +292 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory_hwm.cpp +129 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory_tipc.cpp +70 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_scatter_gather.cpp +84 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_curve.cpp +792 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_gssapi.cpp +362 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_null.cpp +209 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_plain.cpp +212 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_zap.cpp +417 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_setsockopt.cpp +153 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_shutdown_stress.cpp +101 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_shutdown_stress_tipc.cpp +95 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_socket_null.cpp +82 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_sockopt_hwm.cpp +190 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_sodium.cpp +98 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_dealer.cpp +266 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_pushpull.cpp +304 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_rep.cpp +169 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_req.cpp +266 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_router.cpp +217 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_srcfd.cpp +127 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream.cpp +342 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream_disconnect.cpp +295 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream_empty.cpp +74 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream_exceeds_buffer.cpp +124 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream_timeout.cpp +235 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_sub_forward.cpp +109 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_sub_forward_tipc.cpp +102 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_system.cpp +98 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_term_endpoint.cpp +226 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_term_endpoint_tipc.cpp +120 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_thread_safe.cpp +90 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_timeo.cpp +85 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_timers.cpp +226 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_udp.cpp +133 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_unbind_inproc.cpp +43 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_unbind_wildcard.cpp +216 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_use_fd_ipc.cpp +223 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_use_fd_tcp.cpp +238 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_xpub_manual.cpp +597 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_xpub_nodrop.cpp +118 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_xpub_welcome_msg.cpp +81 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_zmq_poll_fd.cpp +98 -0
- data/vendor/github.com/zeromq/libzmq/tests/testutil.hpp +408 -0
- data/vendor/github.com/zeromq/libzmq/tests/testutil_security.hpp +684 -0
- data/vendor/github.com/zeromq/libzmq/tools/curve_keygen.cpp +58 -0
- data/vendor/github.com/zeromq/libzmq/version.sh +21 -0
- metadata +875 -0
@@ -0,0 +1,79 @@
|
|
1
|
+
/*
|
2
|
+
Copyright (c) 2007-2016 Contributors as noted in the AUTHORS file
|
3
|
+
|
4
|
+
This file is part of libzmq, the ZeroMQ core engine in C++.
|
5
|
+
|
6
|
+
libzmq is free software; you can redistribute it and/or modify it under
|
7
|
+
the terms of the GNU Lesser General Public License (LGPL) as published
|
8
|
+
by the Free Software Foundation; either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
As a special exception, the Contributors give you permission to link
|
12
|
+
this library with independent modules to produce an executable,
|
13
|
+
regardless of the license terms of these independent modules, and to
|
14
|
+
copy and distribute the resulting executable under terms of your choice,
|
15
|
+
provided that you also meet, for each linked independent module, the
|
16
|
+
terms and conditions of the license of that module. An independent
|
17
|
+
module is a module which is not derived from or based on this library.
|
18
|
+
If you modify this library, you must extend this exception to your
|
19
|
+
version of the library.
|
20
|
+
|
21
|
+
libzmq is distributed in the hope that it will be useful, but WITHOUT
|
22
|
+
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
23
|
+
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
24
|
+
License for more details.
|
25
|
+
|
26
|
+
You should have received a copy of the GNU Lesser General Public License
|
27
|
+
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
28
|
+
*/
|
29
|
+
|
30
|
+
#ifndef __ZMQ_CURVE_MECHANISM_BASE_HPP_INCLUDED__
|
31
|
+
#define __ZMQ_CURVE_MECHANISM_BASE_HPP_INCLUDED__
|
32
|
+
|
33
|
+
#ifdef ZMQ_HAVE_CURVE
|
34
|
+
|
35
|
+
#if defined(ZMQ_USE_TWEETNACL)
|
36
|
+
#include "tweetnacl.h"
|
37
|
+
#elif defined(ZMQ_USE_LIBSODIUM)
|
38
|
+
#include "sodium.h"
|
39
|
+
#endif
|
40
|
+
|
41
|
+
#if crypto_box_NONCEBYTES != 24 || crypto_box_PUBLICKEYBYTES != 32 \
|
42
|
+
|| crypto_box_SECRETKEYBYTES != 32 || crypto_box_ZEROBYTES != 32 \
|
43
|
+
|| crypto_box_BOXZEROBYTES != 16 || crypto_secretbox_NONCEBYTES != 24 \
|
44
|
+
|| crypto_secretbox_ZEROBYTES != 32 || crypto_secretbox_BOXZEROBYTES != 16
|
45
|
+
#error "CURVE library not built properly"
|
46
|
+
#endif
|
47
|
+
|
48
|
+
#include "mechanism_base.hpp"
|
49
|
+
#include "options.hpp"
|
50
|
+
|
51
|
+
namespace zmq
|
52
|
+
{
|
53
|
+
class curve_mechanism_base_t : public virtual mechanism_base_t
|
54
|
+
{
|
55
|
+
public:
|
56
|
+
curve_mechanism_base_t (session_base_t *session_,
|
57
|
+
const options_t &options_,
|
58
|
+
const char *encode_nonce_prefix_,
|
59
|
+
const char *decode_nonce_prefix_);
|
60
|
+
|
61
|
+
// mechanism implementation
|
62
|
+
virtual int encode (msg_t *msg_);
|
63
|
+
virtual int decode (msg_t *msg_);
|
64
|
+
|
65
|
+
protected:
|
66
|
+
const char *encode_nonce_prefix;
|
67
|
+
const char *decode_nonce_prefix;
|
68
|
+
|
69
|
+
uint64_t cn_nonce;
|
70
|
+
uint64_t cn_peer_nonce;
|
71
|
+
|
72
|
+
// Intermediary buffer used to speed up boxing and unboxing.
|
73
|
+
uint8_t cn_precom [crypto_box_BEFORENMBYTES];
|
74
|
+
};
|
75
|
+
}
|
76
|
+
|
77
|
+
#endif
|
78
|
+
|
79
|
+
#endif
|
@@ -0,0 +1,492 @@
|
|
1
|
+
/*
|
2
|
+
Copyright (c) 2007-2016 Contributors as noted in the AUTHORS file
|
3
|
+
|
4
|
+
This file is part of libzmq, the ZeroMQ core engine in C++.
|
5
|
+
|
6
|
+
libzmq is free software; you can redistribute it and/or modify it under
|
7
|
+
the terms of the GNU Lesser General Public License (LGPL) as published
|
8
|
+
by the Free Software Foundation; either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
As a special exception, the Contributors give you permission to link
|
12
|
+
this library with independent modules to produce an executable,
|
13
|
+
regardless of the license terms of these independent modules, and to
|
14
|
+
copy and distribute the resulting executable under terms of your choice,
|
15
|
+
provided that you also meet, for each linked independent module, the
|
16
|
+
terms and conditions of the license of that module. An independent
|
17
|
+
module is a module which is not derived from or based on this library.
|
18
|
+
If you modify this library, you must extend this exception to your
|
19
|
+
version of the library.
|
20
|
+
|
21
|
+
libzmq is distributed in the hope that it will be useful, but WITHOUT
|
22
|
+
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
23
|
+
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
24
|
+
License for more details.
|
25
|
+
|
26
|
+
You should have received a copy of the GNU Lesser General Public License
|
27
|
+
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
28
|
+
*/
|
29
|
+
|
30
|
+
#include "precompiled.hpp"
|
31
|
+
#include "macros.hpp"
|
32
|
+
|
33
|
+
#ifdef ZMQ_HAVE_CURVE
|
34
|
+
|
35
|
+
#include "msg.hpp"
|
36
|
+
#include "session_base.hpp"
|
37
|
+
#include "err.hpp"
|
38
|
+
#include "curve_server.hpp"
|
39
|
+
#include "wire.hpp"
|
40
|
+
|
41
|
+
zmq::curve_server_t::curve_server_t (session_base_t *session_,
|
42
|
+
const std::string &peer_address_,
|
43
|
+
const options_t &options_) :
|
44
|
+
mechanism_base_t (session_, options_),
|
45
|
+
zap_client_common_handshake_t (
|
46
|
+
session_, peer_address_, options_, sending_ready),
|
47
|
+
curve_mechanism_base_t (
|
48
|
+
session_, options_, "CurveZMQMESSAGES", "CurveZMQMESSAGEC")
|
49
|
+
{
|
50
|
+
int rc;
|
51
|
+
// Fetch our secret key from socket options
|
52
|
+
memcpy (secret_key, options_.curve_secret_key, crypto_box_SECRETKEYBYTES);
|
53
|
+
|
54
|
+
// Generate short-term key pair
|
55
|
+
rc = crypto_box_keypair (cn_public, cn_secret);
|
56
|
+
zmq_assert (rc == 0);
|
57
|
+
}
|
58
|
+
|
59
|
+
zmq::curve_server_t::~curve_server_t ()
|
60
|
+
{
|
61
|
+
}
|
62
|
+
|
63
|
+
int zmq::curve_server_t::next_handshake_command (msg_t *msg_)
|
64
|
+
{
|
65
|
+
int rc = 0;
|
66
|
+
|
67
|
+
switch (state) {
|
68
|
+
case sending_welcome:
|
69
|
+
rc = produce_welcome (msg_);
|
70
|
+
if (rc == 0)
|
71
|
+
state = waiting_for_initiate;
|
72
|
+
break;
|
73
|
+
case sending_ready:
|
74
|
+
rc = produce_ready (msg_);
|
75
|
+
if (rc == 0)
|
76
|
+
state = ready;
|
77
|
+
break;
|
78
|
+
case sending_error:
|
79
|
+
rc = produce_error (msg_);
|
80
|
+
if (rc == 0)
|
81
|
+
state = error_sent;
|
82
|
+
break;
|
83
|
+
default:
|
84
|
+
errno = EAGAIN;
|
85
|
+
rc = -1;
|
86
|
+
break;
|
87
|
+
}
|
88
|
+
return rc;
|
89
|
+
}
|
90
|
+
|
91
|
+
int zmq::curve_server_t::process_handshake_command (msg_t *msg_)
|
92
|
+
{
|
93
|
+
int rc = 0;
|
94
|
+
|
95
|
+
switch (state) {
|
96
|
+
case waiting_for_hello:
|
97
|
+
rc = process_hello (msg_);
|
98
|
+
break;
|
99
|
+
case waiting_for_initiate:
|
100
|
+
rc = process_initiate (msg_);
|
101
|
+
break;
|
102
|
+
default:
|
103
|
+
// TODO I think this is not a case reachable with a misbehaving
|
104
|
+
// client. It is not an "invalid handshake command", but would be
|
105
|
+
// trying to process a handshake command in an invalid state,
|
106
|
+
// which is purely under control of this peer.
|
107
|
+
// Therefore, it should be changed to zmq_assert (false);
|
108
|
+
|
109
|
+
// CURVE I: invalid handshake command
|
110
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
111
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_UNSPECIFIED);
|
112
|
+
errno = EPROTO;
|
113
|
+
rc = -1;
|
114
|
+
break;
|
115
|
+
}
|
116
|
+
if (rc == 0) {
|
117
|
+
rc = msg_->close ();
|
118
|
+
errno_assert (rc == 0);
|
119
|
+
rc = msg_->init ();
|
120
|
+
errno_assert (rc == 0);
|
121
|
+
}
|
122
|
+
return rc;
|
123
|
+
}
|
124
|
+
|
125
|
+
int zmq::curve_server_t::encode (msg_t *msg_)
|
126
|
+
{
|
127
|
+
zmq_assert (state == ready);
|
128
|
+
return curve_mechanism_base_t::encode (msg_);
|
129
|
+
}
|
130
|
+
|
131
|
+
int zmq::curve_server_t::decode (msg_t *msg_)
|
132
|
+
{
|
133
|
+
zmq_assert (state == ready);
|
134
|
+
return curve_mechanism_base_t::decode (msg_);
|
135
|
+
}
|
136
|
+
|
137
|
+
int zmq::curve_server_t::process_hello (msg_t *msg_)
|
138
|
+
{
|
139
|
+
int rc = check_basic_command_structure (msg_);
|
140
|
+
if (rc == -1)
|
141
|
+
return -1;
|
142
|
+
|
143
|
+
const size_t size = msg_->size ();
|
144
|
+
const uint8_t * const hello = static_cast <uint8_t *> (msg_->data ());
|
145
|
+
|
146
|
+
if (size < 6 || memcmp (hello, "\x05HELLO", 6)) {
|
147
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
148
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_UNEXPECTED_COMMAND);
|
149
|
+
errno = EPROTO;
|
150
|
+
return -1;
|
151
|
+
}
|
152
|
+
|
153
|
+
if (size != 200) {
|
154
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
155
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_MALFORMED_COMMAND_HELLO);
|
156
|
+
errno = EPROTO;
|
157
|
+
return -1;
|
158
|
+
}
|
159
|
+
|
160
|
+
const uint8_t major = hello [6];
|
161
|
+
const uint8_t minor = hello [7];
|
162
|
+
|
163
|
+
if (major != 1 || minor != 0) {
|
164
|
+
// CURVE I: client HELLO has unknown version number
|
165
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
166
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_MALFORMED_COMMAND_HELLO);
|
167
|
+
errno = EPROTO;
|
168
|
+
return -1;
|
169
|
+
}
|
170
|
+
|
171
|
+
// Save client's short-term public key (C')
|
172
|
+
memcpy (cn_client, hello + 80, 32);
|
173
|
+
|
174
|
+
uint8_t hello_nonce [crypto_box_NONCEBYTES];
|
175
|
+
uint8_t hello_plaintext [crypto_box_ZEROBYTES + 64];
|
176
|
+
uint8_t hello_box [crypto_box_BOXZEROBYTES + 80];
|
177
|
+
|
178
|
+
memcpy (hello_nonce, "CurveZMQHELLO---", 16);
|
179
|
+
memcpy (hello_nonce + 16, hello + 112, 8);
|
180
|
+
cn_peer_nonce = get_uint64(hello + 112);
|
181
|
+
|
182
|
+
memset (hello_box, 0, crypto_box_BOXZEROBYTES);
|
183
|
+
memcpy (hello_box + crypto_box_BOXZEROBYTES, hello + 120, 80);
|
184
|
+
|
185
|
+
// Open Box [64 * %x0](C'->S)
|
186
|
+
rc = crypto_box_open (hello_plaintext, hello_box, sizeof hello_box,
|
187
|
+
hello_nonce, cn_client, secret_key);
|
188
|
+
if (rc != 0) {
|
189
|
+
// CURVE I: cannot open client HELLO -- wrong server key?
|
190
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
191
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_CRYPTOGRAPHIC);
|
192
|
+
errno = EPROTO;
|
193
|
+
return -1;
|
194
|
+
}
|
195
|
+
|
196
|
+
state = sending_welcome;
|
197
|
+
return rc;
|
198
|
+
}
|
199
|
+
|
200
|
+
int zmq::curve_server_t::produce_welcome (msg_t *msg_)
|
201
|
+
{
|
202
|
+
uint8_t cookie_nonce [crypto_secretbox_NONCEBYTES];
|
203
|
+
uint8_t cookie_plaintext [crypto_secretbox_ZEROBYTES + 64];
|
204
|
+
uint8_t cookie_ciphertext [crypto_secretbox_BOXZEROBYTES + 80];
|
205
|
+
|
206
|
+
// Create full nonce for encryption
|
207
|
+
// 8-byte prefix plus 16-byte random nonce
|
208
|
+
memcpy (cookie_nonce, "COOKIE--", 8);
|
209
|
+
randombytes (cookie_nonce + 8, 16);
|
210
|
+
|
211
|
+
// Generate cookie = Box [C' + s'](t)
|
212
|
+
memset (cookie_plaintext, 0, crypto_secretbox_ZEROBYTES);
|
213
|
+
memcpy (cookie_plaintext + crypto_secretbox_ZEROBYTES,
|
214
|
+
cn_client, 32);
|
215
|
+
memcpy (cookie_plaintext + crypto_secretbox_ZEROBYTES + 32,
|
216
|
+
cn_secret, 32);
|
217
|
+
|
218
|
+
// Generate fresh cookie key
|
219
|
+
randombytes (cookie_key, crypto_secretbox_KEYBYTES);
|
220
|
+
|
221
|
+
// Encrypt using symmetric cookie key
|
222
|
+
int rc = crypto_secretbox (cookie_ciphertext, cookie_plaintext,
|
223
|
+
sizeof cookie_plaintext,
|
224
|
+
cookie_nonce, cookie_key);
|
225
|
+
zmq_assert (rc == 0);
|
226
|
+
|
227
|
+
uint8_t welcome_nonce [crypto_box_NONCEBYTES];
|
228
|
+
uint8_t welcome_plaintext [crypto_box_ZEROBYTES + 128];
|
229
|
+
uint8_t welcome_ciphertext [crypto_box_BOXZEROBYTES + 144];
|
230
|
+
|
231
|
+
// Create full nonce for encryption
|
232
|
+
// 8-byte prefix plus 16-byte random nonce
|
233
|
+
memcpy (welcome_nonce, "WELCOME-", 8);
|
234
|
+
randombytes (welcome_nonce + 8, crypto_box_NONCEBYTES - 8);
|
235
|
+
|
236
|
+
// Create 144-byte Box [S' + cookie](S->C')
|
237
|
+
memset (welcome_plaintext, 0, crypto_box_ZEROBYTES);
|
238
|
+
memcpy (welcome_plaintext + crypto_box_ZEROBYTES, cn_public, 32);
|
239
|
+
memcpy (welcome_plaintext + crypto_box_ZEROBYTES + 32,
|
240
|
+
cookie_nonce + 8, 16);
|
241
|
+
memcpy (welcome_plaintext + crypto_box_ZEROBYTES + 48,
|
242
|
+
cookie_ciphertext + crypto_secretbox_BOXZEROBYTES, 80);
|
243
|
+
|
244
|
+
rc = crypto_box (welcome_ciphertext, welcome_plaintext,
|
245
|
+
sizeof welcome_plaintext, welcome_nonce, cn_client,
|
246
|
+
secret_key);
|
247
|
+
|
248
|
+
// TODO I think we should change this back to zmq_assert (rc == 0);
|
249
|
+
// as it was before https://github.com/zeromq/libzmq/pull/1832
|
250
|
+
// The reason given there was that secret_key might be 0ed.
|
251
|
+
// But if it were, we would never get this far, since we could
|
252
|
+
// not have opened the client's hello box with a 0ed key.
|
253
|
+
|
254
|
+
if (rc == -1)
|
255
|
+
return -1;
|
256
|
+
|
257
|
+
rc = msg_->init_size (168);
|
258
|
+
errno_assert (rc == 0);
|
259
|
+
|
260
|
+
uint8_t * const welcome = static_cast <uint8_t *> (msg_->data ());
|
261
|
+
memcpy (welcome, "\x07WELCOME", 8);
|
262
|
+
memcpy (welcome + 8, welcome_nonce + 8, 16);
|
263
|
+
memcpy (welcome + 24, welcome_ciphertext + crypto_box_BOXZEROBYTES, 144);
|
264
|
+
|
265
|
+
return 0;
|
266
|
+
}
|
267
|
+
|
268
|
+
int zmq::curve_server_t::process_initiate (msg_t *msg_)
|
269
|
+
{
|
270
|
+
int rc = check_basic_command_structure (msg_);
|
271
|
+
if (rc == -1)
|
272
|
+
return -1;
|
273
|
+
|
274
|
+
const size_t size = msg_->size ();
|
275
|
+
const uint8_t *initiate = static_cast <uint8_t *> (msg_->data ());
|
276
|
+
|
277
|
+
if (size < 9 || memcmp (initiate, "\x08INITIATE", 9)) {
|
278
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
279
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_UNEXPECTED_COMMAND);
|
280
|
+
errno = EPROTO;
|
281
|
+
return -1;
|
282
|
+
}
|
283
|
+
|
284
|
+
if (size < 257) {
|
285
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
286
|
+
session->get_endpoint (),
|
287
|
+
ZMQ_PROTOCOL_ERROR_ZMTP_MALFORMED_COMMAND_INITIATE);
|
288
|
+
errno = EPROTO;
|
289
|
+
return -1;
|
290
|
+
}
|
291
|
+
|
292
|
+
uint8_t cookie_nonce [crypto_secretbox_NONCEBYTES];
|
293
|
+
uint8_t cookie_plaintext [crypto_secretbox_ZEROBYTES + 64];
|
294
|
+
uint8_t cookie_box [crypto_secretbox_BOXZEROBYTES + 80];
|
295
|
+
|
296
|
+
// Open Box [C' + s'](t)
|
297
|
+
memset (cookie_box, 0, crypto_secretbox_BOXZEROBYTES);
|
298
|
+
memcpy (cookie_box + crypto_secretbox_BOXZEROBYTES, initiate + 25, 80);
|
299
|
+
|
300
|
+
memcpy (cookie_nonce, "COOKIE--", 8);
|
301
|
+
memcpy (cookie_nonce + 8, initiate + 9, 16);
|
302
|
+
|
303
|
+
rc = crypto_secretbox_open (cookie_plaintext, cookie_box, sizeof cookie_box,
|
304
|
+
cookie_nonce, cookie_key);
|
305
|
+
if (rc != 0) {
|
306
|
+
// CURVE I: cannot open client INITIATE cookie
|
307
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
308
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_CRYPTOGRAPHIC);
|
309
|
+
errno = EPROTO;
|
310
|
+
return -1;
|
311
|
+
}
|
312
|
+
|
313
|
+
// Check cookie plain text is as expected [C' + s']
|
314
|
+
if (memcmp (cookie_plaintext + crypto_secretbox_ZEROBYTES, cn_client, 32)
|
315
|
+
|| memcmp (cookie_plaintext + crypto_secretbox_ZEROBYTES + 32, cn_secret, 32)) {
|
316
|
+
// TODO this case is very hard to test, as it would require a modified
|
317
|
+
// client that knows the server's secret temporary cookie key
|
318
|
+
|
319
|
+
// CURVE I: client INITIATE cookie is not valid
|
320
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
321
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_CRYPTOGRAPHIC);
|
322
|
+
errno = EPROTO;
|
323
|
+
return -1;
|
324
|
+
}
|
325
|
+
|
326
|
+
const size_t clen = (size - 113) + crypto_box_BOXZEROBYTES;
|
327
|
+
|
328
|
+
uint8_t initiate_nonce [crypto_box_NONCEBYTES];
|
329
|
+
uint8_t initiate_plaintext [crypto_box_ZEROBYTES + 128 + 256];
|
330
|
+
uint8_t initiate_box [crypto_box_BOXZEROBYTES + 144 + 256];
|
331
|
+
|
332
|
+
// Open Box [C + vouch + metadata](C'->S')
|
333
|
+
memset (initiate_box, 0, crypto_box_BOXZEROBYTES);
|
334
|
+
memcpy (initiate_box + crypto_box_BOXZEROBYTES,
|
335
|
+
initiate + 113, clen - crypto_box_BOXZEROBYTES);
|
336
|
+
|
337
|
+
memcpy (initiate_nonce, "CurveZMQINITIATE", 16);
|
338
|
+
memcpy (initiate_nonce + 16, initiate + 105, 8);
|
339
|
+
cn_peer_nonce = get_uint64(initiate + 105);
|
340
|
+
|
341
|
+
rc = crypto_box_open (initiate_plaintext, initiate_box,
|
342
|
+
clen, initiate_nonce, cn_client, cn_secret);
|
343
|
+
if (rc != 0) {
|
344
|
+
// CURVE I: cannot open client INITIATE
|
345
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
346
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_CRYPTOGRAPHIC);
|
347
|
+
errno = EPROTO;
|
348
|
+
return -1;
|
349
|
+
}
|
350
|
+
|
351
|
+
const uint8_t *client_key = initiate_plaintext + crypto_box_ZEROBYTES;
|
352
|
+
|
353
|
+
uint8_t vouch_nonce [crypto_box_NONCEBYTES];
|
354
|
+
uint8_t vouch_plaintext [crypto_box_ZEROBYTES + 64];
|
355
|
+
uint8_t vouch_box [crypto_box_BOXZEROBYTES + 80];
|
356
|
+
|
357
|
+
// Open Box Box [C',S](C->S') and check contents
|
358
|
+
memset (vouch_box, 0, crypto_box_BOXZEROBYTES);
|
359
|
+
memcpy (vouch_box + crypto_box_BOXZEROBYTES,
|
360
|
+
initiate_plaintext + crypto_box_ZEROBYTES + 48, 80);
|
361
|
+
|
362
|
+
memcpy (vouch_nonce, "VOUCH---", 8);
|
363
|
+
memcpy (vouch_nonce + 8,
|
364
|
+
initiate_plaintext + crypto_box_ZEROBYTES + 32, 16);
|
365
|
+
|
366
|
+
rc = crypto_box_open (vouch_plaintext, vouch_box,
|
367
|
+
sizeof vouch_box,
|
368
|
+
vouch_nonce, client_key, cn_secret);
|
369
|
+
if (rc != 0) {
|
370
|
+
// CURVE I: cannot open client INITIATE vouch
|
371
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
372
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_CRYPTOGRAPHIC);
|
373
|
+
errno = EPROTO;
|
374
|
+
return -1;
|
375
|
+
}
|
376
|
+
|
377
|
+
// What we decrypted must be the client's short-term public key
|
378
|
+
if (memcmp (vouch_plaintext + crypto_box_ZEROBYTES, cn_client, 32)) {
|
379
|
+
// TODO this case is very hard to test, as it would require a modified
|
380
|
+
// client that knows the server's secret short-term key
|
381
|
+
|
382
|
+
// CURVE I: invalid handshake from client (public key)
|
383
|
+
session->get_socket ()->event_handshake_failed_protocol (
|
384
|
+
session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_KEY_EXCHANGE);
|
385
|
+
errno = EPROTO;
|
386
|
+
return -1;
|
387
|
+
}
|
388
|
+
|
389
|
+
// Precompute connection secret from client key
|
390
|
+
rc = crypto_box_beforenm (cn_precom, cn_client, cn_secret);
|
391
|
+
zmq_assert (rc == 0);
|
392
|
+
|
393
|
+
// Given this is a backward-incompatible change, it's behind a socket
|
394
|
+
// option disabled by default.
|
395
|
+
if (zap_required () || !options.zap_enforce_domain) {
|
396
|
+
// Use ZAP protocol (RFC 27) to authenticate the user.
|
397
|
+
rc = session->zap_connect ();
|
398
|
+
if (rc == 0) {
|
399
|
+
send_zap_request (client_key);
|
400
|
+
state = waiting_for_zap_reply;
|
401
|
+
|
402
|
+
// TODO actually, it is quite unlikely that we can read the ZAP
|
403
|
+
// reply already, but removing this has some strange side-effect
|
404
|
+
// (probably because the pipe's in_active flag is true until a read
|
405
|
+
// is attempted)
|
406
|
+
rc = receive_and_process_zap_reply ();
|
407
|
+
if (rc == -1)
|
408
|
+
return -1;
|
409
|
+
} else if (!options.zap_enforce_domain) {
|
410
|
+
// This supports the Stonehouse pattern (encryption without
|
411
|
+
// authentication) in legacy mode (domain set but no handler).
|
412
|
+
state = sending_ready;
|
413
|
+
} else {
|
414
|
+
session->get_socket ()->event_handshake_failed_no_detail (
|
415
|
+
session->get_endpoint (), EFAULT);
|
416
|
+
return -1;
|
417
|
+
}
|
418
|
+
} else {
|
419
|
+
// This supports the Stonehouse pattern (encryption without authentication).
|
420
|
+
state = sending_ready;
|
421
|
+
}
|
422
|
+
|
423
|
+
return parse_metadata (initiate_plaintext + crypto_box_ZEROBYTES + 128,
|
424
|
+
clen - crypto_box_ZEROBYTES - 128);
|
425
|
+
}
|
426
|
+
|
427
|
+
int zmq::curve_server_t::produce_ready (msg_t *msg_)
|
428
|
+
{
|
429
|
+
const size_t metadata_length = basic_properties_len ();
|
430
|
+
uint8_t ready_nonce [crypto_box_NONCEBYTES];
|
431
|
+
|
432
|
+
uint8_t *ready_plaintext =
|
433
|
+
(uint8_t *) malloc (crypto_box_ZEROBYTES + metadata_length);
|
434
|
+
alloc_assert (ready_plaintext);
|
435
|
+
|
436
|
+
// Create Box [metadata](S'->C')
|
437
|
+
memset (ready_plaintext, 0, crypto_box_ZEROBYTES);
|
438
|
+
uint8_t *ptr = ready_plaintext + crypto_box_ZEROBYTES;
|
439
|
+
|
440
|
+
ptr += add_basic_properties (ptr, metadata_length);
|
441
|
+
const size_t mlen = ptr - ready_plaintext;
|
442
|
+
|
443
|
+
memcpy (ready_nonce, "CurveZMQREADY---", 16);
|
444
|
+
put_uint64 (ready_nonce + 16, cn_nonce);
|
445
|
+
|
446
|
+
uint8_t *ready_box =
|
447
|
+
(uint8_t *) malloc (crypto_box_BOXZEROBYTES + 16 + metadata_length);
|
448
|
+
alloc_assert (ready_box);
|
449
|
+
|
450
|
+
int rc = crypto_box_afternm (ready_box, ready_plaintext, mlen, ready_nonce,
|
451
|
+
cn_precom);
|
452
|
+
zmq_assert (rc == 0);
|
453
|
+
|
454
|
+
free (ready_plaintext);
|
455
|
+
|
456
|
+
rc = msg_->init_size (14 + mlen - crypto_box_BOXZEROBYTES);
|
457
|
+
errno_assert (rc == 0);
|
458
|
+
|
459
|
+
uint8_t *ready = static_cast <uint8_t *> (msg_->data ());
|
460
|
+
|
461
|
+
memcpy (ready, "\x05READY", 6);
|
462
|
+
// Short nonce, prefixed by "CurveZMQREADY---"
|
463
|
+
memcpy (ready + 6, ready_nonce + 16, 8);
|
464
|
+
// Box [metadata](S'->C')
|
465
|
+
memcpy (ready + 14, ready_box + crypto_box_BOXZEROBYTES,
|
466
|
+
mlen - crypto_box_BOXZEROBYTES);
|
467
|
+
free (ready_box);
|
468
|
+
|
469
|
+
cn_nonce++;
|
470
|
+
|
471
|
+
return 0;
|
472
|
+
}
|
473
|
+
|
474
|
+
int zmq::curve_server_t::produce_error (msg_t *msg_) const
|
475
|
+
{
|
476
|
+
const size_t expected_status_code_length = 3;
|
477
|
+
zmq_assert (status_code.length () == 3);
|
478
|
+
const int rc = msg_->init_size (6 + 1 + expected_status_code_length);
|
479
|
+
zmq_assert (rc == 0);
|
480
|
+
char *msg_data = static_cast <char *> (msg_->data ());
|
481
|
+
memcpy (msg_data, "\5ERROR", 6);
|
482
|
+
msg_data [6] = expected_status_code_length;
|
483
|
+
memcpy (msg_data + 7, status_code.c_str (), expected_status_code_length);
|
484
|
+
return 0;
|
485
|
+
}
|
486
|
+
|
487
|
+
void zmq::curve_server_t::send_zap_request (const uint8_t *key)
|
488
|
+
{
|
489
|
+
zap_client_t::send_zap_request ("CURVE", 5, key, crypto_box_PUBLICKEYBYTES);
|
490
|
+
}
|
491
|
+
|
492
|
+
#endif
|