zeroc-ice 3.7.11 → 3.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (895) hide show
  1. checksums.yaml +4 -4
  2. data/dist/IceRuby/Communicator.cpp +159 -376
  3. data/dist/IceRuby/Communicator.h +8 -9
  4. data/dist/IceRuby/Config.h +23 -89
  5. data/dist/IceRuby/Connection.cpp +111 -219
  6. data/dist/IceRuby/Connection.h +8 -12
  7. data/dist/IceRuby/DefaultSliceLoader.cpp +45 -0
  8. data/dist/IceRuby/DefaultSliceLoader.h +25 -0
  9. data/dist/IceRuby/Endpoint.cpp +63 -65
  10. data/dist/IceRuby/Endpoint.h +7 -11
  11. data/dist/IceRuby/ImplicitContext.cpp +26 -31
  12. data/dist/IceRuby/ImplicitContext.h +6 -10
  13. data/dist/IceRuby/Init.cpp +27 -40
  14. data/dist/IceRuby/Logger.cpp +23 -28
  15. data/dist/IceRuby/Logger.h +8 -12
  16. data/dist/IceRuby/Operation.cpp +177 -219
  17. data/dist/IceRuby/Operation.h +15 -18
  18. data/dist/IceRuby/Properties.cpp +133 -89
  19. data/dist/IceRuby/Properties.h +6 -10
  20. data/dist/IceRuby/Proxy.cpp +179 -649
  21. data/dist/IceRuby/Proxy.h +11 -12
  22. data/dist/IceRuby/RubySliceLoader.cpp +39 -0
  23. data/dist/IceRuby/RubySliceLoader.h +27 -0
  24. data/dist/IceRuby/Slice.cpp +88 -94
  25. data/dist/IceRuby/Slice.h +3 -7
  26. data/dist/IceRuby/Types.cpp +987 -1190
  27. data/dist/IceRuby/Types.h +390 -461
  28. data/dist/IceRuby/Util.cpp +214 -473
  29. data/dist/IceRuby/Util.h +378 -479
  30. data/dist/ice/cpp/include/Ice/AsyncResponseHandler.h +85 -0
  31. data/dist/ice/cpp/include/Ice/BatchRequest.h +39 -0
  32. data/dist/ice/cpp/include/Ice/BatchRequestQueueF.h +4 -10
  33. data/dist/ice/cpp/include/Ice/Buffer.h +116 -111
  34. data/dist/ice/cpp/include/Ice/Communicator.h +411 -0
  35. data/dist/ice/cpp/include/Ice/CommunicatorF.h +16 -0
  36. data/dist/ice/cpp/include/Ice/Config.h +46 -62
  37. data/dist/ice/cpp/include/Ice/Connection.h +410 -0
  38. data/dist/ice/cpp/include/Ice/ConnectionF.h +36 -0
  39. data/dist/ice/cpp/include/Ice/ConnectionIF.h +6 -28
  40. data/dist/ice/cpp/include/Ice/CtrlCHandler.h +56 -0
  41. data/dist/ice/cpp/include/Ice/Current.h +60 -0
  42. data/dist/ice/cpp/include/Ice/DefaultSliceLoader.h +160 -0
  43. data/dist/ice/cpp/include/Ice/Demangle.h +17 -0
  44. data/dist/ice/cpp/include/Ice/Endpoint.h +298 -0
  45. data/dist/ice/cpp/include/Ice/EndpointF.h +44 -0
  46. data/dist/ice/cpp/include/Ice/EndpointSelectionType.h +21 -0
  47. data/dist/ice/cpp/include/Ice/Exception.h +46 -151
  48. data/dist/ice/cpp/include/Ice/FacetMap.h +16 -0
  49. data/dist/ice/cpp/include/Ice/Format.h +11 -27
  50. data/dist/ice/cpp/include/Ice/Ice.h +53 -48
  51. data/dist/ice/cpp/include/Ice/IconvStringConverter.h +165 -326
  52. data/dist/ice/cpp/include/Ice/ImplicitContext.h +76 -0
  53. data/dist/ice/cpp/include/Ice/IncomingRequest.h +75 -0
  54. data/dist/ice/cpp/include/Ice/Initialize.h +113 -927
  55. data/dist/ice/cpp/include/Ice/InputStream.h +748 -1320
  56. data/dist/ice/cpp/include/Ice/InstanceF.h +4 -10
  57. data/dist/ice/cpp/include/Ice/Instrumentation.h +319 -0
  58. data/dist/ice/cpp/include/Ice/LocalException.h +58 -0
  59. data/dist/ice/cpp/include/Ice/LocalExceptions.h +870 -0
  60. data/dist/ice/cpp/include/Ice/Logger.h +62 -0
  61. data/dist/ice/cpp/include/Ice/LoggerUtil.h +124 -147
  62. data/dist/ice/cpp/include/Ice/MarshaledResult.h +50 -0
  63. data/dist/ice/cpp/include/Ice/NativePropertiesAdmin.h +41 -71
  64. data/dist/ice/cpp/include/Ice/Object.h +151 -490
  65. data/dist/ice/cpp/include/Ice/ObjectAdapter.h +324 -0
  66. data/dist/ice/cpp/include/Ice/ObjectAdapterF.h +16 -0
  67. data/dist/ice/cpp/include/Ice/ObjectF.h +5 -19
  68. data/dist/ice/cpp/include/Ice/ObserverHelper.h +115 -132
  69. data/dist/ice/cpp/include/Ice/OutgoingAsync.h +392 -748
  70. data/dist/ice/cpp/include/Ice/OutgoingResponse.h +129 -0
  71. data/dist/ice/cpp/include/Ice/OutputStream.h +756 -956
  72. data/dist/ice/cpp/include/Ice/Plugin.h +73 -0
  73. data/dist/ice/cpp/include/Ice/PluginFactory.h +77 -0
  74. data/dist/ice/cpp/include/{IceUtil → Ice}/PopDisableWarnings.h +8 -6
  75. data/dist/ice/cpp/include/Ice/Properties.h +307 -0
  76. data/dist/ice/cpp/include/Ice/PropertiesF.h +19 -0
  77. data/dist/ice/cpp/include/Ice/Proxy.h +665 -5094
  78. data/dist/ice/cpp/include/Ice/ProxyF.h +2 -44
  79. data/dist/ice/cpp/include/Ice/ProxyFunctions.h +209 -0
  80. data/dist/ice/cpp/include/Ice/PushDisableWarnings.h +29 -0
  81. data/dist/ice/cpp/include/Ice/ReferenceF.h +4 -19
  82. data/dist/ice/cpp/include/Ice/RequestHandlerF.h +8 -18
  83. data/dist/ice/cpp/include/Ice/SSL/ClientAuthenticationOptions.h +276 -0
  84. data/dist/ice/cpp/include/Ice/SSL/Config.h +54 -0
  85. data/dist/ice/cpp/include/Ice/SSL/ConnectionInfo.h +107 -0
  86. data/dist/ice/cpp/include/Ice/SSL/ConnectionInfoF.h +39 -0
  87. data/dist/ice/cpp/include/Ice/SSL/EndpointInfo.h +40 -0
  88. data/dist/ice/cpp/include/Ice/SSL/SSLException.h +32 -0
  89. data/dist/ice/cpp/include/Ice/SSL/ServerAuthenticationOptions.h +286 -0
  90. data/dist/ice/cpp/include/Ice/ServantLocator.h +51 -0
  91. data/dist/ice/cpp/include/Ice/Service.h +182 -342
  92. data/dist/ice/cpp/include/Ice/SliceLoader.h +67 -0
  93. data/dist/ice/cpp/include/Ice/SlicedData.h +113 -160
  94. data/dist/ice/cpp/include/Ice/SlicedDataF.h +17 -27
  95. data/dist/ice/cpp/include/Ice/StreamHelpers.h +532 -1070
  96. data/dist/ice/cpp/include/Ice/StreamableTraits.h +291 -0
  97. data/dist/ice/cpp/include/Ice/StringConverter.h +152 -63
  98. data/dist/ice/cpp/include/Ice/StringUtil.h +114 -0
  99. data/dist/ice/cpp/include/Ice/TimerTask.h +24 -0
  100. data/dist/ice/cpp/include/Ice/TupleCompare.h +103 -0
  101. data/dist/ice/cpp/include/Ice/UUID.h +6 -9
  102. data/dist/ice/cpp/include/Ice/UserException.h +46 -0
  103. data/dist/ice/cpp/include/Ice/UserExceptionFactory.h +4 -79
  104. data/dist/ice/cpp/include/Ice/Value.h +103 -115
  105. data/dist/ice/cpp/include/Ice/ValueF.h +6 -11
  106. data/dist/ice/cpp/include/IceDiscovery/IceDiscovery.h +16 -1877
  107. data/dist/ice/cpp/include/IceLocatorDiscovery/IceLocatorDiscovery.h +16 -1185
  108. data/dist/ice/cpp/include/generated/Ice/BuiltinSequences.h +46 -146
  109. data/dist/ice/cpp/include/generated/Ice/Context.h +40 -0
  110. data/dist/ice/cpp/include/generated/Ice/EndpointTypes.h +49 -93
  111. data/dist/ice/cpp/include/generated/Ice/Identity.h +70 -226
  112. data/dist/ice/cpp/include/generated/Ice/Locator.h +494 -3850
  113. data/dist/ice/cpp/include/generated/Ice/LocatorRegistry.h +443 -0
  114. data/dist/ice/cpp/include/generated/Ice/Metrics.h +937 -4603
  115. data/dist/ice/cpp/include/generated/Ice/OperationMode.h +73 -0
  116. data/dist/ice/cpp/include/generated/Ice/Process.h +197 -929
  117. data/dist/ice/cpp/include/generated/Ice/PropertiesAdmin.h +249 -1301
  118. data/dist/ice/cpp/include/generated/Ice/PropertyDict.h +39 -0
  119. data/dist/ice/cpp/include/generated/Ice/RemoteLogger.h +637 -2620
  120. data/dist/ice/cpp/include/generated/Ice/ReplyStatus.h +94 -0
  121. data/dist/ice/cpp/include/generated/Ice/Router.h +429 -1783
  122. data/dist/ice/cpp/include/generated/Ice/SliceChecksumDict.h +18 -65
  123. data/dist/ice/cpp/include/generated/Ice/Version.h +73 -318
  124. data/dist/ice/cpp/include/generated/IceDiscovery/Lookup.h +498 -0
  125. data/dist/ice/cpp/include/generated/IceLocatorDiscovery/Lookup.h +387 -0
  126. data/dist/ice/cpp/src/Ice/Acceptor.h +28 -24
  127. data/dist/ice/cpp/src/Ice/AcceptorF.h +6 -14
  128. data/dist/ice/cpp/src/Ice/AddDefaultPluginFactories.h +16 -0
  129. data/dist/ice/cpp/src/Ice/AddDefaultPluginFactories_all.cpp +43 -0
  130. data/dist/ice/cpp/src/Ice/AddDefaultPluginFactories_min.cpp +17 -0
  131. data/dist/ice/cpp/src/Ice/ArgVector.cpp +17 -18
  132. data/dist/ice/cpp/src/Ice/ArgVector.h +19 -25
  133. data/dist/ice/cpp/src/Ice/Base64.cpp +66 -66
  134. data/dist/ice/cpp/src/Ice/Base64.h +14 -19
  135. data/dist/ice/cpp/src/Ice/BatchRequestQueue.cpp +70 -121
  136. data/dist/ice/cpp/src/Ice/BatchRequestQueue.h +37 -47
  137. data/dist/ice/cpp/src/Ice/Buffer.cpp +73 -41
  138. data/dist/ice/cpp/src/Ice/CheckIdentity.h +21 -0
  139. data/dist/ice/cpp/src/Ice/CollocatedRequestHandler.cpp +215 -249
  140. data/dist/ice/cpp/src/Ice/CollocatedRequestHandler.h +38 -60
  141. data/dist/ice/cpp/src/Ice/Communicator.cpp +399 -0
  142. data/dist/ice/cpp/src/Ice/CommunicatorFlushBatchAsync.cpp +140 -0
  143. data/dist/ice/cpp/src/Ice/CommunicatorFlushBatchAsync.h +39 -0
  144. data/dist/ice/cpp/src/Ice/ConnectRequestHandler.cpp +63 -184
  145. data/dist/ice/cpp/src/Ice/ConnectRequestHandler.h +30 -51
  146. data/dist/ice/cpp/src/Ice/ConnectRequestHandlerF.h +4 -14
  147. data/dist/ice/cpp/src/Ice/Connection.cpp +44 -0
  148. data/dist/ice/cpp/src/Ice/ConnectionFactory.cpp +578 -792
  149. data/dist/ice/cpp/src/Ice/ConnectionFactory.h +200 -200
  150. data/dist/ice/cpp/src/Ice/ConnectionFactoryF.h +6 -19
  151. data/dist/ice/cpp/src/Ice/ConnectionI.cpp +1674 -1782
  152. data/dist/ice/cpp/src/Ice/ConnectionI.h +333 -293
  153. data/dist/ice/cpp/src/Ice/ConnectionOptions.h +22 -0
  154. data/dist/ice/cpp/src/Ice/Connector.h +25 -19
  155. data/dist/ice/cpp/src/Ice/ConnectorF.h +4 -11
  156. data/dist/ice/cpp/src/{IceUtil → Ice}/ConsoleUtil.cpp +32 -53
  157. data/dist/ice/cpp/src/Ice/ConsoleUtil.h +79 -0
  158. data/dist/ice/cpp/src/Ice/CtrlCHandler.cpp +189 -0
  159. data/dist/ice/cpp/src/Ice/Current.cpp +29 -0
  160. data/dist/ice/cpp/src/Ice/DLLMain.cpp +25 -35
  161. data/dist/ice/cpp/src/Ice/DefaultSliceLoader.cpp +39 -0
  162. data/dist/ice/cpp/src/Ice/DefaultsAndOverrides.cpp +41 -119
  163. data/dist/ice/cpp/src/Ice/DefaultsAndOverrides.h +27 -41
  164. data/dist/ice/cpp/src/Ice/DefaultsAndOverridesF.h +4 -11
  165. data/dist/ice/cpp/src/Ice/Demangle.cpp +26 -0
  166. data/dist/ice/cpp/src/Ice/DisableWarnings.h +31 -0
  167. data/dist/ice/cpp/src/Ice/DynamicLibrary.cpp +44 -112
  168. data/dist/ice/cpp/src/Ice/DynamicLibrary.h +91 -0
  169. data/dist/ice/cpp/src/Ice/Endian.h +40 -0
  170. data/dist/ice/cpp/src/Ice/EndpointFactory.cpp +35 -59
  171. data/dist/ice/cpp/src/Ice/EndpointFactory.h +82 -103
  172. data/dist/ice/cpp/src/Ice/EndpointFactoryF.h +4 -11
  173. data/dist/ice/cpp/src/Ice/EndpointFactoryManager.cpp +54 -87
  174. data/dist/ice/cpp/src/Ice/EndpointFactoryManager.h +28 -33
  175. data/dist/ice/cpp/src/Ice/EndpointFactoryManagerF.h +4 -11
  176. data/dist/ice/cpp/src/Ice/EndpointI.cpp +53 -23
  177. data/dist/ice/cpp/src/Ice/EndpointI.h +132 -200
  178. data/dist/ice/cpp/src/Ice/EndpointIF.h +11 -39
  179. data/dist/ice/cpp/src/Ice/EventHandler.cpp +3 -26
  180. data/dist/ice/cpp/src/Ice/EventHandler.h +46 -56
  181. data/dist/ice/cpp/src/Ice/EventHandlerF.h +4 -14
  182. data/dist/ice/cpp/src/Ice/Exception.cpp +3 -816
  183. data/dist/ice/cpp/src/Ice/FileUtil.cpp +476 -0
  184. data/dist/ice/cpp/src/Ice/FileUtil.h +152 -0
  185. data/dist/ice/cpp/src/Ice/FixedRequestHandler.cpp +34 -0
  186. data/dist/ice/cpp/src/Ice/FixedRequestHandler.h +29 -0
  187. data/dist/ice/cpp/src/Ice/HashUtil.h +46 -32
  188. data/dist/ice/cpp/src/Ice/HttpParser.cpp +431 -431
  189. data/dist/ice/cpp/src/Ice/HttpParser.h +95 -100
  190. data/dist/ice/cpp/src/Ice/IPEndpointI.cpp +207 -324
  191. data/dist/ice/cpp/src/Ice/IPEndpointI.h +80 -126
  192. data/dist/ice/cpp/src/Ice/IPEndpointIF.h +6 -17
  193. data/dist/ice/cpp/src/Ice/IdleTimeoutTransceiverDecorator.cpp +172 -0
  194. data/dist/ice/cpp/src/Ice/IdleTimeoutTransceiverDecorator.h +89 -0
  195. data/dist/ice/cpp/src/Ice/ImplicitContext.cpp +109 -0
  196. data/dist/ice/cpp/src/Ice/IncomingRequest.cpp +66 -0
  197. data/dist/ice/cpp/src/Ice/Initialize.cpp +48 -542
  198. data/dist/ice/cpp/src/Ice/InputStream.cpp +848 -1385
  199. data/dist/ice/cpp/src/Ice/Instance.cpp +816 -827
  200. data/dist/ice/cpp/src/Ice/Instance.h +202 -212
  201. data/dist/ice/cpp/src/Ice/InstrumentationI.cpp +526 -661
  202. data/dist/ice/cpp/src/Ice/InstrumentationI.h +171 -192
  203. data/dist/ice/cpp/src/Ice/LocalException.cpp +518 -0
  204. data/dist/ice/cpp/src/Ice/LocalExceptions.cpp +577 -0
  205. data/dist/ice/cpp/src/Ice/LocatorInfo.cpp +291 -329
  206. data/dist/ice/cpp/src/Ice/LocatorInfo.h +144 -157
  207. data/dist/ice/cpp/src/Ice/LocatorInfoF.h +8 -17
  208. data/dist/ice/cpp/src/Ice/LoggerAdminI.cpp +561 -743
  209. data/dist/ice/cpp/src/Ice/LoggerAdminI.h +18 -28
  210. data/dist/ice/cpp/src/Ice/LoggerI.cpp +66 -91
  211. data/dist/ice/cpp/src/Ice/LoggerI.h +36 -41
  212. data/dist/ice/cpp/src/Ice/LoggerMiddleware.cpp +176 -0
  213. data/dist/ice/cpp/src/Ice/LoggerMiddleware.h +42 -0
  214. data/dist/ice/cpp/src/Ice/LoggerUtil.cpp +14 -38
  215. data/dist/ice/cpp/src/Ice/MarshaledResult.cpp +20 -0
  216. data/dist/ice/cpp/src/Ice/MetricsAdminI.cpp +194 -280
  217. data/dist/ice/cpp/src/Ice/MetricsAdminI.h +600 -0
  218. data/dist/ice/cpp/src/Ice/MetricsFunctional.h +92 -0
  219. data/dist/ice/cpp/src/Ice/MetricsObserverI.h +587 -0
  220. data/dist/ice/cpp/src/Ice/NativePropertiesAdmin.cpp +185 -0
  221. data/dist/ice/cpp/src/Ice/Network.cpp +595 -917
  222. data/dist/ice/cpp/src/Ice/Network.h +189 -213
  223. data/dist/ice/cpp/src/Ice/NetworkF.h +2 -10
  224. data/dist/ice/cpp/src/Ice/NetworkProxy.cpp +99 -104
  225. data/dist/ice/cpp/src/Ice/NetworkProxy.h +49 -54
  226. data/dist/ice/cpp/src/Ice/NetworkProxyF.h +4 -11
  227. data/dist/ice/cpp/src/Ice/OSLogLoggerI.cpp +16 -18
  228. data/dist/ice/cpp/src/Ice/OSLogLoggerI.h +22 -27
  229. data/dist/ice/cpp/src/Ice/Object.cpp +152 -338
  230. data/dist/ice/cpp/src/Ice/ObjectAdapterFactory.cpp +170 -113
  231. data/dist/ice/cpp/src/Ice/ObjectAdapterFactory.h +41 -41
  232. data/dist/ice/cpp/src/Ice/ObjectAdapterFactoryF.h +4 -15
  233. data/dist/ice/cpp/src/Ice/ObjectAdapterI.cpp +580 -727
  234. data/dist/ice/cpp/src/Ice/ObjectAdapterI.h +149 -145
  235. data/dist/ice/cpp/src/Ice/ObserverHelper.cpp +36 -17
  236. data/dist/ice/cpp/src/Ice/ObserverMiddleware.cpp +96 -0
  237. data/dist/ice/cpp/src/Ice/ObserverMiddleware.h +25 -0
  238. data/dist/ice/cpp/src/Ice/OpaqueEndpointI.cpp +147 -187
  239. data/dist/ice/cpp/src/Ice/OpaqueEndpointI.h +56 -64
  240. data/dist/ice/cpp/src/{IceUtil → Ice}/Options.cpp +187 -258
  241. data/dist/ice/cpp/src/Ice/Options.h +119 -0
  242. data/dist/ice/cpp/src/Ice/OutgoingAsync.cpp +516 -732
  243. data/dist/ice/cpp/src/Ice/OutgoingResponse.cpp +276 -0
  244. data/dist/ice/cpp/src/Ice/OutputStream.cpp +610 -543
  245. data/dist/ice/cpp/src/Ice/OutputUtil.cpp +344 -0
  246. data/dist/ice/cpp/src/Ice/OutputUtil.h +173 -0
  247. data/dist/ice/cpp/src/Ice/PluginManagerI.cpp +118 -277
  248. data/dist/ice/cpp/src/Ice/PluginManagerI.h +41 -48
  249. data/dist/ice/cpp/src/Ice/Properties.cpp +931 -0
  250. data/dist/ice/cpp/src/Ice/PropertyNames.cpp +519 -1341
  251. data/dist/ice/cpp/src/Ice/PropertyNames.h +49 -64
  252. data/dist/ice/cpp/src/Ice/PropertyUtil.cpp +103 -0
  253. data/dist/ice/cpp/src/Ice/PropertyUtil.h +31 -0
  254. data/dist/ice/cpp/src/Ice/Protocol.cpp +129 -94
  255. data/dist/ice/cpp/src/Ice/Protocol.h +116 -0
  256. data/dist/ice/cpp/src/Ice/ProtocolInstance.cpp +117 -62
  257. data/dist/ice/cpp/src/Ice/ProtocolInstance.h +63 -82
  258. data/dist/ice/cpp/src/Ice/ProtocolInstanceF.h +4 -11
  259. data/dist/ice/cpp/src/Ice/ProtocolPluginFacade.cpp +10 -32
  260. data/dist/ice/cpp/src/Ice/ProtocolPluginFacade.h +25 -54
  261. data/dist/ice/cpp/src/Ice/Proxy.cpp +294 -1357
  262. data/dist/ice/cpp/src/Ice/ProxyAsync.cpp +684 -0
  263. data/dist/ice/cpp/src/Ice/ProxyFunctions.cpp +90 -0
  264. data/dist/ice/cpp/src/Ice/PushDisableDeprecatedWarnings.h +15 -0
  265. data/dist/ice/cpp/src/Ice/Random.cpp +29 -0
  266. data/dist/ice/cpp/src/Ice/Random.h +23 -0
  267. data/dist/ice/cpp/src/Ice/Reference.cpp +635 -1097
  268. data/dist/ice/cpp/src/Ice/Reference.h +314 -298
  269. data/dist/ice/cpp/src/Ice/ReferenceFactory.cpp +320 -378
  270. data/dist/ice/cpp/src/Ice/ReferenceFactory.h +48 -66
  271. data/dist/ice/cpp/src/Ice/ReferenceFactoryF.h +4 -9
  272. data/dist/ice/cpp/src/Ice/RequestHandler.cpp +15 -24
  273. data/dist/ice/cpp/src/Ice/RequestHandler.h +43 -68
  274. data/dist/ice/cpp/src/Ice/RequestHandlerCache.cpp +76 -0
  275. data/dist/ice/cpp/src/Ice/RequestHandlerCache.h +33 -0
  276. data/dist/ice/cpp/src/Ice/ResourceConfig.h +27 -0
  277. data/dist/ice/cpp/src/Ice/RetryQueue.cpp +51 -57
  278. data/dist/ice/cpp/src/Ice/RetryQueue.h +39 -46
  279. data/dist/ice/cpp/src/Ice/RetryQueueF.h +4 -9
  280. data/dist/ice/cpp/src/Ice/RouterInfo.cpp +97 -201
  281. data/dist/ice/cpp/src/Ice/RouterInfo.h +61 -118
  282. data/dist/ice/cpp/src/Ice/RouterInfoF.h +6 -14
  283. data/dist/ice/cpp/src/Ice/SHA1.cpp +86 -60
  284. data/dist/ice/cpp/src/Ice/SHA1.h +35 -0
  285. data/dist/ice/cpp/src/Ice/SSL/DistinguishedName.cpp +89 -0
  286. data/dist/ice/cpp/src/Ice/SSL/DistinguishedName.h +87 -0
  287. data/dist/ice/cpp/src/Ice/SSL/OpenSSLEngine.cpp +521 -0
  288. data/dist/ice/cpp/src/Ice/SSL/OpenSSLEngine.h +40 -0
  289. data/dist/ice/cpp/src/Ice/SSL/OpenSSLEngineF.h +13 -0
  290. data/dist/ice/cpp/src/Ice/SSL/OpenSSLTransceiverI.cpp +646 -0
  291. data/dist/ice/cpp/src/Ice/SSL/OpenSSLTransceiverI.h +80 -0
  292. data/dist/ice/cpp/src/{IceSSL → Ice/SSL}/RFC2253.cpp +85 -88
  293. data/dist/ice/cpp/src/Ice/SSL/RFC2253.h +58 -0
  294. data/dist/ice/cpp/src/Ice/SSL/SSLAcceptorI.cpp +124 -0
  295. data/dist/ice/cpp/src/Ice/SSL/SSLAcceptorI.h +52 -0
  296. data/dist/ice/cpp/src/Ice/SSL/SSLConnectorI.cpp +92 -0
  297. data/dist/ice/cpp/src/Ice/SSL/SSLConnectorI.h +38 -0
  298. data/dist/ice/cpp/src/Ice/SSL/SSLEndpointI.cpp +377 -0
  299. data/dist/ice/cpp/src/Ice/SSL/SSLEndpointI.h +84 -0
  300. data/dist/ice/cpp/src/Ice/SSL/SSLEngine.cpp +115 -0
  301. data/dist/ice/cpp/src/Ice/SSL/SSLEngine.h +69 -0
  302. data/dist/ice/cpp/src/Ice/SSL/SSLEngineF.h +14 -0
  303. data/dist/ice/cpp/src/Ice/SSL/SSLException.cpp +18 -0
  304. data/dist/ice/cpp/src/Ice/SSL/SSLInstance.cpp +27 -0
  305. data/dist/ice/cpp/src/Ice/SSL/SSLInstance.h +26 -0
  306. data/dist/ice/cpp/src/Ice/SSL/SSLInstanceF.h +19 -0
  307. data/dist/ice/cpp/src/Ice/SSL/SSLUtil.cpp +673 -0
  308. data/dist/ice/cpp/src/Ice/SSL/SSLUtil.h +118 -0
  309. data/dist/ice/cpp/src/Ice/SSL/SchannelEngine.cpp +1449 -0
  310. data/dist/ice/cpp/src/Ice/SSL/SchannelEngine.h +58 -0
  311. data/dist/ice/cpp/src/Ice/SSL/SchannelEngineF.h +18 -0
  312. data/dist/ice/cpp/src/Ice/SSL/SchannelTransceiverI.cpp +1088 -0
  313. data/dist/ice/cpp/src/Ice/SSL/SchannelTransceiverI.h +118 -0
  314. data/dist/ice/cpp/src/Ice/SSL/SecureTransportEngine.cpp +825 -0
  315. data/dist/ice/cpp/src/Ice/SSL/SecureTransportEngine.h +44 -0
  316. data/dist/ice/cpp/src/Ice/SSL/SecureTransportEngineF.h +18 -0
  317. data/dist/ice/cpp/src/Ice/SSL/SecureTransportTransceiverI.cpp +621 -0
  318. data/dist/ice/cpp/src/Ice/SSL/SecureTransportTransceiverI.h +91 -0
  319. data/dist/ice/cpp/src/Ice/SSL/SecureTransportUtil.cpp +1048 -0
  320. data/dist/ice/cpp/src/Ice/SSL/SecureTransportUtil.h +40 -0
  321. data/dist/ice/cpp/src/Ice/SSL/TrustManager.cpp +233 -0
  322. data/dist/ice/cpp/src/Ice/SSL/TrustManager.h +42 -0
  323. data/dist/ice/cpp/src/Ice/SSL/TrustManagerF.h +14 -0
  324. data/dist/ice/cpp/src/Ice/ScannerConfig.h +35 -0
  325. data/dist/ice/cpp/src/Ice/Selector.cpp +341 -606
  326. data/dist/ice/cpp/src/Ice/Selector.h +167 -224
  327. data/dist/ice/cpp/src/Ice/ServantManager.cpp +195 -128
  328. data/dist/ice/cpp/src/Ice/ServantManager.h +52 -55
  329. data/dist/ice/cpp/src/Ice/ServantManagerF.h +14 -0
  330. data/dist/ice/cpp/src/Ice/Service.cpp +548 -641
  331. data/dist/ice/cpp/src/Ice/SharedContext.h +13 -26
  332. data/dist/ice/cpp/src/Ice/SliceLoader.cpp +53 -0
  333. data/dist/ice/cpp/src/Ice/SlicedData.cpp +17 -96
  334. data/dist/ice/cpp/src/Ice/StreamSocket.cpp +104 -151
  335. data/dist/ice/cpp/src/Ice/StreamSocket.h +48 -60
  336. data/dist/ice/cpp/src/Ice/StringConverter.cpp +586 -0
  337. data/dist/ice/cpp/src/Ice/StringUtil.cpp +1137 -0
  338. data/dist/ice/cpp/src/Ice/SysLoggerI.cpp +41 -47
  339. data/dist/ice/cpp/src/Ice/SysLoggerI.h +24 -27
  340. data/dist/ice/cpp/src/Ice/SystemdJournalI.cpp +16 -17
  341. data/dist/ice/cpp/src/Ice/SystemdJournalI.h +19 -25
  342. data/dist/ice/cpp/src/Ice/TargetCompare.h +96 -0
  343. data/dist/ice/cpp/src/Ice/TcpAcceptor.cpp +67 -88
  344. data/dist/ice/cpp/src/Ice/TcpAcceptor.h +34 -40
  345. data/dist/ice/cpp/src/Ice/TcpConnector.cpp +42 -41
  346. data/dist/ice/cpp/src/Ice/TcpConnector.h +26 -35
  347. data/dist/ice/cpp/src/Ice/TcpEndpointI.cpp +172 -146
  348. data/dist/ice/cpp/src/Ice/TcpEndpointI.h +76 -80
  349. data/dist/ice/cpp/src/Ice/TcpTransceiver.cpp +38 -26
  350. data/dist/ice/cpp/src/Ice/TcpTransceiver.h +40 -45
  351. data/dist/ice/cpp/src/Ice/ThreadPool.cpp +333 -515
  352. data/dist/ice/cpp/src/Ice/ThreadPool.h +202 -290
  353. data/dist/ice/cpp/src/Ice/ThreadPoolF.h +14 -0
  354. data/dist/ice/cpp/src/Ice/TimeUtil.cpp +47 -0
  355. data/dist/ice/cpp/src/Ice/TimeUtil.h +21 -0
  356. data/dist/ice/cpp/src/Ice/Timer.cpp +73 -167
  357. data/dist/ice/cpp/src/Ice/Timer.h +212 -0
  358. data/dist/ice/cpp/src/Ice/TraceLevels.cpp +11 -29
  359. data/dist/ice/cpp/src/Ice/TraceLevels.h +22 -28
  360. data/dist/ice/cpp/src/Ice/TraceLevelsF.h +4 -11
  361. data/dist/ice/cpp/src/Ice/TraceUtil.cpp +136 -215
  362. data/dist/ice/cpp/src/Ice/TraceUtil.h +27 -16
  363. data/dist/ice/cpp/src/Ice/Transceiver.cpp +3 -7
  364. data/dist/ice/cpp/src/Ice/Transceiver.h +35 -32
  365. data/dist/ice/cpp/src/Ice/TransceiverF.h +10 -20
  366. data/dist/ice/cpp/src/Ice/UUID.cpp +79 -0
  367. data/dist/ice/cpp/src/Ice/UdpConnector.cpp +39 -39
  368. data/dist/ice/cpp/src/Ice/UdpConnector.h +27 -36
  369. data/dist/ice/cpp/src/Ice/UdpEndpointI.cpp +178 -213
  370. data/dist/ice/cpp/src/Ice/UdpEndpointI.h +82 -85
  371. data/dist/ice/cpp/src/Ice/UdpTransceiver.cpp +201 -221
  372. data/dist/ice/cpp/src/Ice/UdpTransceiver.h +68 -74
  373. data/dist/ice/cpp/{include/IceUtil → src/Ice}/UndefSysMacros.h +12 -12
  374. data/dist/ice/cpp/src/Ice/UniqueRef.h +77 -0
  375. data/dist/ice/cpp/src/Ice/UserException.cpp +58 -0
  376. data/dist/ice/cpp/src/Ice/Value.cpp +107 -38
  377. data/dist/ice/cpp/src/Ice/WSAcceptor.cpp +10 -15
  378. data/dist/ice/cpp/src/Ice/WSAcceptor.h +31 -37
  379. data/dist/ice/cpp/src/Ice/WSConnector.cpp +25 -40
  380. data/dist/ice/cpp/src/Ice/WSConnector.h +26 -33
  381. data/dist/ice/cpp/src/Ice/WSEndpoint.cpp +164 -217
  382. data/dist/ice/cpp/src/Ice/WSEndpoint.h +72 -83
  383. data/dist/ice/cpp/src/Ice/WSTransceiver.cpp +469 -458
  384. data/dist/ice/cpp/src/Ice/WSTransceiver.h +117 -123
  385. data/dist/ice/cpp/src/Ice/generated/BuiltinSequences.cpp +20 -29
  386. data/dist/ice/cpp/src/Ice/generated/Context.cpp +40 -0
  387. data/dist/ice/cpp/src/Ice/generated/EndpointTypes.cpp +20 -31
  388. data/dist/ice/cpp/src/Ice/generated/Identity.cpp +24 -34
  389. data/dist/ice/cpp/src/Ice/generated/Locator.cpp +454 -1744
  390. data/dist/ice/cpp/src/Ice/generated/LocatorRegistry.cpp +577 -0
  391. data/dist/ice/cpp/src/Ice/generated/Metrics.cpp +824 -1971
  392. data/dist/ice/cpp/src/Ice/generated/OperationMode.cpp +56 -0
  393. data/dist/ice/cpp/src/Ice/generated/Process.cpp +190 -331
  394. data/dist/ice/cpp/src/Ice/generated/PropertiesAdmin.cpp +289 -449
  395. data/dist/ice/cpp/src/Ice/generated/PropertyDict.cpp +40 -0
  396. data/dist/ice/cpp/src/Ice/generated/RemoteLogger.cpp +547 -867
  397. data/dist/ice/cpp/src/Ice/generated/ReplyStatus.cpp +70 -0
  398. data/dist/ice/cpp/src/Ice/generated/Router.cpp +406 -723
  399. data/dist/ice/cpp/src/Ice/generated/SliceChecksumDict.cpp +19 -29
  400. data/dist/ice/cpp/src/Ice/generated/Version.cpp +28 -31
  401. data/dist/ice/cpp/src/IceDiscovery/LocatorI.cpp +76 -139
  402. data/dist/ice/cpp/src/IceDiscovery/LocatorI.h +55 -96
  403. data/dist/ice/cpp/src/IceDiscovery/LookupI.cpp +190 -303
  404. data/dist/ice/cpp/src/IceDiscovery/LookupI.h +126 -185
  405. data/dist/ice/cpp/src/IceDiscovery/PluginI.cpp +56 -77
  406. data/dist/ice/cpp/src/IceDiscovery/PluginI.h +20 -25
  407. data/dist/ice/cpp/src/IceDiscovery/generated/Lookup.cpp +638 -0
  408. data/dist/ice/cpp/src/IceLocatorDiscovery/Plugin.h +14 -37
  409. data/dist/ice/cpp/src/IceLocatorDiscovery/PluginI.cpp +411 -649
  410. data/dist/ice/cpp/src/IceLocatorDiscovery/generated/Lookup.cpp +468 -0
  411. data/dist/ice/cpp/src/Slice/DeprecationReporter.cpp +172 -0
  412. data/dist/ice/cpp/src/Slice/DeprecationReporter.h +14 -0
  413. data/dist/ice/cpp/src/Slice/DocCommentParser.cpp +736 -0
  414. data/dist/ice/cpp/src/Slice/DocCommentParser.h +61 -0
  415. data/dist/ice/cpp/src/Slice/FileTracker.cpp +25 -75
  416. data/dist/ice/cpp/src/Slice/FileTracker.h +35 -56
  417. data/dist/ice/cpp/src/Slice/Grammar.cpp +2711 -3382
  418. data/dist/ice/cpp/src/Slice/Grammar.h +95 -75
  419. data/dist/ice/cpp/src/Slice/GrammarUtil.h +117 -217
  420. data/dist/ice/cpp/src/Slice/MetadataValidation.cpp +486 -0
  421. data/dist/ice/cpp/src/Slice/MetadataValidation.h +106 -0
  422. data/dist/ice/cpp/src/Slice/Parser.cpp +3068 -5223
  423. data/dist/ice/cpp/src/Slice/Parser.h +1086 -1065
  424. data/dist/ice/cpp/src/Slice/Preprocessor.cpp +97 -599
  425. data/dist/ice/cpp/src/Slice/Preprocessor.h +26 -42
  426. data/dist/ice/cpp/src/Slice/Scanner.cpp +1562 -924
  427. data/dist/ice/cpp/src/Slice/SliceUtil.cpp +517 -113
  428. data/dist/ice/cpp/src/Slice/StringLiteralUtil.cpp +254 -269
  429. data/dist/ice/cpp/src/Slice/Util.h +126 -35
  430. data/dist/ice/cpp/src/slice2rb/Main.cpp +13 -15
  431. data/dist/ice/cpp/src/slice2rb/Ruby.cpp +250 -0
  432. data/dist/ice/cpp/src/slice2rb/RubyUtil.cpp +1197 -0
  433. data/dist/ice/cpp/src/slice2rb/RubyUtil.h +56 -0
  434. data/dist/ice/slice/Glacier2/Metrics.ice +34 -75
  435. data/dist/ice/slice/Glacier2/PermissionsVerifier.ice +42 -98
  436. data/dist/ice/slice/Glacier2/Router.ice +80 -173
  437. data/dist/ice/slice/Glacier2/SSLInfo.ice +23 -40
  438. data/dist/ice/slice/Glacier2/Session.ice +120 -261
  439. data/dist/ice/slice/Ice/BuiltinSequences.ice +33 -38
  440. data/dist/ice/slice/Ice/Context.ice +24 -0
  441. data/dist/ice/slice/Ice/EndpointTypes.ice +35 -33
  442. data/dist/ice/slice/Ice/Identity.ice +24 -63
  443. data/dist/ice/slice/Ice/Locator.ice +61 -226
  444. data/dist/ice/slice/Ice/LocatorRegistry.ice +77 -0
  445. data/dist/ice/slice/Ice/Metrics.ice +189 -424
  446. data/dist/ice/slice/Ice/OperationMode.ice +38 -0
  447. data/dist/ice/slice/Ice/Process.ice +16 -52
  448. data/dist/ice/slice/Ice/PropertiesAdmin.ice +25 -75
  449. data/dist/ice/slice/Ice/PropertyDict.ice +23 -0
  450. data/dist/ice/slice/Ice/RemoteLogger.ice +113 -213
  451. data/dist/ice/slice/Ice/ReplyStatus.ice +65 -0
  452. data/dist/ice/slice/Ice/Router.ice +42 -91
  453. data/dist/ice/slice/Ice/SliceChecksumDict.ice +7 -25
  454. data/dist/ice/slice/Ice/Version.ice +31 -39
  455. data/dist/ice/slice/IceBox/ServiceManager.ice +79 -0
  456. data/dist/ice/slice/IceGrid/Admin.ice +942 -1918
  457. data/dist/ice/slice/IceGrid/Descriptor.ice +476 -1051
  458. data/dist/ice/slice/IceGrid/Exception.ice +86 -384
  459. data/dist/ice/slice/IceGrid/FileParser.ice +23 -59
  460. data/dist/ice/slice/IceGrid/Registry.ice +117 -256
  461. data/dist/ice/slice/IceGrid/Session.ice +46 -110
  462. data/dist/ice/slice/IceGrid/UserAccountMapper.ice +22 -57
  463. data/dist/ice/slice/IceStorm/IceStorm.ice +173 -401
  464. data/dist/ice/slice/IceStorm/Metrics.ice +28 -70
  465. data/dist/lib/Glacier2/Metrics.rb +16 -31
  466. data/dist/lib/Glacier2/PermissionsVerifier.rb +18 -50
  467. data/dist/lib/Glacier2/Router.rb +20 -42
  468. data/dist/lib/Glacier2/SSLInfo.rb +14 -22
  469. data/dist/lib/Glacier2/Session.rb +53 -113
  470. data/dist/lib/Glacier2.rb +6 -6
  471. data/dist/lib/Ice/BuiltinSequences.rb +14 -26
  472. data/dist/lib/Ice/CompressBatch.rb +50 -0
  473. data/dist/lib/Ice/Context.rb +12 -0
  474. data/dist/lib/Ice/EndpointSelectionType.rb +49 -0
  475. data/dist/lib/Ice/EndpointTypes.rb +14 -55
  476. data/dist/lib/Ice/Exception.rb +20 -0
  477. data/dist/lib/Ice/Identity.rb +10 -26
  478. data/dist/lib/Ice/IdentitySpaceship.rb +16 -0
  479. data/dist/lib/Ice/InitializationData.rb +12 -0
  480. data/dist/lib/Ice/LocalExceptions.rb +168 -0
  481. data/dist/lib/Ice/Locator.rb +21 -134
  482. data/dist/lib/Ice/LocatorRegistry.rb +73 -0
  483. data/dist/lib/Ice/Metrics.rb +85 -132
  484. data/dist/lib/Ice/OperationMode.rb +58 -0
  485. data/dist/lib/Ice/Process.rb +12 -31
  486. data/dist/lib/Ice/PropertiesAdmin.rb +12 -36
  487. data/dist/lib/Ice/PropertyDict.rb +12 -0
  488. data/dist/lib/Ice/Proxy.rb +85 -0
  489. data/dist/lib/Ice/ProxyFunctions.rb +69 -0
  490. data/dist/lib/Ice/RemoteLogger.rb +29 -60
  491. data/dist/lib/Ice/ReplyStatus.rb +65 -0
  492. data/dist/lib/Ice/Router.rb +19 -47
  493. data/dist/lib/Ice/SliceChecksumDict.rb +5 -17
  494. data/dist/lib/Ice/SliceUtil.rb +41 -0
  495. data/dist/lib/Ice/Struct.rb +11 -0
  496. data/dist/lib/Ice/ToStringMode.rb +50 -0
  497. data/dist/lib/Ice/Value.rb +93 -0
  498. data/dist/lib/Ice/Version.rb +12 -24
  499. data/dist/lib/Ice.rb +29 -665
  500. data/dist/lib/IceBox/ServiceManager.rb +104 -0
  501. data/dist/lib/IceBox.rb +2 -4
  502. data/dist/lib/IceGrid/Admin.rb +303 -291
  503. data/dist/lib/IceGrid/Descriptor.rb +147 -192
  504. data/dist/lib/IceGrid/Exception.rb +26 -257
  505. data/dist/lib/IceGrid/FileParser.rb +12 -36
  506. data/dist/lib/IceGrid/Registry.rb +35 -76
  507. data/dist/lib/IceGrid/Session.rb +19 -34
  508. data/dist/lib/IceGrid/UserAccountMapper.rb +11 -34
  509. data/dist/lib/IceGrid.rb +3 -3
  510. data/dist/lib/IceStorm/IceStorm.rb +51 -132
  511. data/dist/lib/IceStorm/Metrics.rb +19 -37
  512. data/dist/lib/IceStorm.rb +3 -5
  513. data/extconf.rb +6 -8
  514. data/ice.gemspec +3 -3
  515. data/scripts/slice2rb +1 -3
  516. metadata +206 -386
  517. data/dist/IceRuby/ValueFactoryManager.cpp +0 -445
  518. data/dist/IceRuby/ValueFactoryManager.h +0 -95
  519. data/dist/ice/cpp/include/Ice/Application.h +0 -326
  520. data/dist/ice/cpp/include/Ice/AsyncResult.h +0 -155
  521. data/dist/ice/cpp/include/Ice/AsyncResultF.h +0 -23
  522. data/dist/ice/cpp/include/Ice/BatchRequestInterceptor.h +0 -75
  523. data/dist/ice/cpp/include/Ice/CommunicatorAsync.h +0 -154
  524. data/dist/ice/cpp/include/Ice/Comparable.h +0 -205
  525. data/dist/ice/cpp/include/Ice/ConnectionAsync.h +0 -302
  526. data/dist/ice/cpp/include/Ice/ConsoleUtil.h +0 -23
  527. data/dist/ice/cpp/include/Ice/DefaultValueFactory.h +0 -57
  528. data/dist/ice/cpp/include/Ice/DispatchInterceptor.h +0 -41
  529. data/dist/ice/cpp/include/Ice/Dispatcher.h +0 -67
  530. data/dist/ice/cpp/include/Ice/DynamicLibrary.h +0 -102
  531. data/dist/ice/cpp/include/Ice/DynamicLibraryF.h +0 -24
  532. data/dist/ice/cpp/include/Ice/ExceptionHelpers.h +0 -74
  533. data/dist/ice/cpp/include/Ice/FactoryTable.h +0 -73
  534. data/dist/ice/cpp/include/Ice/FactoryTableInit.h +0 -84
  535. data/dist/ice/cpp/include/Ice/Functional.h +0 -140
  536. data/dist/ice/cpp/include/Ice/GCObject.h +0 -76
  537. data/dist/ice/cpp/include/Ice/Handle.h +0 -182
  538. data/dist/ice/cpp/include/Ice/Incoming.h +0 -225
  539. data/dist/ice/cpp/include/Ice/IncomingAsync.h +0 -186
  540. data/dist/ice/cpp/include/Ice/IncomingAsyncF.h +0 -36
  541. data/dist/ice/cpp/include/Ice/InterfaceByValue.h +0 -57
  542. data/dist/ice/cpp/include/Ice/LocalObject.h +0 -35
  543. data/dist/ice/cpp/include/Ice/LocalObjectF.h +0 -21
  544. data/dist/ice/cpp/include/Ice/MetricsAdminI.h +0 -715
  545. data/dist/ice/cpp/include/Ice/MetricsFunctional.h +0 -159
  546. data/dist/ice/cpp/include/Ice/MetricsObserverI.h +0 -669
  547. data/dist/ice/cpp/include/Ice/Optional.h +0 -1114
  548. data/dist/ice/cpp/include/Ice/OutgoingAsyncF.h +0 -39
  549. data/dist/ice/cpp/include/Ice/Protocol.h +0 -274
  550. data/dist/ice/cpp/include/Ice/ProxyFactoryF.h +0 -21
  551. data/dist/ice/cpp/include/Ice/ProxyHandle.h +0 -318
  552. data/dist/ice/cpp/include/Ice/RegisterPlugins.h +0 -127
  553. data/dist/ice/cpp/include/Ice/ResponseHandlerF.h +0 -25
  554. data/dist/ice/cpp/include/Ice/SHA1.h +0 -40
  555. data/dist/ice/cpp/include/Ice/ServantManagerF.h +0 -21
  556. data/dist/ice/cpp/include/Ice/SliceChecksums.h +0 -33
  557. data/dist/ice/cpp/include/Ice/ThreadPoolF.h +0 -23
  558. data/dist/ice/cpp/include/Ice/UniquePtr.h +0 -95
  559. data/dist/ice/cpp/include/Ice/UniqueRef.h +0 -97
  560. data/dist/ice/cpp/include/IceSSL/Config.h +0 -21
  561. data/dist/ice/cpp/include/IceSSL/IceSSL.h +0 -24
  562. data/dist/ice/cpp/include/IceSSL/OpenSSL.h +0 -147
  563. data/dist/ice/cpp/include/IceSSL/Plugin.h +0 -712
  564. data/dist/ice/cpp/include/IceSSL/SChannel.h +0 -72
  565. data/dist/ice/cpp/include/IceSSL/SecureTransport.h +0 -72
  566. data/dist/ice/cpp/include/IceUtil/Atomic.h +0 -179
  567. data/dist/ice/cpp/include/IceUtil/Cond.h +0 -317
  568. data/dist/ice/cpp/include/IceUtil/Config.h +0 -392
  569. data/dist/ice/cpp/include/IceUtil/ConsoleUtil.h +0 -92
  570. data/dist/ice/cpp/include/IceUtil/CountDownLatch.h +0 -45
  571. data/dist/ice/cpp/include/IceUtil/CtrlCHandler.h +0 -96
  572. data/dist/ice/cpp/include/IceUtil/DisableWarnings.h +0 -44
  573. data/dist/ice/cpp/include/IceUtil/Exception.h +0 -394
  574. data/dist/ice/cpp/include/IceUtil/FileUtil.h +0 -140
  575. data/dist/ice/cpp/include/IceUtil/Functional.h +0 -389
  576. data/dist/ice/cpp/include/IceUtil/Handle.h +0 -261
  577. data/dist/ice/cpp/include/IceUtil/IceUtil.h +0 -40
  578. data/dist/ice/cpp/include/IceUtil/InputUtil.h +0 -42
  579. data/dist/ice/cpp/include/IceUtil/Iterator.h +0 -31
  580. data/dist/ice/cpp/include/IceUtil/Lock.h +0 -128
  581. data/dist/ice/cpp/include/IceUtil/Monitor.h +0 -243
  582. data/dist/ice/cpp/include/IceUtil/Mutex.h +0 -349
  583. data/dist/ice/cpp/include/IceUtil/MutexProtocol.h +0 -23
  584. data/dist/ice/cpp/include/IceUtil/MutexPtrLock.h +0 -78
  585. data/dist/ice/cpp/include/IceUtil/MutexPtrTryLock.h +0 -77
  586. data/dist/ice/cpp/include/IceUtil/Optional.h +0 -433
  587. data/dist/ice/cpp/include/IceUtil/Options.h +0 -135
  588. data/dist/ice/cpp/include/IceUtil/OutputUtil.h +0 -383
  589. data/dist/ice/cpp/include/IceUtil/PushDisableWarnings.h +0 -33
  590. data/dist/ice/cpp/include/IceUtil/Random.h +0 -55
  591. data/dist/ice/cpp/include/IceUtil/RecMutex.h +0 -107
  592. data/dist/ice/cpp/include/IceUtil/ResourceConfig.h +0 -37
  593. data/dist/ice/cpp/include/IceUtil/ScannerConfig.h +0 -40
  594. data/dist/ice/cpp/include/IceUtil/ScopedArray.h +0 -98
  595. data/dist/ice/cpp/include/IceUtil/Shared.h +0 -127
  596. data/dist/ice/cpp/include/IceUtil/StopWatch.h +0 -49
  597. data/dist/ice/cpp/include/IceUtil/StringConverter.h +0 -195
  598. data/dist/ice/cpp/include/IceUtil/StringUtil.h +0 -97
  599. data/dist/ice/cpp/include/IceUtil/Thread.h +0 -160
  600. data/dist/ice/cpp/include/IceUtil/ThreadException.h +0 -94
  601. data/dist/ice/cpp/include/IceUtil/Time.h +0 -205
  602. data/dist/ice/cpp/include/IceUtil/Timer.h +0 -153
  603. data/dist/ice/cpp/include/IceUtil/UUID.h +0 -21
  604. data/dist/ice/cpp/include/generated/Glacier2/Metrics.h +0 -475
  605. data/dist/ice/cpp/include/generated/Glacier2/PermissionsVerifier.h +0 -1430
  606. data/dist/ice/cpp/include/generated/Glacier2/PermissionsVerifierF.h +0 -147
  607. data/dist/ice/cpp/include/generated/Glacier2/Router.h +0 -3260
  608. data/dist/ice/cpp/include/generated/Glacier2/RouterF.h +0 -125
  609. data/dist/ice/cpp/include/generated/Glacier2/SSLInfo.h +0 -223
  610. data/dist/ice/cpp/include/generated/Glacier2/Session.h +0 -5894
  611. data/dist/ice/cpp/include/generated/Ice/Communicator.h +0 -1162
  612. data/dist/ice/cpp/include/generated/Ice/CommunicatorF.h +0 -101
  613. data/dist/ice/cpp/include/generated/Ice/Connection.h +0 -1703
  614. data/dist/ice/cpp/include/generated/Ice/ConnectionF.h +0 -119
  615. data/dist/ice/cpp/include/generated/Ice/Current.h +0 -322
  616. data/dist/ice/cpp/include/generated/Ice/Endpoint.h +0 -979
  617. data/dist/ice/cpp/include/generated/Ice/EndpointF.h +0 -166
  618. data/dist/ice/cpp/include/generated/Ice/FacetMap.h +0 -80
  619. data/dist/ice/cpp/include/generated/Ice/ImplicitContext.h +0 -284
  620. data/dist/ice/cpp/include/generated/Ice/ImplicitContextF.h +0 -101
  621. data/dist/ice/cpp/include/generated/Ice/Instrumentation.h +0 -1203
  622. data/dist/ice/cpp/include/generated/Ice/InstrumentationF.h +0 -128
  623. data/dist/ice/cpp/include/generated/Ice/LocalException.h +0 -7437
  624. data/dist/ice/cpp/include/generated/Ice/LocatorF.h +0 -147
  625. data/dist/ice/cpp/include/generated/Ice/Logger.h +0 -237
  626. data/dist/ice/cpp/include/generated/Ice/LoggerF.h +0 -101
  627. data/dist/ice/cpp/include/generated/Ice/ObjectAdapter.h +0 -1181
  628. data/dist/ice/cpp/include/generated/Ice/ObjectAdapterF.h +0 -101
  629. data/dist/ice/cpp/include/generated/Ice/ObjectFactory.h +0 -203
  630. data/dist/ice/cpp/include/generated/Ice/Plugin.h +0 -318
  631. data/dist/ice/cpp/include/generated/Ice/PluginF.h +0 -110
  632. data/dist/ice/cpp/include/generated/Ice/ProcessF.h +0 -125
  633. data/dist/ice/cpp/include/generated/Ice/Properties.h +0 -452
  634. data/dist/ice/cpp/include/generated/Ice/PropertiesF.h +0 -134
  635. data/dist/ice/cpp/include/generated/Ice/RouterF.h +0 -125
  636. data/dist/ice/cpp/include/generated/Ice/ServantLocator.h +0 -305
  637. data/dist/ice/cpp/include/generated/Ice/ServantLocatorF.h +0 -101
  638. data/dist/ice/cpp/include/generated/Ice/ValueFactory.h +0 -330
  639. data/dist/ice/cpp/include/generated/IceBox/IceBox.h +0 -3269
  640. data/dist/ice/cpp/include/generated/IceGrid/Admin.h +0 -33773
  641. data/dist/ice/cpp/include/generated/IceGrid/Descriptor.h +0 -5254
  642. data/dist/ice/cpp/include/generated/IceGrid/Exception.h +0 -2834
  643. data/dist/ice/cpp/include/generated/IceGrid/FileParser.h +0 -824
  644. data/dist/ice/cpp/include/generated/IceGrid/PluginFacade.h +0 -635
  645. data/dist/ice/cpp/include/generated/IceGrid/Registry.h +0 -5089
  646. data/dist/ice/cpp/include/generated/IceGrid/Session.h +0 -2240
  647. data/dist/ice/cpp/include/generated/IceGrid/UserAccountMapper.h +0 -800
  648. data/dist/ice/cpp/include/generated/IcePatch2/FileInfo.h +0 -325
  649. data/dist/ice/cpp/include/generated/IcePatch2/FileServer.h +0 -2891
  650. data/dist/ice/cpp/include/generated/IceSSL/ConnectionInfo.h +0 -228
  651. data/dist/ice/cpp/include/generated/IceSSL/ConnectionInfoF.h +0 -101
  652. data/dist/ice/cpp/include/generated/IceSSL/EndpointInfo.h +0 -186
  653. data/dist/ice/cpp/include/generated/IceStorm/IceStorm.h +0 -6627
  654. data/dist/ice/cpp/include/generated/IceStorm/Metrics.h +0 -665
  655. data/dist/ice/cpp/src/Ice/ACM.cpp +0 -380
  656. data/dist/ice/cpp/src/Ice/ACM.h +0 -119
  657. data/dist/ice/cpp/src/Ice/ACMF.h +0 -30
  658. data/dist/ice/cpp/src/Ice/Acceptor.cpp +0 -16
  659. data/dist/ice/cpp/src/Ice/Application.cpp +0 -661
  660. data/dist/ice/cpp/src/Ice/AsyncResult.cpp +0 -70
  661. data/dist/ice/cpp/src/Ice/CommunicatorI.cpp +0 -586
  662. data/dist/ice/cpp/src/Ice/CommunicatorI.h +0 -167
  663. data/dist/ice/cpp/src/Ice/Cond.cpp +0 -381
  664. data/dist/ice/cpp/src/Ice/ConnectionRequestHandler.cpp +0 -73
  665. data/dist/ice/cpp/src/Ice/ConnectionRequestHandler.h +0 -41
  666. data/dist/ice/cpp/src/Ice/Connector.cpp +0 -16
  667. data/dist/ice/cpp/src/Ice/CountDownLatch.cpp +0 -171
  668. data/dist/ice/cpp/src/Ice/DispatchInterceptor.cpp +0 -37
  669. data/dist/ice/cpp/src/Ice/FactoryTable.cpp +0 -162
  670. data/dist/ice/cpp/src/Ice/FactoryTableInit.cpp +0 -88
  671. data/dist/ice/cpp/src/Ice/GCObject.cpp +0 -442
  672. data/dist/ice/cpp/src/Ice/IconvStringConverter.cpp +0 -51
  673. data/dist/ice/cpp/src/Ice/ImplicitContextI.cpp +0 -655
  674. data/dist/ice/cpp/src/Ice/ImplicitContextI.h +0 -48
  675. data/dist/ice/cpp/src/Ice/Incoming.cpp +0 -795
  676. data/dist/ice/cpp/src/Ice/IncomingAsync.cpp +0 -230
  677. data/dist/ice/cpp/src/Ice/IncomingRequest.h +0 -33
  678. data/dist/ice/cpp/src/Ice/LocalObject.cpp +0 -23
  679. data/dist/ice/cpp/src/Ice/MetricsObserverI.cpp +0 -8
  680. data/dist/ice/cpp/src/Ice/PropertiesAdminI.cpp +0 -265
  681. data/dist/ice/cpp/src/Ice/PropertiesAdminI.h +0 -64
  682. data/dist/ice/cpp/src/Ice/PropertiesI.cpp +0 -739
  683. data/dist/ice/cpp/src/Ice/PropertiesI.h +0 -70
  684. data/dist/ice/cpp/src/Ice/ProtocolPluginFacadeF.h +0 -21
  685. data/dist/ice/cpp/src/Ice/ProxyFactory.cpp +0 -300
  686. data/dist/ice/cpp/src/Ice/ProxyFactory.h +0 -57
  687. data/dist/ice/cpp/src/Ice/RegisterPluginsInit.cpp +0 -38
  688. data/dist/ice/cpp/src/Ice/RegisterPluginsInit.h +0 -20
  689. data/dist/ice/cpp/src/Ice/ReplyStatus.h +0 -24
  690. data/dist/ice/cpp/src/Ice/RequestHandlerFactory.cpp +0 -77
  691. data/dist/ice/cpp/src/Ice/RequestHandlerFactory.h +0 -37
  692. data/dist/ice/cpp/src/Ice/ResponseHandler.cpp +0 -12
  693. data/dist/ice/cpp/src/Ice/ResponseHandler.h +0 -43
  694. data/dist/ice/cpp/src/Ice/SliceChecksums.cpp +0 -75
  695. data/dist/ice/cpp/src/Ice/StringConverterPlugin.cpp +0 -192
  696. data/dist/ice/cpp/src/Ice/StringUtil.h +0 -30
  697. data/dist/ice/cpp/src/Ice/Thread.cpp +0 -569
  698. data/dist/ice/cpp/src/Ice/ValueFactoryManagerI.cpp +0 -61
  699. data/dist/ice/cpp/src/Ice/ValueFactoryManagerI.h +0 -37
  700. data/dist/ice/cpp/src/Ice/VirtualShared.h +0 -38
  701. data/dist/ice/cpp/src/Ice/generated/Communicator.cpp +0 -79
  702. data/dist/ice/cpp/src/Ice/generated/CommunicatorF.cpp +0 -61
  703. data/dist/ice/cpp/src/Ice/generated/Connection.cpp +0 -155
  704. data/dist/ice/cpp/src/Ice/generated/ConnectionF.cpp +0 -61
  705. data/dist/ice/cpp/src/Ice/generated/Current.cpp +0 -62
  706. data/dist/ice/cpp/src/Ice/generated/Endpoint.cpp +0 -147
  707. data/dist/ice/cpp/src/Ice/generated/EndpointF.cpp +0 -61
  708. data/dist/ice/cpp/src/Ice/generated/FacetMap.cpp +0 -49
  709. data/dist/ice/cpp/src/Ice/generated/ImplicitContext.cpp +0 -75
  710. data/dist/ice/cpp/src/Ice/generated/ImplicitContextF.cpp +0 -61
  711. data/dist/ice/cpp/src/Ice/generated/Instrumentation.cpp +0 -188
  712. data/dist/ice/cpp/src/Ice/generated/InstrumentationF.cpp +0 -66
  713. data/dist/ice/cpp/src/Ice/generated/LocalException.cpp +0 -3262
  714. data/dist/ice/cpp/src/Ice/generated/LocatorF.cpp +0 -63
  715. data/dist/ice/cpp/src/Ice/generated/Logger.cpp +0 -73
  716. data/dist/ice/cpp/src/Ice/generated/LoggerF.cpp +0 -61
  717. data/dist/ice/cpp/src/Ice/generated/ObjectAdapter.cpp +0 -79
  718. data/dist/ice/cpp/src/Ice/generated/ObjectAdapterF.cpp +0 -61
  719. data/dist/ice/cpp/src/Ice/generated/ObjectFactory.cpp +0 -75
  720. data/dist/ice/cpp/src/Ice/generated/Plugin.cpp +0 -87
  721. data/dist/ice/cpp/src/Ice/generated/PluginF.cpp +0 -61
  722. data/dist/ice/cpp/src/Ice/generated/ProcessF.cpp +0 -63
  723. data/dist/ice/cpp/src/Ice/generated/Properties.cpp +0 -78
  724. data/dist/ice/cpp/src/Ice/generated/PropertiesF.cpp +0 -63
  725. data/dist/ice/cpp/src/Ice/generated/RouterF.cpp +0 -63
  726. data/dist/ice/cpp/src/Ice/generated/ServantLocator.cpp +0 -75
  727. data/dist/ice/cpp/src/Ice/generated/ServantLocatorF.cpp +0 -61
  728. data/dist/ice/cpp/src/Ice/generated/ValueFactory.cpp +0 -83
  729. data/dist/ice/cpp/src/Ice/ios/StreamAcceptor.cpp +0 -154
  730. data/dist/ice/cpp/src/Ice/ios/StreamAcceptor.h +0 -49
  731. data/dist/ice/cpp/src/Ice/ios/StreamConnector.cpp +0 -146
  732. data/dist/ice/cpp/src/Ice/ios/StreamConnector.h +0 -52
  733. data/dist/ice/cpp/src/Ice/ios/StreamEndpointI.cpp +0 -477
  734. data/dist/ice/cpp/src/Ice/ios/StreamEndpointI.h +0 -156
  735. data/dist/ice/cpp/src/Ice/ios/StreamTransceiver.cpp +0 -570
  736. data/dist/ice/cpp/src/Ice/ios/StreamTransceiver.h +0 -93
  737. data/dist/ice/cpp/src/IceDiscovery/generated/IceDiscovery/IceDiscovery.h +0 -1889
  738. data/dist/ice/cpp/src/IceDiscovery/generated/IceDiscovery.cpp +0 -915
  739. data/dist/ice/cpp/src/IceLocatorDiscovery/generated/IceLocatorDiscovery/IceLocatorDiscovery.h +0 -1197
  740. data/dist/ice/cpp/src/IceLocatorDiscovery/generated/IceLocatorDiscovery.cpp +0 -730
  741. data/dist/ice/cpp/src/IceSSL/AcceptorI.cpp +0 -105
  742. data/dist/ice/cpp/src/IceSSL/AcceptorI.h +0 -52
  743. data/dist/ice/cpp/src/IceSSL/CertificateI.cpp +0 -301
  744. data/dist/ice/cpp/src/IceSSL/CertificateI.h +0 -64
  745. data/dist/ice/cpp/src/IceSSL/ConnectorI.cpp +0 -102
  746. data/dist/ice/cpp/src/IceSSL/ConnectorI.h +0 -44
  747. data/dist/ice/cpp/src/IceSSL/EndpointI.cpp +0 -372
  748. data/dist/ice/cpp/src/IceSSL/EndpointI.h +0 -100
  749. data/dist/ice/cpp/src/IceSSL/Instance.cpp +0 -28
  750. data/dist/ice/cpp/src/IceSSL/Instance.h +0 -37
  751. data/dist/ice/cpp/src/IceSSL/InstanceF.h +0 -33
  752. data/dist/ice/cpp/src/IceSSL/OpenSSLCertificateI.cpp +0 -688
  753. data/dist/ice/cpp/src/IceSSL/OpenSSLEngine.cpp +0 -1147
  754. data/dist/ice/cpp/src/IceSSL/OpenSSLEngine.h +0 -59
  755. data/dist/ice/cpp/src/IceSSL/OpenSSLEngineF.h +0 -27
  756. data/dist/ice/cpp/src/IceSSL/OpenSSLPluginI.cpp +0 -127
  757. data/dist/ice/cpp/src/IceSSL/OpenSSLTransceiverI.cpp +0 -1092
  758. data/dist/ice/cpp/src/IceSSL/OpenSSLTransceiverI.h +0 -90
  759. data/dist/ice/cpp/src/IceSSL/OpenSSLUtil.cpp +0 -288
  760. data/dist/ice/cpp/src/IceSSL/OpenSSLUtil.h +0 -58
  761. data/dist/ice/cpp/src/IceSSL/PluginI.cpp +0 -246
  762. data/dist/ice/cpp/src/IceSSL/PluginI.h +0 -67
  763. data/dist/ice/cpp/src/IceSSL/RFC2253.h +0 -62
  764. data/dist/ice/cpp/src/IceSSL/SChannelCertificateI.cpp +0 -721
  765. data/dist/ice/cpp/src/IceSSL/SChannelEngine.cpp +0 -1283
  766. data/dist/ice/cpp/src/IceSSL/SChannelEngine.h +0 -123
  767. data/dist/ice/cpp/src/IceSSL/SChannelEngineF.h +0 -31
  768. data/dist/ice/cpp/src/IceSSL/SChannelPluginI.cpp +0 -73
  769. data/dist/ice/cpp/src/IceSSL/SChannelTransceiverI.cpp +0 -1174
  770. data/dist/ice/cpp/src/IceSSL/SChannelTransceiverI.h +0 -133
  771. data/dist/ice/cpp/src/IceSSL/SSLEngine.cpp +0 -313
  772. data/dist/ice/cpp/src/IceSSL/SSLEngine.h +0 -100
  773. data/dist/ice/cpp/src/IceSSL/SSLEngineF.h +0 -21
  774. data/dist/ice/cpp/src/IceSSL/SecureTransportCertificateI.cpp +0 -999
  775. data/dist/ice/cpp/src/IceSSL/SecureTransportEngine.cpp +0 -1308
  776. data/dist/ice/cpp/src/IceSSL/SecureTransportEngine.h +0 -59
  777. data/dist/ice/cpp/src/IceSSL/SecureTransportEngineF.h +0 -29
  778. data/dist/ice/cpp/src/IceSSL/SecureTransportPluginI.cpp +0 -75
  779. data/dist/ice/cpp/src/IceSSL/SecureTransportTransceiverI.cpp +0 -719
  780. data/dist/ice/cpp/src/IceSSL/SecureTransportTransceiverI.h +0 -92
  781. data/dist/ice/cpp/src/IceSSL/SecureTransportUtil.cpp +0 -868
  782. data/dist/ice/cpp/src/IceSSL/SecureTransportUtil.h +0 -45
  783. data/dist/ice/cpp/src/IceSSL/TrustManager.cpp +0 -236
  784. data/dist/ice/cpp/src/IceSSL/TrustManager.h +0 -46
  785. data/dist/ice/cpp/src/IceSSL/TrustManagerF.h +0 -21
  786. data/dist/ice/cpp/src/IceSSL/Util.cpp +0 -192
  787. data/dist/ice/cpp/src/IceSSL/Util.h +0 -99
  788. data/dist/ice/cpp/src/IceSSL/generated/ConnectionInfo.cpp +0 -75
  789. data/dist/ice/cpp/src/IceSSL/generated/ConnectionInfoF.cpp +0 -61
  790. data/dist/ice/cpp/src/IceSSL/generated/EndpointInfo.cpp +0 -75
  791. data/dist/ice/cpp/src/IceUtil/ConvertUTF.cpp +0 -472
  792. data/dist/ice/cpp/src/IceUtil/ConvertUTF.h +0 -147
  793. data/dist/ice/cpp/src/IceUtil/CtrlCHandler.cpp +0 -259
  794. data/dist/ice/cpp/src/IceUtil/FileUtil.cpp +0 -471
  795. data/dist/ice/cpp/src/IceUtil/InputUtil.cpp +0 -36
  796. data/dist/ice/cpp/src/IceUtil/MutexProtocol.cpp +0 -19
  797. data/dist/ice/cpp/src/IceUtil/OutputUtil.cpp +0 -609
  798. data/dist/ice/cpp/src/IceUtil/Random.cpp +0 -180
  799. data/dist/ice/cpp/src/IceUtil/RecMutex.cpp +0 -238
  800. data/dist/ice/cpp/src/IceUtil/Shared.cpp +0 -71
  801. data/dist/ice/cpp/src/IceUtil/StringConverter.cpp +0 -690
  802. data/dist/ice/cpp/src/IceUtil/StringUtil.cpp +0 -1135
  803. data/dist/ice/cpp/src/IceUtil/ThreadException.cpp +0 -130
  804. data/dist/ice/cpp/src/IceUtil/Time.cpp +0 -307
  805. data/dist/ice/cpp/src/IceUtil/UUID.cpp +0 -165
  806. data/dist/ice/cpp/src/IceUtil/Unicode.cpp +0 -183
  807. data/dist/ice/cpp/src/IceUtil/Unicode.h +0 -43
  808. data/dist/ice/cpp/src/IceUtil/UtilException.cpp +0 -839
  809. data/dist/ice/cpp/src/Slice/CPlusPlusUtil.cpp +0 -1810
  810. data/dist/ice/cpp/src/Slice/CPlusPlusUtil.h +0 -72
  811. data/dist/ice/cpp/src/Slice/Checksum.cpp +0 -447
  812. data/dist/ice/cpp/src/Slice/Checksum.h +0 -21
  813. data/dist/ice/cpp/src/Slice/JavaUtil.cpp +0 -5183
  814. data/dist/ice/cpp/src/Slice/JavaUtil.h +0 -407
  815. data/dist/ice/cpp/src/Slice/MD5.cpp +0 -52
  816. data/dist/ice/cpp/src/Slice/MD5.h +0 -39
  817. data/dist/ice/cpp/src/Slice/MD5I.cpp +0 -393
  818. data/dist/ice/cpp/src/Slice/MD5I.h +0 -91
  819. data/dist/ice/cpp/src/Slice/PHPUtil.cpp +0 -157
  820. data/dist/ice/cpp/src/Slice/PHPUtil.h +0 -36
  821. data/dist/ice/cpp/src/Slice/Python.cpp +0 -830
  822. data/dist/ice/cpp/src/Slice/PythonUtil.cpp +0 -3439
  823. data/dist/ice/cpp/src/Slice/PythonUtil.h +0 -70
  824. data/dist/ice/cpp/src/Slice/Ruby.cpp +0 -350
  825. data/dist/ice/cpp/src/Slice/RubyUtil.cpp +0 -1571
  826. data/dist/ice/cpp/src/Slice/RubyUtil.h +0 -49
  827. data/dist/ice/slice/Glacier2/PermissionsVerifierF.ice +0 -30
  828. data/dist/ice/slice/Glacier2/RouterF.ice +0 -29
  829. data/dist/ice/slice/Ice/Communicator.ice +0 -676
  830. data/dist/ice/slice/Ice/CommunicatorF.ice +0 -31
  831. data/dist/ice/slice/Ice/Connection.ice +0 -516
  832. data/dist/ice/slice/Ice/ConnectionF.ice +0 -33
  833. data/dist/ice/slice/Ice/Current.ice +0 -170
  834. data/dist/ice/slice/Ice/Endpoint.ice +0 -291
  835. data/dist/ice/slice/Ice/EndpointF.ice +0 -43
  836. data/dist/ice/slice/Ice/FacetMap.ice +0 -36
  837. data/dist/ice/slice/Ice/ImplicitContext.ice +0 -119
  838. data/dist/ice/slice/Ice/ImplicitContextF.ice +0 -30
  839. data/dist/ice/slice/Ice/Instrumentation.ice +0 -509
  840. data/dist/ice/slice/Ice/InstrumentationF.ice +0 -38
  841. data/dist/ice/slice/Ice/LocalException.ice +0 -1040
  842. data/dist/ice/slice/Ice/LocatorF.ice +0 -32
  843. data/dist/ice/slice/Ice/Logger.ice +0 -99
  844. data/dist/ice/slice/Ice/LoggerF.ice +0 -31
  845. data/dist/ice/slice/Ice/ObjectAdapter.ice +0 -710
  846. data/dist/ice/slice/Ice/ObjectAdapterF.ice +0 -31
  847. data/dist/ice/slice/Ice/ObjectFactory.ice +0 -71
  848. data/dist/ice/slice/Ice/Plugin.ice +0 -131
  849. data/dist/ice/slice/Ice/PluginF.ice +0 -36
  850. data/dist/ice/slice/Ice/ProcessF.ice +0 -31
  851. data/dist/ice/slice/Ice/Properties.ice +0 -244
  852. data/dist/ice/slice/Ice/PropertiesF.ice +0 -32
  853. data/dist/ice/slice/Ice/RouterF.ice +0 -31
  854. data/dist/ice/slice/Ice/ServantLocator.ice +0 -136
  855. data/dist/ice/slice/Ice/ServantLocatorF.ice +0 -31
  856. data/dist/ice/slice/Ice/ValueFactory.ice +0 -133
  857. data/dist/ice/slice/IceBox/IceBox.ice +0 -216
  858. data/dist/ice/slice/IceGrid/PluginFacade.ice +0 -329
  859. data/dist/ice/slice/IcePatch2/FileInfo.ice +0 -85
  860. data/dist/ice/slice/IcePatch2/FileServer.ice +0 -191
  861. data/dist/lib/Glacier2/PermissionsVerifierF.rb +0 -30
  862. data/dist/lib/Glacier2/RouterF.rb +0 -25
  863. data/dist/lib/Ice/Communicator.rb +0 -87
  864. data/dist/lib/Ice/CommunicatorF.rb +0 -24
  865. data/dist/lib/Ice/Connection.rb +0 -413
  866. data/dist/lib/Ice/ConnectionF.rb +0 -32
  867. data/dist/lib/Ice/Current.rb +0 -141
  868. data/dist/lib/Ice/Endpoint.rb +0 -187
  869. data/dist/lib/Ice/EndpointF.rb +0 -48
  870. data/dist/lib/Ice/FacetMap.rb +0 -24
  871. data/dist/lib/Ice/ImplicitContext.rb +0 -26
  872. data/dist/lib/Ice/ImplicitContextF.rb +0 -24
  873. data/dist/lib/Ice/Instrumentation.rb +0 -169
  874. data/dist/lib/Ice/InstrumentationF.rb +0 -31
  875. data/dist/lib/Ice/LocalException.rb +0 -1031
  876. data/dist/lib/Ice/LocatorF.rb +0 -30
  877. data/dist/lib/Ice/Logger.rb +0 -24
  878. data/dist/lib/Ice/LoggerF.rb +0 -24
  879. data/dist/lib/Ice/ObjectAdapter.rb +0 -29
  880. data/dist/lib/Ice/ObjectAdapterF.rb +0 -24
  881. data/dist/lib/Ice/ObjectFactory.rb +0 -24
  882. data/dist/lib/Ice/Plugin.rb +0 -30
  883. data/dist/lib/Ice/PluginF.rb +0 -28
  884. data/dist/lib/Ice/ProcessF.rb +0 -25
  885. data/dist/lib/Ice/Properties.rb +0 -25
  886. data/dist/lib/Ice/PropertiesF.rb +0 -29
  887. data/dist/lib/Ice/RouterF.rb +0 -25
  888. data/dist/lib/Ice/ServantLocator.rb +0 -26
  889. data/dist/lib/Ice/ServantLocatorF.rb +0 -24
  890. data/dist/lib/Ice/ValueFactory.rb +0 -28
  891. data/dist/lib/IceBox/IceBox.rb +0 -164
  892. data/dist/lib/IceGrid/PluginFacade.rb +0 -35
  893. data/dist/lib/IcePatch2/FileInfo.rb +0 -115
  894. data/dist/lib/IcePatch2/FileServer.rb +0 -123
  895. data/dist/lib/IcePatch2.rb +0 -5
@@ -0,0 +1,1449 @@
1
+ // Copyright (c) ZeroC, Inc.
2
+
3
+ #include "SchannelEngine.h"
4
+ #include "../FileUtil.h"
5
+ #include "DistinguishedName.h"
6
+ #include "Ice/Communicator.h"
7
+ #include "Ice/LocalExceptions.h"
8
+ #include "Ice/Logger.h"
9
+ #include "Ice/StringConverter.h"
10
+ #include "Ice/StringUtil.h"
11
+ #include "Ice/UUID.h"
12
+ #include "SSLUtil.h"
13
+ #include "SchannelTransceiverI.h"
14
+
15
+ #include <wincrypt.h>
16
+
17
+ #include <mutex>
18
+
19
+ #ifndef SECURITY_FLAG_IGNORE_CERT_CN_INVALID
20
+ # define SECURITY_FLAG_IGNORE_CERT_CN_INVALID 0x00001000
21
+ #endif
22
+
23
+ //
24
+ // CALG_ECDH_EPHEM algorithm constant is not defined in older version of the SDK headers
25
+ //
26
+ // https://msdn.microsoft.com/en-us/library/windows/desktop/aa375549(v=vs.85).aspx
27
+ //
28
+
29
+ const int ICESSL_CALG_ECDH_EPHEM = 0x0000AE06;
30
+
31
+ using namespace std;
32
+ using namespace Ice;
33
+ using namespace IceInternal;
34
+ using namespace Ice::SSL;
35
+
36
+ namespace
37
+ {
38
+ mutex globalMutex;
39
+
40
+ string errorStatusToString(DWORD errorStatus)
41
+ {
42
+ assert(errorStatus != CERT_TRUST_NO_ERROR);
43
+ ostringstream os;
44
+ os << "SSL transport: certificate verification failure:";
45
+
46
+ if (errorStatus & CERT_TRUST_IS_NOT_TIME_VALID)
47
+ {
48
+ os << "\n - This certificate or one of the certificates in the certificate chain is not time valid.";
49
+ }
50
+
51
+ if (errorStatus & CERT_TRUST_IS_REVOKED)
52
+ {
53
+ os << "\n - Trust for this certificate or one of the certificates in the certificate chain has been "
54
+ "revoked.";
55
+ }
56
+
57
+ if (errorStatus & CERT_TRUST_IS_NOT_SIGNATURE_VALID)
58
+ {
59
+ os << "\n - The certificate or one of the certificates in the certificate chain does not have a valid "
60
+ "signature.";
61
+ }
62
+
63
+ if (errorStatus & CERT_TRUST_IS_NOT_VALID_FOR_USAGE)
64
+ {
65
+ os << "\n - The certificate or certificate chain is not valid for its proposed usage.";
66
+ }
67
+
68
+ if (errorStatus & CERT_TRUST_IS_UNTRUSTED_ROOT)
69
+ {
70
+ os << "\n - The certificate or certificate chain is based on an untrusted root.";
71
+ }
72
+
73
+ if (errorStatus & CERT_TRUST_REVOCATION_STATUS_UNKNOWN)
74
+ {
75
+ os << "\n - The revocation status of the certificate or one of the certificates in the certificate "
76
+ "chain is unknown.";
77
+ }
78
+
79
+ if (errorStatus & CERT_TRUST_IS_CYCLIC)
80
+ {
81
+ os << "\n - One of the certificates in the chain was issued by a certificate in the chain.";
82
+ }
83
+
84
+ if (errorStatus & CERT_TRUST_INVALID_EXTENSION)
85
+ {
86
+ os << "\n - One of the certificates has an extension that is not valid.";
87
+ }
88
+
89
+ if (errorStatus & CERT_TRUST_INVALID_POLICY_CONSTRAINTS)
90
+ {
91
+ os << "\n - The certificate or one of the certificates in the certificate chain has a policy "
92
+ "constraints extension, and one of the issued certificates has a disallowed policy mapping "
93
+ "extension or does not have a required issuance policies extension.";
94
+ }
95
+
96
+ if (errorStatus & CERT_TRUST_INVALID_BASIC_CONSTRAINTS)
97
+ {
98
+ os << "\n - The certificate or one of the certificates in the certificate chain has a basic "
99
+ "constraints "
100
+ "extension, and either the certificate cannot be used to issue other certificates, or the chain "
101
+ "path length has been exceeded.";
102
+ }
103
+
104
+ if (errorStatus & CERT_TRUST_HAS_NOT_SUPPORTED_NAME_CONSTRAINT)
105
+ {
106
+ os << "\n - The certificate or one of the certificates in the certificate chain has a name "
107
+ "constraints extension that contains unsupported fields.";
108
+ }
109
+
110
+ if (errorStatus & CERT_TRUST_HAS_NOT_DEFINED_NAME_CONSTRAINT)
111
+ {
112
+ os << "\n - The certificate or one of the certificates in the certificate chain has a name "
113
+ "constraints extension and a name constraint is missing for one of the name choices in the end "
114
+ "certificate.";
115
+ }
116
+
117
+ if (errorStatus & CERT_TRUST_HAS_NOT_PERMITTED_NAME_CONSTRAINT)
118
+ {
119
+ os << "\n - The certificate or one of the certificates in the certificate chain has a name "
120
+ "constraints extension, and there is not a permitted name constraint for one of the name choices "
121
+ "in the end certificate.";
122
+ }
123
+
124
+ if (errorStatus & CERT_TRUST_HAS_EXCLUDED_NAME_CONSTRAINT)
125
+ {
126
+ os << "\n - The certificate or one of the certificates in the certificate chain has a name "
127
+ "constraints extension, and one of the name choices in the end certificate is explicitly "
128
+ "excluded.";
129
+ }
130
+
131
+ if (errorStatus & CERT_TRUST_IS_OFFLINE_REVOCATION)
132
+ {
133
+ os << "\n - The revocation status of the certificate or one of the certificates in the certificate "
134
+ "chain is either offline or stale.";
135
+ }
136
+
137
+ if (errorStatus & CERT_TRUST_NO_ISSUANCE_CHAIN_POLICY)
138
+ {
139
+ os << "\n - The end certificate does not have any resultant issuance policies, and one of the issuing "
140
+ "certification authority certificates has a policy constraints extension requiring it.";
141
+ }
142
+
143
+ if (errorStatus & CERT_TRUST_IS_EXPLICIT_DISTRUST)
144
+ {
145
+ os << "\n - The certificate is explicitly distrusted.";
146
+ }
147
+
148
+ if (errorStatus & CERT_TRUST_HAS_NOT_SUPPORTED_CRITICAL_EXT)
149
+ {
150
+ os << "\n - The certificate does not support a critical extension.";
151
+ }
152
+
153
+ if (errorStatus & CERT_TRUST_HAS_WEAK_SIGNATURE)
154
+ {
155
+ os << "\n - The certificate has not been strong signed.";
156
+ }
157
+
158
+ if (errorStatus & CERT_TRUST_IS_PARTIAL_CHAIN)
159
+ {
160
+ os << "\n - The certificate chain is not complete.";
161
+ }
162
+
163
+ if (errorStatus & CERT_TRUST_CTL_IS_NOT_TIME_VALID)
164
+ {
165
+ os << "\n - A certificate trust list (CTL) used to create this chain was not time valid.";
166
+ }
167
+
168
+ if (errorStatus & CERT_TRUST_CTL_IS_NOT_SIGNATURE_VALID)
169
+ {
170
+ os << "\n - A CTL used to create this chain did not have a valid signature.";
171
+ }
172
+
173
+ if (errorStatus & CERT_TRUST_CTL_IS_NOT_VALID_FOR_USAGE)
174
+ {
175
+ os << "\n - A CTL used to create this chain is not valid for this usage.";
176
+ }
177
+
178
+ return os.str();
179
+ }
180
+
181
+ string policyStatusToString(DWORD policyStatus)
182
+ {
183
+ assert(policyStatus);
184
+ ostringstream os;
185
+ switch (policyStatus)
186
+ {
187
+ case TRUST_E_CERT_SIGNATURE:
188
+ {
189
+ os << "The signature of the certificate cannot be verified.";
190
+ break;
191
+ }
192
+ case CRYPT_E_REVOKED:
193
+ {
194
+ os << "The certificate or signature has been revoked.";
195
+ break;
196
+ }
197
+ case CERT_E_UNTRUSTEDROOT:
198
+ {
199
+ os << "A certification chain processed correctly but terminated in a root certificate that is not "
200
+ "trusted by "
201
+ "the trust provider.";
202
+ break;
203
+ }
204
+ case CERT_E_UNTRUSTEDTESTROOT:
205
+ {
206
+ os << "The root certificate is a testing certificate, and policy settings disallow test certificates.";
207
+ break;
208
+ }
209
+ case CERT_E_CHAINING:
210
+ {
211
+ os << "A chain of certificates was not correctly created.";
212
+ break;
213
+ }
214
+ case CERT_E_WRONG_USAGE:
215
+ {
216
+ os << "The certificate is not valid for the requested usage.";
217
+ break;
218
+ }
219
+ case CERT_E_EXPIRED:
220
+ {
221
+ os << "A required certificate is not within its validity period.";
222
+ break;
223
+ }
224
+ case CERT_E_INVALID_NAME:
225
+ {
226
+ os << "The certificate has an invalid name. Either the name is not included in the permitted list, or "
227
+ "it is "
228
+ "explicitly excluded.";
229
+ break;
230
+ }
231
+ case CERT_E_INVALID_POLICY:
232
+ {
233
+ os << "The certificate has invalid policy.";
234
+ break;
235
+ }
236
+ case TRUST_E_BASIC_CONSTRAINTS:
237
+ {
238
+ os << "The basic constraints of the certificate are not valid, or they are missing.";
239
+ break;
240
+ }
241
+ case CERT_E_CRITICAL:
242
+ {
243
+ os << "The certificate is being used for a purpose other than the purpose specified by its CA.";
244
+ break;
245
+ }
246
+ case CERT_E_VALIDITYPERIODNESTING:
247
+ {
248
+ os << "The validity periods of the certification chain do not nest correctly.";
249
+ break;
250
+ }
251
+ case CRYPT_E_NO_REVOCATION_CHECK:
252
+ {
253
+ os << "The revocation function was unable to check revocation for the certificate.";
254
+ break;
255
+ }
256
+ case CRYPT_E_REVOCATION_OFFLINE:
257
+ {
258
+ os << "The revocation function was unable to check revocation because the revocation server was "
259
+ "offline.";
260
+ break;
261
+ }
262
+ case CERT_E_CN_NO_MATCH:
263
+ {
264
+ os << "The certificate's CN name does not match the passed value.";
265
+ break;
266
+ }
267
+ case CERT_E_PURPOSE:
268
+ {
269
+ os << "The certificate is being used for a purpose other than the purpose specified by its CA.";
270
+ break;
271
+ }
272
+ case CERT_E_REVOKED:
273
+ {
274
+ os << "The certificate has been explicitly revoked by the issuer.";
275
+ break;
276
+ }
277
+ case CERT_E_REVOCATION_FAILURE:
278
+ {
279
+ os << "The revocation process could not continue, and the certificate could not be checked.";
280
+ break;
281
+ }
282
+ case CERT_E_ROLE:
283
+ {
284
+ os << "The certificate does not have a valid role.";
285
+ break;
286
+ }
287
+ default:
288
+ {
289
+ os << "Unknown policy status: " << policyStatus;
290
+ break;
291
+ }
292
+ }
293
+ return os.str();
294
+ }
295
+
296
+ void addMatchingCertificates(HCERTSTORE source, HCERTSTORE target, DWORD findType, const void* findParam)
297
+ {
298
+ PCCERT_CONTEXT next = 0;
299
+ do
300
+ {
301
+ if ((next = CertFindCertificateInStore(
302
+ source,
303
+ X509_ASN_ENCODING | PKCS_7_ASN_ENCODING,
304
+ 0,
305
+ findType,
306
+ findParam,
307
+ next)) != 0)
308
+ {
309
+ if (!CertAddCertificateContextToStore(target, next, CERT_STORE_ADD_ALWAYS, 0))
310
+ {
311
+ throw InitializationException(
312
+ __FILE__,
313
+ __LINE__,
314
+ "SSL transport: error adding certificate to store:\n" + IceInternal::lastErrorToString());
315
+ }
316
+ }
317
+ } while (next);
318
+ }
319
+
320
+ vector<PCCERT_CONTEXT>
321
+ findCertificates(const string& location, const string& storeName, const string& value, vector<HCERTSTORE>& stores)
322
+ {
323
+ HCERTSTORE store = CertOpenStore(
324
+ CERT_STORE_PROV_SYSTEM,
325
+ 0,
326
+ 0,
327
+ location == "CurrentUser" ? CERT_SYSTEM_STORE_CURRENT_USER : CERT_SYSTEM_STORE_LOCAL_MACHINE,
328
+ Ice::stringToWstring(storeName).c_str());
329
+
330
+ if (!store)
331
+ {
332
+ throw InitializationException(
333
+ __FILE__,
334
+ __LINE__,
335
+ "SSL transport: failed to open certificate store '" + storeName + "':\n" +
336
+ IceInternal::lastErrorToString());
337
+ }
338
+
339
+ //
340
+ // Start with all of the certificates in the collection and filter as necessary.
341
+ //
342
+ // - If the value is "*", return all certificates.
343
+ // - Otherwise, search using key:value pairs. The following keys are supported:
344
+ //
345
+ // Issuer
346
+ // IssuerDN
347
+ // Serial
348
+ // Subject
349
+ // SubjectDN
350
+ // SubjectKeyId
351
+ // Thumbprint
352
+ //
353
+ // A value must be enclosed in single or double quotes if it contains whitespace.
354
+ //
355
+ HCERTSTORE tmpStore = 0;
356
+ try
357
+ {
358
+ if (value != "*")
359
+ {
360
+ if (value.find(':', 0) == string::npos)
361
+ {
362
+ throw InitializationException(__FILE__, __LINE__, "SSL transport: no key in '" + value + "'");
363
+ }
364
+ size_t start = 0;
365
+ size_t pos;
366
+ while ((pos = value.find(':', start)) != string::npos)
367
+ {
368
+ string field = IceInternal::toUpper(IceInternal::trim(value.substr(start, pos - start)));
369
+ if (field != "SUBJECT" && field != "SUBJECTDN" && field != "ISSUER" && field != "ISSUERDN" &&
370
+ field != "THUMBPRINT" && field != "SUBJECTKEYID" && field != "SERIAL")
371
+ {
372
+ throw InitializationException(
373
+ __FILE__,
374
+ __LINE__,
375
+ "SSL transport: unknown key in '" + value + "'");
376
+ }
377
+
378
+ start = pos + 1;
379
+ while (start < value.size() && (value[start] == ' ' || value[start] == '\t'))
380
+ {
381
+ ++start;
382
+ }
383
+
384
+ if (start == value.size())
385
+ {
386
+ throw InitializationException(
387
+ __FILE__,
388
+ __LINE__,
389
+ "SSL transport: missing argument in '" + value + "'");
390
+ }
391
+
392
+ string arg;
393
+ if (value[start] == '"' || value[start] == '\'')
394
+ {
395
+ size_t end = start;
396
+ ++end;
397
+ while (end < value.size())
398
+ {
399
+ if (value[end] == value[start] && value[end - 1] != '\\')
400
+ {
401
+ break;
402
+ }
403
+ ++end;
404
+ }
405
+ if (end == value.size() || value[end] != value[start])
406
+ {
407
+ throw InitializationException(
408
+ __FILE__,
409
+ __LINE__,
410
+ "SSL transport: unmatched quote in '" + value + "'");
411
+ }
412
+ ++start;
413
+ arg = value.substr(start, end - start);
414
+ start = end + 1;
415
+ }
416
+ else
417
+ {
418
+ size_t end = value.find_first_of(" \t", start);
419
+ if (end == string::npos)
420
+ {
421
+ arg = value.substr(start);
422
+ start = value.size();
423
+ }
424
+ else
425
+ {
426
+ arg = value.substr(start, end - start);
427
+ start = end + 1;
428
+ }
429
+ }
430
+
431
+ tmpStore = CertOpenStore(CERT_STORE_PROV_MEMORY, 0, 0, 0, 0);
432
+ if (!tmpStore)
433
+ {
434
+ throw InitializationException(
435
+ __FILE__,
436
+ __LINE__,
437
+ "SSL transport: error adding certificate to store:\n" + IceInternal::lastErrorToString());
438
+ }
439
+
440
+ if (field == "SUBJECT" || field == "ISSUER")
441
+ {
442
+ const wstring argW = Ice::stringToWstring(arg);
443
+ DWORD findType = field == "SUBJECT" ? CERT_FIND_SUBJECT_STR : CERT_FIND_ISSUER_STR;
444
+ addMatchingCertificates(store, tmpStore, findType, argW.c_str());
445
+ }
446
+ else if (field == "SUBJECTDN" || field == "ISSUERDN")
447
+ {
448
+ const wstring argW = Ice::stringToWstring(arg);
449
+ DWORD flags[] = {
450
+ CERT_OID_NAME_STR,
451
+ CERT_OID_NAME_STR | CERT_NAME_STR_REVERSE_FLAG,
452
+ CERT_OID_NAME_STR | CERT_NAME_STR_FORCE_UTF8_DIR_STR_FLAG,
453
+ CERT_OID_NAME_STR | CERT_NAME_STR_FORCE_UTF8_DIR_STR_FLAG | CERT_NAME_STR_REVERSE_FLAG};
454
+ for (size_t i = 0; i < sizeof(flags) / sizeof(DWORD); ++i)
455
+ {
456
+ DWORD length = 0;
457
+ if (!CertStrToNameW(X509_ASN_ENCODING, argW.c_str(), flags[i], 0, 0, &length, 0))
458
+ {
459
+ throw InitializationException(
460
+ __FILE__,
461
+ __LINE__,
462
+ "SSL transport: invalid value '" + value + "' for `IceSSL.FindCert' property:\n" +
463
+ IceInternal::lastErrorToString());
464
+ }
465
+
466
+ vector<BYTE> buffer(length);
467
+ if (!CertStrToNameW(X509_ASN_ENCODING, argW.c_str(), flags[i], 0, &buffer[0], &length, 0))
468
+ {
469
+ throw InitializationException(
470
+ __FILE__,
471
+ __LINE__,
472
+ "SSL transport: invalid value '" + value + "' for `IceSSL.FindCert' property:\n" +
473
+ IceInternal::lastErrorToString());
474
+ }
475
+
476
+ CERT_NAME_BLOB name = {length, &buffer[0]};
477
+
478
+ DWORD findType = field == "SUBJECTDN" ? CERT_FIND_SUBJECT_NAME : CERT_FIND_ISSUER_NAME;
479
+ addMatchingCertificates(store, tmpStore, findType, &name);
480
+ }
481
+ }
482
+ else if (field == "THUMBPRINT" || field == "SUBJECTKEYID")
483
+ {
484
+ vector<BYTE> buffer;
485
+ if (!parseBytes(arg, buffer))
486
+ {
487
+ throw InitializationException(
488
+ __FILE__,
489
+ __LINE__,
490
+ "SSL transport: invalid 'IceSSL.FindCert' property: can't decode the value");
491
+ }
492
+
493
+ CRYPT_HASH_BLOB hash = {static_cast<DWORD>(buffer.size()), &buffer[0]};
494
+ DWORD findType = field == "THUMBPRINT" ? CERT_FIND_HASH : CERT_FIND_KEY_IDENTIFIER;
495
+ addMatchingCertificates(store, tmpStore, findType, &hash);
496
+ }
497
+ else if (field == "SERIAL")
498
+ {
499
+ vector<BYTE> buffer;
500
+ if (!parseBytes(arg, buffer))
501
+ {
502
+ throw InitializationException(
503
+ __FILE__,
504
+ __LINE__,
505
+ "SSL transport: invalid value '" + value + "' for `IceSSL.FindCert' property");
506
+ }
507
+
508
+ // CRYPT_INTEGER_BLOB stores serial data in little-endian format, parseBytes returns big-endian
509
+ // data.
510
+ std::vector<BYTE> serialData(buffer.size());
511
+ std::reverse_copy(std::begin(buffer), std::end(buffer), std::begin(serialData));
512
+
513
+ CRYPT_INTEGER_BLOB serial = {static_cast<DWORD>(serialData.size()), &serialData[0]};
514
+ PCCERT_CONTEXT next = nullptr;
515
+ do
516
+ {
517
+ if ((next = CertFindCertificateInStore(
518
+ store,
519
+ X509_ASN_ENCODING | PKCS_7_ASN_ENCODING,
520
+ 0,
521
+ CERT_FIND_ANY,
522
+ 0,
523
+ next)) != 0)
524
+ {
525
+ if (CertCompareIntegerBlob(&serial, &next->pCertInfo->SerialNumber))
526
+ {
527
+ if (!CertAddCertificateContextToStore(tmpStore, next, CERT_STORE_ADD_ALWAYS, 0))
528
+ {
529
+ throw InitializationException(
530
+ __FILE__,
531
+ __LINE__,
532
+ "SSL transport: error adding certificate to store:\n" +
533
+ IceInternal::lastErrorToString());
534
+ }
535
+ }
536
+ }
537
+ } while (next);
538
+ }
539
+ CertCloseStore(store, 0);
540
+ store = tmpStore;
541
+ }
542
+ }
543
+ }
544
+ catch (...)
545
+ {
546
+ if (store && store != tmpStore)
547
+ {
548
+ CertCloseStore(store, 0);
549
+ }
550
+
551
+ if (tmpStore)
552
+ {
553
+ CertCloseStore(tmpStore, 0);
554
+ tmpStore = nullptr;
555
+ }
556
+ throw;
557
+ }
558
+
559
+ vector<PCCERT_CONTEXT> certs;
560
+ if (store)
561
+ {
562
+ PCCERT_CONTEXT next = nullptr;
563
+ do
564
+ {
565
+ if ((next = CertFindCertificateInStore(
566
+ store,
567
+ X509_ASN_ENCODING | PKCS_7_ASN_ENCODING,
568
+ 0,
569
+ CERT_FIND_ANY,
570
+ 0,
571
+ next)) != 0)
572
+ {
573
+ certs.push_back(next);
574
+ }
575
+ } while (next);
576
+ stores.push_back(store);
577
+ }
578
+ return certs;
579
+ }
580
+
581
+ void addCertificatesToStore(const string& file, HCERTSTORE store, PCCERT_CONTEXT* cert = nullptr)
582
+ {
583
+ vector<char> buffer;
584
+ readFile(file, buffer);
585
+ if (buffer.empty())
586
+ {
587
+ ostringstream os;
588
+ os << "SSL transport: certificate file is empty: '" << file << "'";
589
+ throw InitializationException(__FILE__, __LINE__, os.str());
590
+ }
591
+
592
+ string strbuf(buffer.begin(), buffer.end());
593
+ string::size_type size, startpos, endpos = 0;
594
+ bool first = true;
595
+ while (true)
596
+ {
597
+ startpos = strbuf.find("-----BEGIN CERTIFICATE-----", endpos);
598
+ if (startpos != string::npos)
599
+ {
600
+ endpos = strbuf.find("-----END CERTIFICATE-----", startpos);
601
+ size = endpos - startpos + sizeof("-----END CERTIFICATE-----");
602
+ }
603
+ else if (first)
604
+ {
605
+ startpos = 0;
606
+ endpos = string::npos;
607
+ size = strbuf.size();
608
+ }
609
+ else
610
+ {
611
+ break;
612
+ }
613
+
614
+ vector<BYTE> outBuffer;
615
+ outBuffer.resize(size);
616
+ DWORD outLength = static_cast<DWORD>(outBuffer.size());
617
+ if (!CryptStringToBinary(
618
+ &buffer[startpos],
619
+ static_cast<DWORD>(size),
620
+ CRYPT_STRING_ANY,
621
+ &outBuffer[0],
622
+ &outLength,
623
+ 0,
624
+ 0))
625
+ {
626
+ assert(GetLastError() != ERROR_MORE_DATA); // Base64 data should always be bigger than binary
627
+ throw InitializationException(
628
+ __FILE__,
629
+ __LINE__,
630
+ "SSL transport: error decoding certificate:\n" + lastErrorToString());
631
+ }
632
+
633
+ if (!CertAddEncodedCertificateToStore(
634
+ store,
635
+ X509_ASN_ENCODING | PKCS_7_ASN_ENCODING,
636
+ &outBuffer[0],
637
+ outLength,
638
+ CERT_STORE_ADD_NEW,
639
+ first ? cert : 0))
640
+ {
641
+ if (GetLastError() != static_cast<DWORD>(CRYPT_E_EXISTS))
642
+ {
643
+ throw InitializationException(
644
+ __FILE__,
645
+ __LINE__,
646
+ "SSL transport: error decoding certificate:\n" + lastErrorToString());
647
+ }
648
+ }
649
+
650
+ first = false;
651
+ }
652
+ }
653
+
654
+ void verifyPeerCertName(
655
+ PCCERT_CONTEXT cert,
656
+ const string& address,
657
+ const Ice::LoggerPtr& logger,
658
+ int traceLevel,
659
+ const string& traceCategory)
660
+ {
661
+ // For an outgoing connection, we compare the proxy address (if any) against fields in the server's certificate
662
+ // (if any).
663
+
664
+ // Extract the IP addresses and the DNS names from the subject alternative names.
665
+ vector<pair<int, string>> subjectAltNames = getSubjectAltNames(cert);
666
+ vector<string> ipAddresses;
667
+ vector<string> dnsNames;
668
+ for (vector<pair<int, string>>::const_iterator p = subjectAltNames.begin(); p != subjectAltNames.end(); ++p)
669
+ {
670
+ if (p->first == AltNameIP)
671
+ {
672
+ ipAddresses.push_back(IceInternal::toLower(p->second));
673
+ }
674
+ else if (p->first == AltNameDNS)
675
+ {
676
+ dnsNames.push_back(IceInternal::toLower(p->second));
677
+ }
678
+ }
679
+
680
+ bool certNameOK = false;
681
+ string addrLower = IceInternal::toLower(address);
682
+ bool isIpAddress = IceInternal::isIpAddress(address);
683
+
684
+ // If address is an IP address, compare it to the subject alternative names IP address
685
+ if (isIpAddress)
686
+ {
687
+ certNameOK = find(ipAddresses.begin(), ipAddresses.end(), addrLower) != ipAddresses.end();
688
+ }
689
+ else
690
+ {
691
+ // If subjectAlt is empty compare it to the subject CN, otherwise compare it to the to the subject alt
692
+ // name dnsNames.
693
+ if (dnsNames.empty())
694
+ {
695
+ DistinguishedName d{list<pair<string, string>>{}};
696
+ try
697
+ {
698
+ d = DistinguishedName(getSubjectName(cert));
699
+ }
700
+ catch (const Ice::ParseException& ex)
701
+ {
702
+ throw SecurityException(
703
+ __FILE__,
704
+ __LINE__,
705
+ "SSL transport: certificate verification failure:\nunable to parse certificate DN:\n" +
706
+ string{ex.what()});
707
+ }
708
+ string dn = IceInternal::toLower(string(d));
709
+ string cn = "cn=" + addrLower;
710
+ string::size_type pos = dn.find(cn);
711
+ if (pos != string::npos)
712
+ {
713
+ // Ensure we match the entire common name.
714
+ certNameOK = (pos + cn.size() == dn.size()) || (dn[pos + cn.size()] == ',');
715
+ }
716
+ }
717
+ else
718
+ {
719
+ certNameOK = find(dnsNames.begin(), dnsNames.end(), addrLower) != dnsNames.end();
720
+ }
721
+ }
722
+
723
+ if (!certNameOK)
724
+ {
725
+ ostringstream os;
726
+ os << "SSL transport: certificate verification failure "
727
+ << (isIpAddress ? "IP address mismatch" : "Hostname mismatch");
728
+ string msg = os.str();
729
+ if (traceLevel >= 1)
730
+ {
731
+ Trace out(logger, traceCategory);
732
+ out << msg;
733
+ }
734
+ throw SecurityException(__FILE__, __LINE__, msg);
735
+ }
736
+ }
737
+ }
738
+
739
+ Schannel::SSLEngine::SSLEngine(const IceInternal::InstancePtr& instance)
740
+ : Ice::SSL::SSLEngine(instance),
741
+ _rootStore(nullptr),
742
+ _chainEngine(nullptr)
743
+ {
744
+ }
745
+
746
+ void
747
+ Schannel::SSLEngine::initialize()
748
+ {
749
+ //
750
+ // BUGFIX: we use a global mutex for the initialization of Schannel to
751
+ // avoid crashes occurring with last Schannel updates see:
752
+ // https://github.com/zeroc-ice/ice/issues/242
753
+ //
754
+ lock_guard globalLock(globalMutex);
755
+
756
+ Ice::SSL::SSLEngine::initialize();
757
+
758
+ const PropertiesPtr properties = getProperties();
759
+
760
+ // Check for a default directory. We look in this directory for files mentioned in the configuration.
761
+ const string defaultDir = properties->getIceProperty("IceSSL.DefaultDir");
762
+
763
+ string certStoreLocation = properties->getIceProperty("IceSSL.CertStoreLocation");
764
+ if (certStoreLocation != "CurrentUser" && certStoreLocation != "LocalMachine")
765
+ {
766
+ getLogger()->warning(
767
+ "invalid IceSSL.CertStoreLocation value '" + certStoreLocation + "' adjusted to 'CurrentUser'");
768
+ certStoreLocation = "CurrentUser";
769
+ }
770
+
771
+ //
772
+ // Create trusted CA store with contents of IceSSL.CAs
773
+ //
774
+ string caFile = properties->getIceProperty("IceSSL.CAs");
775
+ if (!caFile.empty() || properties->getIcePropertyAsInt("IceSSL.UsePlatformCAs") <= 0)
776
+ {
777
+ _rootStore = CertOpenStore(CERT_STORE_PROV_MEMORY, 0, 0, 0, 0);
778
+ if (!_rootStore)
779
+ {
780
+ throw InitializationException(
781
+ __FILE__,
782
+ __LINE__,
783
+ "SSL transport: error creating in memory certificate store:\n" + lastErrorToString());
784
+ }
785
+ }
786
+ if (!caFile.empty())
787
+ {
788
+ optional<string> resolved = resolveFilePath(caFile, defaultDir);
789
+
790
+ if (!resolved)
791
+ {
792
+ ostringstream os;
793
+ os << "SSL transport: CA certificate file not found: '" << caFile << "'";
794
+ throw InitializationException(__FILE__, __LINE__, os.str());
795
+ }
796
+
797
+ addCertificatesToStore(*resolved, _rootStore);
798
+ }
799
+
800
+ if (_rootStore)
801
+ {
802
+ //
803
+ // Create a chain engine that uses our Trusted Root Store
804
+ //
805
+ CERT_CHAIN_ENGINE_CONFIG config;
806
+ memset(&config, 0, sizeof(CERT_CHAIN_ENGINE_CONFIG));
807
+ config.cbSize = sizeof(CERT_CHAIN_ENGINE_CONFIG);
808
+ config.hExclusiveRoot = _rootStore;
809
+
810
+ //
811
+ // Build the chain using the LocalMachine registry location as opposed
812
+ // to the CurrentUser location.
813
+ //
814
+ if (certStoreLocation == "LocalMachine")
815
+ {
816
+ config.dwFlags = CERT_CHAIN_USE_LOCAL_MACHINE_STORE;
817
+ }
818
+
819
+ if (!CertCreateCertificateChainEngine(&config, &_chainEngine))
820
+ {
821
+ throw InitializationException(
822
+ __FILE__,
823
+ __LINE__,
824
+ "SSL transport: error creating certificate chain engine:\n" + lastErrorToString());
825
+ }
826
+ }
827
+ else
828
+ {
829
+ _chainEngine = (certStoreLocation == "LocalMachine") ? HCCE_LOCAL_MACHINE : HCCE_CURRENT_USER;
830
+ }
831
+
832
+ string certFile = properties->getIceProperty("IceSSL.CertFile");
833
+ string keyFile = properties->getIceProperty("IceSSL.KeyFile");
834
+ string findCert = properties->getIceProperty("IceSSL.FindCert");
835
+
836
+ if (!certFile.empty())
837
+ {
838
+ optional<string> resolved = resolveFilePath(certFile, defaultDir);
839
+
840
+ if (!resolved)
841
+ {
842
+ ostringstream os;
843
+ os << "SSL transport: certificate file not found: '" << certFile << "'";
844
+ throw InitializationException(__FILE__, __LINE__, os.str());
845
+ }
846
+ certFile = *resolved;
847
+
848
+ vector<char> buffer;
849
+ readFile(certFile, buffer);
850
+ if (buffer.empty())
851
+ {
852
+ ostringstream os;
853
+ os << "SSL transport: certificate file is empty: '" << certFile << "'";
854
+ throw InitializationException(__FILE__, __LINE__, os.str());
855
+ }
856
+
857
+ CRYPT_DATA_BLOB pfxBlob;
858
+ pfxBlob.cbData = static_cast<DWORD>(buffer.size());
859
+ pfxBlob.pbData = reinterpret_cast<BYTE*>(&buffer[0]);
860
+
861
+ PCCERT_CONTEXT cert = nullptr;
862
+ DWORD importFlags = (certStoreLocation == "LocalMachine") ? CRYPT_MACHINE_KEYSET : CRYPT_USER_KEYSET;
863
+ HCERTSTORE store = PFXImportCertStore(
864
+ &pfxBlob,
865
+ Ice::stringToWstring(properties->getIceProperty("IceSSL.Password")).c_str(),
866
+ importFlags);
867
+ int err = store ? 0 : GetLastError();
868
+
869
+ if (store)
870
+ {
871
+ // Try to find a certificate chain.
872
+ CERT_CHAIN_FIND_BY_ISSUER_PARA para;
873
+ memset(&para, 0, sizeof(CERT_CHAIN_FIND_BY_ISSUER_PARA));
874
+ para.cbSize = sizeof(CERT_CHAIN_FIND_BY_ISSUER_PARA);
875
+
876
+ PCCERT_CHAIN_CONTEXT chain = nullptr;
877
+ while (!cert)
878
+ {
879
+ chain = CertFindChainInStore(
880
+ store,
881
+ X509_ASN_ENCODING,
882
+ CERT_CHAIN_FIND_BY_ISSUER_CACHE_ONLY_URL_FLAG, // Don't fetch anything from the Internet
883
+ CERT_CHAIN_FIND_BY_ISSUER,
884
+ &para,
885
+ chain);
886
+ if (!chain)
887
+ {
888
+ break; // No more chains found in the store.
889
+ }
890
+
891
+ if (chain->cChain > 0 && chain->rgpChain[0]->cElement > 0)
892
+ {
893
+ cert = CertDuplicateCertificateContext(chain->rgpChain[0]->rgpElement[0]->pCertContext);
894
+ }
895
+ CertFreeCertificateChain(chain);
896
+ }
897
+
898
+ // Check if we can find a certificate if we couldn't find a chain.
899
+ if (!cert)
900
+ {
901
+ cert = CertFindCertificateInStore(store, X509_ASN_ENCODING, 0, CERT_FIND_ANY, 0, cert);
902
+ }
903
+ if (!cert)
904
+ {
905
+ throw InitializationException(
906
+ __FILE__,
907
+ __LINE__,
908
+ "SSL transport: certificate error:\n" + lastErrorToString());
909
+ }
910
+ _allCerts.push_back(cert);
911
+ _stores.push_back(store);
912
+ }
913
+ else
914
+ {
915
+ assert(err);
916
+ if (err != CRYPT_E_BAD_ENCODE)
917
+ {
918
+ throw InitializationException(
919
+ __FILE__,
920
+ __LINE__,
921
+ "SSL transport: error decoding certificate:\n" + lastErrorToString());
922
+ }
923
+
924
+ // Try to load certificate & key as PEM files.
925
+ err = 0;
926
+ resolved = resolveFilePath(keyFile, defaultDir);
927
+ if (!resolved)
928
+ {
929
+ ostringstream os;
930
+ os << "SSL transport: key file not found: '" << keyFile << "'";
931
+ throw InitializationException(__FILE__, __LINE__, os.str());
932
+ }
933
+ keyFile = *resolved;
934
+
935
+ readFile(keyFile, buffer);
936
+ if (buffer.empty())
937
+ {
938
+ ostringstream os;
939
+ os << "SSL transport: key file is empty: '" << keyFile << "'";
940
+ throw InitializationException(__FILE__, __LINE__, os.str());
941
+ }
942
+
943
+ vector<BYTE> outBuffer;
944
+ outBuffer.resize(buffer.size());
945
+ DWORD outLength = static_cast<DWORD>(buffer.size());
946
+
947
+ // Convert the PEM encoded buffer to DER binary format.
948
+ if (!CryptStringToBinary(
949
+ &buffer[0],
950
+ static_cast<DWORD>(buffer.size()),
951
+ CRYPT_STRING_BASE64HEADER,
952
+ &outBuffer[0],
953
+ &outLength,
954
+ 0,
955
+ 0))
956
+ {
957
+ ostringstream os;
958
+ os << "SSL transport: error decoding key '" << keyFile << "':\n" << lastErrorToString();
959
+ throw InitializationException(__FILE__, __LINE__, os.str());
960
+ }
961
+
962
+ PCRYPT_PRIVATE_KEY_INFO keyInfo = nullptr;
963
+ BYTE* key = nullptr;
964
+ HCRYPTKEY hKey = 0;
965
+ try
966
+ {
967
+ // First try to decode as a PKCS#8 key, if that fails try PKCS#1.
968
+ DWORD decodedLength = 0;
969
+ if (CryptDecodeObjectEx(
970
+ X509_ASN_ENCODING,
971
+ PKCS_PRIVATE_KEY_INFO,
972
+ &outBuffer[0],
973
+ outLength,
974
+ CRYPT_DECODE_ALLOC_FLAG,
975
+ 0,
976
+ &keyInfo,
977
+ &decodedLength))
978
+ {
979
+ // Check that we are using an RSA Key.
980
+ if (strcmp(keyInfo->Algorithm.pszObjId, szOID_RSA_RSA))
981
+ {
982
+ ostringstream os;
983
+ os << "SSL transport: unknown key algorithm: '" << keyInfo->Algorithm.pszObjId << "'";
984
+ throw InitializationException(__FILE__, __LINE__, os.str());
985
+ }
986
+
987
+ // Decode the private key BLOB.
988
+ if (!CryptDecodeObjectEx(
989
+ X509_ASN_ENCODING | PKCS_7_ASN_ENCODING,
990
+ PKCS_RSA_PRIVATE_KEY,
991
+ keyInfo->PrivateKey.pbData,
992
+ keyInfo->PrivateKey.cbData,
993
+ CRYPT_DECODE_ALLOC_FLAG,
994
+ 0,
995
+ &key,
996
+ &outLength))
997
+ {
998
+ ostringstream os;
999
+ os << "SSL transport: error decoding key '" + keyFile + "':\n" + lastErrorToString();
1000
+ throw InitializationException(__FILE__, __LINE__, os.str());
1001
+ }
1002
+ LocalFree(keyInfo);
1003
+ keyInfo = nullptr;
1004
+ }
1005
+ else
1006
+ {
1007
+ // Decode the private key BLOB.
1008
+ if (!CryptDecodeObjectEx(
1009
+ X509_ASN_ENCODING | PKCS_7_ASN_ENCODING,
1010
+ PKCS_RSA_PRIVATE_KEY,
1011
+ &outBuffer[0],
1012
+ outLength,
1013
+ CRYPT_DECODE_ALLOC_FLAG,
1014
+ 0,
1015
+ &key,
1016
+ &outLength))
1017
+ {
1018
+ ostringstream os;
1019
+ os << "SSL transport: error decoding key '" << keyFile << "':\n" << lastErrorToString();
1020
+ throw InitializationException(__FILE__, __LINE__, os.str());
1021
+ }
1022
+ }
1023
+
1024
+ // Create a new RSA key set to store our key.
1025
+ const wstring keySetName = Ice::stringToWstring(generateUUID());
1026
+ HCRYPTPROV cryptProv = 0;
1027
+
1028
+ DWORD contextFlags = CRYPT_NEWKEYSET;
1029
+ if (certStoreLocation == "LocalMachine")
1030
+ {
1031
+ contextFlags |= CRYPT_MACHINE_KEYSET;
1032
+ };
1033
+
1034
+ if (!CryptAcquireContextW(
1035
+ &cryptProv,
1036
+ keySetName.c_str(),
1037
+ MS_ENHANCED_PROV_W,
1038
+ PROV_RSA_FULL,
1039
+ contextFlags))
1040
+ {
1041
+ throw InitializationException(
1042
+ __FILE__,
1043
+ __LINE__,
1044
+ "SSL transport: error acquiring cryptographic context:\n" + lastErrorToString());
1045
+ }
1046
+
1047
+ // Import the private key.
1048
+ if (!CryptImportKey(cryptProv, key, outLength, 0, 0, &hKey))
1049
+ {
1050
+ ostringstream os;
1051
+ os << "SSL transport: error importing key '" << keyFile << "':\n" + lastErrorToString();
1052
+ throw InitializationException(__FILE__, __LINE__, os.str());
1053
+ }
1054
+ LocalFree(key);
1055
+ key = nullptr;
1056
+
1057
+ CryptDestroyKey(hKey);
1058
+ hKey = 0;
1059
+
1060
+ // Create a new memory store to place the certificate.
1061
+ store = CertOpenStore(CERT_STORE_PROV_MEMORY, 0, 0, 0, 0);
1062
+ if (!store)
1063
+ {
1064
+ throw InitializationException(
1065
+ __FILE__,
1066
+ __LINE__,
1067
+ "SSL transport: error creating certificate store:\n" + lastErrorToString());
1068
+ }
1069
+
1070
+ addCertificatesToStore(certFile, store, &cert);
1071
+
1072
+ // Associate key & certificate.
1073
+ CRYPT_KEY_PROV_INFO keyProvInfo;
1074
+ memset(&keyProvInfo, 0, sizeof(keyProvInfo));
1075
+ keyProvInfo.pwszContainerName = const_cast<wchar_t*>(keySetName.c_str());
1076
+ keyProvInfo.pwszProvName = const_cast<wchar_t*>(MS_DEF_PROV_W);
1077
+ keyProvInfo.dwProvType = PROV_RSA_FULL;
1078
+ keyProvInfo.dwKeySpec = AT_KEYEXCHANGE;
1079
+ if (!CertSetCertificateContextProperty(cert, CERT_KEY_PROV_INFO_PROP_ID, 0, &keyProvInfo))
1080
+ {
1081
+ throw InitializationException(
1082
+ __FILE__,
1083
+ __LINE__,
1084
+ "SSL transport: error setting certificate property:\n" + lastErrorToString());
1085
+ }
1086
+
1087
+ _importedCerts.push_back(cert);
1088
+ _allCerts.push_back(cert);
1089
+ _stores.push_back(store);
1090
+ }
1091
+ catch (...)
1092
+ {
1093
+ if (keyInfo)
1094
+ {
1095
+ LocalFree(keyInfo);
1096
+ }
1097
+
1098
+ if (key)
1099
+ {
1100
+ LocalFree(key);
1101
+ }
1102
+
1103
+ if (hKey)
1104
+ {
1105
+ CryptDestroyKey(hKey);
1106
+ }
1107
+
1108
+ if (cert)
1109
+ {
1110
+ CertFreeCertificateContext(cert);
1111
+ }
1112
+
1113
+ if (store)
1114
+ {
1115
+ CertCloseStore(store, 0);
1116
+ }
1117
+ throw;
1118
+ }
1119
+ }
1120
+ }
1121
+ else if (!findCert.empty())
1122
+ {
1123
+ string certStore = properties->getIceProperty("IceSSL.CertStore");
1124
+ vector<PCCERT_CONTEXT> certs = findCertificates(certStoreLocation, certStore, findCert, _stores);
1125
+ if (certs.empty())
1126
+ {
1127
+ throw InitializationException(__FILE__, __LINE__, "SSL transport: no certificates found");
1128
+ }
1129
+ _allCerts.insert(_allCerts.end(), certs.begin(), certs.end());
1130
+ }
1131
+ }
1132
+
1133
+ string
1134
+ Schannel::SSLEngine::getCipherName(ALG_ID cipher) const
1135
+ {
1136
+ switch (cipher)
1137
+ {
1138
+ case CALG_3DES:
1139
+ return "3DES";
1140
+ case CALG_3DES_112:
1141
+ return "3DES_112";
1142
+ case CALG_AES:
1143
+ return "AES";
1144
+ case CALG_AES_128:
1145
+ return "AES_128";
1146
+ case CALG_AES_192:
1147
+ return "AES_192";
1148
+ case CALG_AES_256:
1149
+ return "AES_256";
1150
+ case CALG_AGREEDKEY_ANY:
1151
+ return "AGREEDKEY_ANY";
1152
+ case CALG_CYLINK_MEK:
1153
+ return "CYLINK_MEK";
1154
+ case CALG_DES:
1155
+ return "DES";
1156
+ case CALG_DESX:
1157
+ return "DESX";
1158
+ case CALG_DH_EPHEM:
1159
+ return "DH_EPHEM";
1160
+ case CALG_DH_SF:
1161
+ return "DH_SF";
1162
+ case CALG_DSS_SIGN:
1163
+ return "DSS_SIGN";
1164
+ case CALG_ECDH:
1165
+ return "ECDH";
1166
+ case ICESSL_CALG_ECDH_EPHEM:
1167
+ return "ECDH_EPHEM";
1168
+ case CALG_ECDSA:
1169
+ return "ECDSA";
1170
+ case CALG_HASH_REPLACE_OWF:
1171
+ return "HASH_REPLACE_OWF";
1172
+ case CALG_HUGHES_MD5:
1173
+ return "HUGHES_MD5";
1174
+ case CALG_HMAC:
1175
+ return "HMAC";
1176
+ case CALG_MAC:
1177
+ return "MAC";
1178
+ case CALG_MD2:
1179
+ return "MD2";
1180
+ case CALG_MD4:
1181
+ return "MD4";
1182
+ case CALG_MD5:
1183
+ return "MD5";
1184
+ case CALG_NO_SIGN:
1185
+ return "NO_SIGN";
1186
+ case CALG_RC2:
1187
+ return "RC2";
1188
+ case CALG_RC4:
1189
+ return "RC4";
1190
+ case CALG_RC5:
1191
+ return "RC5";
1192
+ case CALG_RSA_KEYX:
1193
+ return "RSA_KEYX";
1194
+ case CALG_RSA_SIGN:
1195
+ return "RSA_SIGN";
1196
+ case CALG_SHA1:
1197
+ return "SHA1";
1198
+ case CALG_SHA_256:
1199
+ return "SHA_256";
1200
+ case CALG_SHA_384:
1201
+ return "SHA_384";
1202
+ case CALG_SHA_512:
1203
+ return "SHA_512";
1204
+ default:
1205
+ {
1206
+ ostringstream os;
1207
+ os << "Unknown cipher: " << cipher;
1208
+ return os.str();
1209
+ }
1210
+ }
1211
+ }
1212
+
1213
+ void
1214
+ Schannel::SSLEngine::destroy()
1215
+ {
1216
+ if (_chainEngine && _chainEngine != HCCE_CURRENT_USER && _chainEngine != HCCE_LOCAL_MACHINE)
1217
+ {
1218
+ CertFreeCertificateChainEngine(_chainEngine);
1219
+ }
1220
+
1221
+ if (_rootStore)
1222
+ {
1223
+ CertCloseStore(_rootStore, 0);
1224
+ }
1225
+
1226
+ for (vector<PCCERT_CONTEXT>::const_iterator i = _importedCerts.begin(); i != _importedCerts.end(); ++i)
1227
+ {
1228
+ // Retrieve the certificate CERT_KEY_PROV_INFO_PROP_ID property, we use the CRYPT_KEY_PROV_INFO data to remove
1229
+ // the key set associated with the certificate.
1230
+ DWORD length = 0;
1231
+ if (!CertGetCertificateContextProperty(*i, CERT_KEY_PROV_INFO_PROP_ID, 0, &length))
1232
+ {
1233
+ continue;
1234
+ }
1235
+ vector<char> buf(length);
1236
+ if (!CertGetCertificateContextProperty(*i, CERT_KEY_PROV_INFO_PROP_ID, &buf[0], &length))
1237
+ {
1238
+ continue;
1239
+ }
1240
+ CRYPT_KEY_PROV_INFO* key = reinterpret_cast<CRYPT_KEY_PROV_INFO*>(&buf[0]);
1241
+ HCRYPTPROV prov = 0;
1242
+ CryptAcquireContextW(&prov, key->pwszContainerName, key->pwszProvName, key->dwProvType, CRYPT_DELETEKEYSET);
1243
+ }
1244
+
1245
+ for (vector<PCCERT_CONTEXT>::const_iterator i = _allCerts.begin(); i != _allCerts.end(); ++i)
1246
+ {
1247
+ CertFreeCertificateContext(*i);
1248
+ }
1249
+
1250
+ for (vector<HCERTSTORE>::const_iterator i = _stores.begin(); i != _stores.end(); ++i)
1251
+ {
1252
+ CertCloseStore(*i, 0);
1253
+ }
1254
+ }
1255
+
1256
+ Ice::SSL::ClientAuthenticationOptions
1257
+ Schannel::SSLEngine::createClientAuthenticationOptions(const string& host) const
1258
+ {
1259
+ return Ice::SSL::ClientAuthenticationOptions{
1260
+ .clientCredentialsSelectionCallback =
1261
+ [this](const string&)
1262
+ {
1263
+ for (const auto& cert : _allCerts)
1264
+ {
1265
+ CertDuplicateCertificateContext(cert);
1266
+ }
1267
+
1268
+ return SCH_CREDENTIALS{
1269
+ .dwVersion = SCH_CREDENTIALS_VERSION,
1270
+ .cCreds = static_cast<DWORD>(_allCerts.size()),
1271
+ .paCred = const_cast<PCCERT_CONTEXT*>(_allCerts.size() > 0 ? &_allCerts[0] : nullptr),
1272
+ .dwFlags = SCH_CRED_NO_DEFAULT_CREDS | SCH_CRED_NO_SERVERNAME_CHECK | SCH_USE_STRONG_CRYPTO};
1273
+ },
1274
+ .trustedRootCertificates = _rootStore,
1275
+ .serverCertificateValidationCallback = [self = shared_from_this(),
1276
+ host](CtxtHandle ssl, const ConnectionInfoPtr& info) -> bool
1277
+ {
1278
+ bool ok = Schannel::SSLEngine::validationCallback(
1279
+ self->_chainEngine, // The chain engine configured to trust the provided trusted root certificates.
1280
+ ssl, // The SSL context handle.
1281
+ false, // This is an outgoing connection.
1282
+ host, // The target host.
1283
+ true, // Whether or not the peer must provide a certificate.
1284
+ self->getRevocationCheck(),
1285
+ self->getRevocationCheckCacheOnly());
1286
+ if (self->getCheckCertName() && info->peerCertificate && !host.empty())
1287
+ {
1288
+ verifyPeerCertName(
1289
+ info->peerCertificate,
1290
+ host,
1291
+ self->getLogger(),
1292
+ self->securityTraceLevel(),
1293
+ self->securityTraceCategory());
1294
+ }
1295
+ self->verifyPeer(info);
1296
+ return ok;
1297
+ }};
1298
+ }
1299
+
1300
+ Ice::SSL::ServerAuthenticationOptions
1301
+ Schannel::SSLEngine::createServerAuthenticationOptions() const
1302
+ {
1303
+ return Ice::SSL::ServerAuthenticationOptions{
1304
+ .serverCredentialsSelectionCallback =
1305
+ [this](const string&)
1306
+ {
1307
+ {
1308
+ for (const auto& cert : _allCerts)
1309
+ {
1310
+ CertDuplicateCertificateContext(cert);
1311
+ }
1312
+
1313
+ return SCH_CREDENTIALS{
1314
+ .dwVersion = SCH_CREDENTIALS_VERSION,
1315
+ .cCreds = static_cast<DWORD>(_allCerts.size()),
1316
+ .paCred = const_cast<PCCERT_CONTEXT*>(_allCerts.size() > 0 ? &_allCerts[0] : nullptr),
1317
+ // Don't set SCH_SEND_ROOT_CERT as it seems to cause problems with Java certificate validation and
1318
+ // Schannel doesn't seems to send the root certificate either way.
1319
+ .dwFlags = SCH_CRED_NO_SYSTEM_MAPPER | SCH_USE_STRONG_CRYPTO};
1320
+ }
1321
+ },
1322
+ .clientCertificateRequired = getVerifyPeer() > 0,
1323
+ .trustedRootCertificates = _rootStore,
1324
+ .clientCertificateValidationCallback =
1325
+ [self = shared_from_this()](CtxtHandle ssl, const ConnectionInfoPtr& info) -> bool
1326
+ {
1327
+ bool ok = Schannel::SSLEngine::validationCallback(
1328
+ self->_chainEngine, // The chain engine configured to trust the provided trusted root certificates.
1329
+ ssl, // The SSL context handle.
1330
+ true, // This is an incoming connection.
1331
+ "", // The target host, empty for incoming connections.
1332
+ self->getVerifyPeer() > 1, // Whether or not the peer must provide a certificate.
1333
+ self->getRevocationCheck(),
1334
+ self->getRevocationCheckCacheOnly());
1335
+ self->verifyPeer(info);
1336
+ return ok;
1337
+ }};
1338
+ }
1339
+
1340
+ namespace
1341
+ {
1342
+ struct ScopedCertChainContext
1343
+ {
1344
+ ScopedCertChainContext(PCCERT_CHAIN_CONTEXT chain) : _chain(chain) {}
1345
+ ~ScopedCertChainContext() { CertFreeCertificateChain(_chain); }
1346
+ PCCERT_CHAIN_CONTEXT _chain;
1347
+ };
1348
+ }
1349
+
1350
+ bool
1351
+ Schannel::SSLEngine::validationCallback(
1352
+ HCERTCHAINENGINE chainEngine,
1353
+ CtxtHandle ssl,
1354
+ bool incoming,
1355
+ const string& host,
1356
+ bool certificateRequired,
1357
+ int revocationCheck,
1358
+ bool revocationCheckCacheOnly)
1359
+ {
1360
+ // Build the peer certificate chain and verify it.
1361
+ PCCERT_CONTEXT cert = nullptr;
1362
+ SECURITY_STATUS err = QueryContextAttributes(&ssl, SECPKG_ATTR_REMOTE_CERT_CONTEXT, &cert);
1363
+
1364
+ if (err && (err != SEC_E_NO_CREDENTIALS || certificateRequired))
1365
+ {
1366
+ ostringstream os;
1367
+ os << "SSL transport: certificate verification failure:\n" << IceInternal::errorToString(err);
1368
+ throw SecurityException(__FILE__, __LINE__, os.str());
1369
+ }
1370
+
1371
+ if (cert) // Verify the remote certificate
1372
+ {
1373
+ ScopedCertificate scopedCertificate(cert);
1374
+ CERT_CHAIN_PARA chainP;
1375
+ memset(&chainP, 0, sizeof(chainP));
1376
+ chainP.cbSize = sizeof(chainP);
1377
+
1378
+ string trustError;
1379
+ PCCERT_CHAIN_CONTEXT certChain;
1380
+ DWORD dwFlags = 0;
1381
+ if (revocationCheck > 0)
1382
+ {
1383
+ if (revocationCheckCacheOnly)
1384
+ {
1385
+ // Disable network I/O for revocation checks.
1386
+ dwFlags = CERT_CHAIN_REVOCATION_CHECK_CACHE_ONLY | CERT_CHAIN_DISABLE_AIA;
1387
+ }
1388
+
1389
+ dwFlags |=
1390
+ (revocationCheck == 1 ? CERT_CHAIN_REVOCATION_CHECK_END_CERT
1391
+ : CERT_CHAIN_REVOCATION_CHECK_CHAIN_EXCLUDE_ROOT);
1392
+ }
1393
+
1394
+ if (!CertGetCertificateChain(
1395
+ chainEngine,
1396
+ cert,
1397
+ nullptr,
1398
+ cert->hCertStore,
1399
+ &chainP,
1400
+ dwFlags,
1401
+ nullptr,
1402
+ &certChain))
1403
+ {
1404
+ ostringstream os;
1405
+ os << "SSL transport: certificate verification failure:\n" << lastErrorToString();
1406
+ throw SecurityException(__FILE__, __LINE__, os.str());
1407
+ }
1408
+ ScopedCertChainContext scopedChainContext(certChain);
1409
+
1410
+ DWORD errorStatus = certChain->TrustStatus.dwErrorStatus;
1411
+ if (errorStatus != CERT_TRUST_NO_ERROR)
1412
+ {
1413
+ throw SecurityException(__FILE__, __LINE__, errorStatusToString(errorStatus));
1414
+ }
1415
+
1416
+ SSL_EXTRA_CERT_CHAIN_POLICY_PARA extraPolicyPara;
1417
+ memset(&extraPolicyPara, 0, sizeof(extraPolicyPara));
1418
+ extraPolicyPara.cbSize = sizeof(extraPolicyPara);
1419
+ extraPolicyPara.dwAuthType = incoming ? AUTHTYPE_CLIENT : AUTHTYPE_SERVER;
1420
+ // Disable because the policy only matches the CN of the certificate, not the SAN.
1421
+ extraPolicyPara.fdwChecks = SECURITY_FLAG_IGNORE_CERT_CN_INVALID;
1422
+ wstring hostW = Ice::stringToWstring(host);
1423
+ extraPolicyPara.pwszServerName = const_cast<wchar_t*>(hostW.c_str());
1424
+
1425
+ CERT_CHAIN_POLICY_PARA policyPara;
1426
+ memset(&policyPara, 0, sizeof(policyPara));
1427
+ policyPara.cbSize = sizeof(policyPara);
1428
+ policyPara.pvExtraPolicyPara = &extraPolicyPara;
1429
+
1430
+ CERT_CHAIN_POLICY_STATUS policyStatus;
1431
+ memset(&policyStatus, 0, sizeof(policyStatus));
1432
+ policyStatus.cbSize = sizeof(policyStatus);
1433
+
1434
+ if (!CertVerifyCertificateChainPolicy(CERT_CHAIN_POLICY_SSL, certChain, &policyPara, &policyStatus))
1435
+ {
1436
+ ostringstream os;
1437
+ os << "SSL transport: certificate verification failure:\n" << lastErrorToString();
1438
+ throw SecurityException(__FILE__, __LINE__, os.str());
1439
+ }
1440
+
1441
+ if (policyStatus.dwError)
1442
+ {
1443
+ ostringstream os;
1444
+ os << "SSL transport: certificate verification failure:\n" << policyStatusToString(policyStatus.dwError);
1445
+ throw SecurityException(__FILE__, __LINE__, os.str());
1446
+ }
1447
+ }
1448
+ return true;
1449
+ }