cli-ih 0.6.3.1__py3-none-any.whl → 0.7.0__py3-none-any.whl

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 (426) hide show
  1. cli_ih/__init__.py +1 -0
  2. cli_ih/asyncClient.py +73 -10
  3. cli_ih/client.py +63 -18
  4. cli_ih/utils.py +51 -0
  5. {cli_ih-0.6.3.1.dist-info → cli_ih-0.7.0.dist-info}/METADATA +1 -1
  6. cli_ih-0.7.0.dist-info/RECORD +9 -0
  7. {cli_ih-0.6.3.1.dist-info → cli_ih-0.7.0.dist-info}/top_level.txt +0 -1
  8. cli_ih-0.6.3.1.dist-info/RECORD +0 -425
  9. venv/Lib/site-packages/__editable___cli_ih_0_6_3_1_finder.py +0 -85
  10. venv/Lib/site-packages/pip/__init__.py +0 -13
  11. venv/Lib/site-packages/pip/__main__.py +0 -24
  12. venv/Lib/site-packages/pip/__pip-runner__.py +0 -50
  13. venv/Lib/site-packages/pip/_internal/__init__.py +0 -18
  14. venv/Lib/site-packages/pip/_internal/build_env.py +0 -349
  15. venv/Lib/site-packages/pip/_internal/cache.py +0 -291
  16. venv/Lib/site-packages/pip/_internal/cli/__init__.py +0 -3
  17. venv/Lib/site-packages/pip/_internal/cli/autocompletion.py +0 -184
  18. venv/Lib/site-packages/pip/_internal/cli/base_command.py +0 -244
  19. venv/Lib/site-packages/pip/_internal/cli/cmdoptions.py +0 -1138
  20. venv/Lib/site-packages/pip/_internal/cli/command_context.py +0 -28
  21. venv/Lib/site-packages/pip/_internal/cli/index_command.py +0 -175
  22. venv/Lib/site-packages/pip/_internal/cli/main.py +0 -80
  23. venv/Lib/site-packages/pip/_internal/cli/main_parser.py +0 -134
  24. venv/Lib/site-packages/pip/_internal/cli/parser.py +0 -298
  25. venv/Lib/site-packages/pip/_internal/cli/progress_bars.py +0 -151
  26. venv/Lib/site-packages/pip/_internal/cli/req_command.py +0 -351
  27. venv/Lib/site-packages/pip/_internal/cli/spinners.py +0 -235
  28. venv/Lib/site-packages/pip/_internal/cli/status_codes.py +0 -6
  29. venv/Lib/site-packages/pip/_internal/commands/__init__.py +0 -139
  30. venv/Lib/site-packages/pip/_internal/commands/cache.py +0 -231
  31. venv/Lib/site-packages/pip/_internal/commands/check.py +0 -66
  32. venv/Lib/site-packages/pip/_internal/commands/completion.py +0 -135
  33. venv/Lib/site-packages/pip/_internal/commands/configuration.py +0 -288
  34. venv/Lib/site-packages/pip/_internal/commands/debug.py +0 -203
  35. venv/Lib/site-packages/pip/_internal/commands/download.py +0 -145
  36. venv/Lib/site-packages/pip/_internal/commands/freeze.py +0 -107
  37. venv/Lib/site-packages/pip/_internal/commands/hash.py +0 -58
  38. venv/Lib/site-packages/pip/_internal/commands/help.py +0 -40
  39. venv/Lib/site-packages/pip/_internal/commands/index.py +0 -159
  40. venv/Lib/site-packages/pip/_internal/commands/inspect.py +0 -92
  41. venv/Lib/site-packages/pip/_internal/commands/install.py +0 -798
  42. venv/Lib/site-packages/pip/_internal/commands/list.py +0 -400
  43. venv/Lib/site-packages/pip/_internal/commands/lock.py +0 -170
  44. venv/Lib/site-packages/pip/_internal/commands/search.py +0 -178
  45. venv/Lib/site-packages/pip/_internal/commands/show.py +0 -231
  46. venv/Lib/site-packages/pip/_internal/commands/uninstall.py +0 -113
  47. venv/Lib/site-packages/pip/_internal/commands/wheel.py +0 -181
  48. venv/Lib/site-packages/pip/_internal/configuration.py +0 -397
  49. venv/Lib/site-packages/pip/_internal/distributions/__init__.py +0 -21
  50. venv/Lib/site-packages/pip/_internal/distributions/base.py +0 -55
  51. venv/Lib/site-packages/pip/_internal/distributions/installed.py +0 -33
  52. venv/Lib/site-packages/pip/_internal/distributions/sdist.py +0 -165
  53. venv/Lib/site-packages/pip/_internal/distributions/wheel.py +0 -44
  54. venv/Lib/site-packages/pip/_internal/exceptions.py +0 -881
  55. venv/Lib/site-packages/pip/_internal/index/__init__.py +0 -1
  56. venv/Lib/site-packages/pip/_internal/index/collector.py +0 -489
  57. venv/Lib/site-packages/pip/_internal/index/package_finder.py +0 -1059
  58. venv/Lib/site-packages/pip/_internal/index/sources.py +0 -287
  59. venv/Lib/site-packages/pip/_internal/locations/__init__.py +0 -441
  60. venv/Lib/site-packages/pip/_internal/locations/_distutils.py +0 -173
  61. venv/Lib/site-packages/pip/_internal/locations/_sysconfig.py +0 -215
  62. venv/Lib/site-packages/pip/_internal/locations/base.py +0 -82
  63. venv/Lib/site-packages/pip/_internal/main.py +0 -12
  64. venv/Lib/site-packages/pip/_internal/metadata/__init__.py +0 -164
  65. venv/Lib/site-packages/pip/_internal/metadata/_json.py +0 -87
  66. venv/Lib/site-packages/pip/_internal/metadata/base.py +0 -685
  67. venv/Lib/site-packages/pip/_internal/metadata/importlib/__init__.py +0 -6
  68. venv/Lib/site-packages/pip/_internal/metadata/importlib/_compat.py +0 -87
  69. venv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py +0 -223
  70. venv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py +0 -143
  71. venv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +0 -298
  72. venv/Lib/site-packages/pip/_internal/models/__init__.py +0 -1
  73. venv/Lib/site-packages/pip/_internal/models/candidate.py +0 -25
  74. venv/Lib/site-packages/pip/_internal/models/direct_url.py +0 -227
  75. venv/Lib/site-packages/pip/_internal/models/format_control.py +0 -78
  76. venv/Lib/site-packages/pip/_internal/models/index.py +0 -28
  77. venv/Lib/site-packages/pip/_internal/models/installation_report.py +0 -57
  78. venv/Lib/site-packages/pip/_internal/models/link.py +0 -613
  79. venv/Lib/site-packages/pip/_internal/models/pylock.py +0 -188
  80. venv/Lib/site-packages/pip/_internal/models/scheme.py +0 -25
  81. venv/Lib/site-packages/pip/_internal/models/search_scope.py +0 -126
  82. venv/Lib/site-packages/pip/_internal/models/selection_prefs.py +0 -53
  83. venv/Lib/site-packages/pip/_internal/models/target_python.py +0 -122
  84. venv/Lib/site-packages/pip/_internal/models/wheel.py +0 -141
  85. venv/Lib/site-packages/pip/_internal/network/__init__.py +0 -1
  86. venv/Lib/site-packages/pip/_internal/network/auth.py +0 -564
  87. venv/Lib/site-packages/pip/_internal/network/cache.py +0 -133
  88. venv/Lib/site-packages/pip/_internal/network/download.py +0 -342
  89. venv/Lib/site-packages/pip/_internal/network/lazy_wheel.py +0 -213
  90. venv/Lib/site-packages/pip/_internal/network/session.py +0 -528
  91. venv/Lib/site-packages/pip/_internal/network/utils.py +0 -98
  92. venv/Lib/site-packages/pip/_internal/network/xmlrpc.py +0 -61
  93. venv/Lib/site-packages/pip/_internal/operations/__init__.py +0 -0
  94. venv/Lib/site-packages/pip/_internal/operations/build/__init__.py +0 -0
  95. venv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py +0 -140
  96. venv/Lib/site-packages/pip/_internal/operations/build/metadata.py +0 -38
  97. venv/Lib/site-packages/pip/_internal/operations/build/metadata_editable.py +0 -41
  98. venv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py +0 -73
  99. venv/Lib/site-packages/pip/_internal/operations/build/wheel.py +0 -38
  100. venv/Lib/site-packages/pip/_internal/operations/build/wheel_editable.py +0 -47
  101. venv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py +0 -119
  102. venv/Lib/site-packages/pip/_internal/operations/check.py +0 -175
  103. venv/Lib/site-packages/pip/_internal/operations/freeze.py +0 -259
  104. venv/Lib/site-packages/pip/_internal/operations/install/__init__.py +0 -1
  105. venv/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py +0 -48
  106. venv/Lib/site-packages/pip/_internal/operations/install/wheel.py +0 -746
  107. venv/Lib/site-packages/pip/_internal/operations/prepare.py +0 -742
  108. venv/Lib/site-packages/pip/_internal/pyproject.py +0 -182
  109. venv/Lib/site-packages/pip/_internal/req/__init__.py +0 -105
  110. venv/Lib/site-packages/pip/_internal/req/constructors.py +0 -562
  111. venv/Lib/site-packages/pip/_internal/req/req_dependency_group.py +0 -75
  112. venv/Lib/site-packages/pip/_internal/req/req_file.py +0 -620
  113. venv/Lib/site-packages/pip/_internal/req/req_install.py +0 -937
  114. venv/Lib/site-packages/pip/_internal/req/req_set.py +0 -81
  115. venv/Lib/site-packages/pip/_internal/req/req_uninstall.py +0 -639
  116. venv/Lib/site-packages/pip/_internal/resolution/__init__.py +0 -0
  117. venv/Lib/site-packages/pip/_internal/resolution/base.py +0 -20
  118. venv/Lib/site-packages/pip/_internal/resolution/legacy/__init__.py +0 -0
  119. venv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +0 -598
  120. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__init__.py +0 -0
  121. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +0 -142
  122. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +0 -582
  123. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +0 -814
  124. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +0 -166
  125. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +0 -276
  126. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py +0 -85
  127. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +0 -247
  128. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py +0 -336
  129. venv/Lib/site-packages/pip/_internal/self_outdated_check.py +0 -254
  130. venv/Lib/site-packages/pip/_internal/utils/__init__.py +0 -0
  131. venv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py +0 -109
  132. venv/Lib/site-packages/pip/_internal/utils/_log.py +0 -38
  133. venv/Lib/site-packages/pip/_internal/utils/appdirs.py +0 -52
  134. venv/Lib/site-packages/pip/_internal/utils/compat.py +0 -85
  135. venv/Lib/site-packages/pip/_internal/utils/compatibility_tags.py +0 -201
  136. venv/Lib/site-packages/pip/_internal/utils/datetime.py +0 -10
  137. venv/Lib/site-packages/pip/_internal/utils/deprecation.py +0 -126
  138. venv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +0 -87
  139. venv/Lib/site-packages/pip/_internal/utils/egg_link.py +0 -81
  140. venv/Lib/site-packages/pip/_internal/utils/entrypoints.py +0 -88
  141. venv/Lib/site-packages/pip/_internal/utils/filesystem.py +0 -152
  142. venv/Lib/site-packages/pip/_internal/utils/filetypes.py +0 -24
  143. venv/Lib/site-packages/pip/_internal/utils/glibc.py +0 -102
  144. venv/Lib/site-packages/pip/_internal/utils/hashes.py +0 -150
  145. venv/Lib/site-packages/pip/_internal/utils/logging.py +0 -364
  146. venv/Lib/site-packages/pip/_internal/utils/misc.py +0 -765
  147. venv/Lib/site-packages/pip/_internal/utils/packaging.py +0 -44
  148. venv/Lib/site-packages/pip/_internal/utils/retry.py +0 -45
  149. venv/Lib/site-packages/pip/_internal/utils/setuptools_build.py +0 -149
  150. venv/Lib/site-packages/pip/_internal/utils/subprocess.py +0 -248
  151. venv/Lib/site-packages/pip/_internal/utils/temp_dir.py +0 -294
  152. venv/Lib/site-packages/pip/_internal/utils/unpacking.py +0 -337
  153. venv/Lib/site-packages/pip/_internal/utils/urls.py +0 -55
  154. venv/Lib/site-packages/pip/_internal/utils/virtualenv.py +0 -105
  155. venv/Lib/site-packages/pip/_internal/utils/wheel.py +0 -132
  156. venv/Lib/site-packages/pip/_internal/vcs/__init__.py +0 -15
  157. venv/Lib/site-packages/pip/_internal/vcs/bazaar.py +0 -130
  158. venv/Lib/site-packages/pip/_internal/vcs/git.py +0 -571
  159. venv/Lib/site-packages/pip/_internal/vcs/mercurial.py +0 -186
  160. venv/Lib/site-packages/pip/_internal/vcs/subversion.py +0 -335
  161. venv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +0 -693
  162. venv/Lib/site-packages/pip/_internal/wheel_builder.py +0 -334
  163. venv/Lib/site-packages/pip/_vendor/__init__.py +0 -117
  164. venv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py +0 -29
  165. venv/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py +0 -70
  166. venv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +0 -168
  167. venv/Lib/site-packages/pip/_vendor/cachecontrol/cache.py +0 -75
  168. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py +0 -8
  169. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py +0 -145
  170. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py +0 -48
  171. venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py +0 -511
  172. venv/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py +0 -119
  173. venv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +0 -157
  174. venv/Lib/site-packages/pip/_vendor/cachecontrol/py.typed +0 -0
  175. venv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +0 -146
  176. venv/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py +0 -43
  177. venv/Lib/site-packages/pip/_vendor/certifi/__init__.py +0 -4
  178. venv/Lib/site-packages/pip/_vendor/certifi/__main__.py +0 -12
  179. venv/Lib/site-packages/pip/_vendor/certifi/core.py +0 -83
  180. venv/Lib/site-packages/pip/_vendor/certifi/py.typed +0 -0
  181. venv/Lib/site-packages/pip/_vendor/dependency_groups/__init__.py +0 -13
  182. venv/Lib/site-packages/pip/_vendor/dependency_groups/__main__.py +0 -65
  183. venv/Lib/site-packages/pip/_vendor/dependency_groups/_implementation.py +0 -209
  184. venv/Lib/site-packages/pip/_vendor/dependency_groups/_lint_dependency_groups.py +0 -59
  185. venv/Lib/site-packages/pip/_vendor/dependency_groups/_pip_wrapper.py +0 -62
  186. venv/Lib/site-packages/pip/_vendor/dependency_groups/_toml_compat.py +0 -9
  187. venv/Lib/site-packages/pip/_vendor/dependency_groups/py.typed +0 -0
  188. venv/Lib/site-packages/pip/_vendor/distlib/__init__.py +0 -33
  189. venv/Lib/site-packages/pip/_vendor/distlib/compat.py +0 -1137
  190. venv/Lib/site-packages/pip/_vendor/distlib/resources.py +0 -358
  191. venv/Lib/site-packages/pip/_vendor/distlib/scripts.py +0 -447
  192. venv/Lib/site-packages/pip/_vendor/distlib/util.py +0 -1984
  193. venv/Lib/site-packages/pip/_vendor/distro/__init__.py +0 -54
  194. venv/Lib/site-packages/pip/_vendor/distro/__main__.py +0 -4
  195. venv/Lib/site-packages/pip/_vendor/distro/distro.py +0 -1403
  196. venv/Lib/site-packages/pip/_vendor/distro/py.typed +0 -0
  197. venv/Lib/site-packages/pip/_vendor/idna/__init__.py +0 -45
  198. venv/Lib/site-packages/pip/_vendor/idna/codec.py +0 -122
  199. venv/Lib/site-packages/pip/_vendor/idna/compat.py +0 -15
  200. venv/Lib/site-packages/pip/_vendor/idna/core.py +0 -437
  201. venv/Lib/site-packages/pip/_vendor/idna/idnadata.py +0 -4243
  202. venv/Lib/site-packages/pip/_vendor/idna/intranges.py +0 -57
  203. venv/Lib/site-packages/pip/_vendor/idna/package_data.py +0 -1
  204. venv/Lib/site-packages/pip/_vendor/idna/py.typed +0 -0
  205. venv/Lib/site-packages/pip/_vendor/idna/uts46data.py +0 -8681
  206. venv/Lib/site-packages/pip/_vendor/msgpack/__init__.py +0 -55
  207. venv/Lib/site-packages/pip/_vendor/msgpack/exceptions.py +0 -48
  208. venv/Lib/site-packages/pip/_vendor/msgpack/ext.py +0 -170
  209. venv/Lib/site-packages/pip/_vendor/msgpack/fallback.py +0 -929
  210. venv/Lib/site-packages/pip/_vendor/packaging/__init__.py +0 -15
  211. venv/Lib/site-packages/pip/_vendor/packaging/_elffile.py +0 -109
  212. venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py +0 -262
  213. venv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py +0 -85
  214. venv/Lib/site-packages/pip/_vendor/packaging/_parser.py +0 -353
  215. venv/Lib/site-packages/pip/_vendor/packaging/_structures.py +0 -61
  216. venv/Lib/site-packages/pip/_vendor/packaging/_tokenizer.py +0 -195
  217. venv/Lib/site-packages/pip/_vendor/packaging/licenses/__init__.py +0 -145
  218. venv/Lib/site-packages/pip/_vendor/packaging/licenses/_spdx.py +0 -759
  219. venv/Lib/site-packages/pip/_vendor/packaging/markers.py +0 -362
  220. venv/Lib/site-packages/pip/_vendor/packaging/metadata.py +0 -862
  221. venv/Lib/site-packages/pip/_vendor/packaging/py.typed +0 -0
  222. venv/Lib/site-packages/pip/_vendor/packaging/requirements.py +0 -91
  223. venv/Lib/site-packages/pip/_vendor/packaging/specifiers.py +0 -1019
  224. venv/Lib/site-packages/pip/_vendor/packaging/tags.py +0 -656
  225. venv/Lib/site-packages/pip/_vendor/packaging/utils.py +0 -163
  226. venv/Lib/site-packages/pip/_vendor/packaging/version.py +0 -582
  227. venv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py +0 -3676
  228. venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py +0 -631
  229. venv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py +0 -55
  230. venv/Lib/site-packages/pip/_vendor/platformdirs/android.py +0 -249
  231. venv/Lib/site-packages/pip/_vendor/platformdirs/api.py +0 -299
  232. venv/Lib/site-packages/pip/_vendor/platformdirs/macos.py +0 -144
  233. venv/Lib/site-packages/pip/_vendor/platformdirs/py.typed +0 -0
  234. venv/Lib/site-packages/pip/_vendor/platformdirs/unix.py +0 -272
  235. venv/Lib/site-packages/pip/_vendor/platformdirs/version.py +0 -21
  236. venv/Lib/site-packages/pip/_vendor/platformdirs/windows.py +0 -272
  237. venv/Lib/site-packages/pip/_vendor/pygments/__init__.py +0 -82
  238. venv/Lib/site-packages/pip/_vendor/pygments/__main__.py +0 -17
  239. venv/Lib/site-packages/pip/_vendor/pygments/console.py +0 -70
  240. venv/Lib/site-packages/pip/_vendor/pygments/filter.py +0 -70
  241. venv/Lib/site-packages/pip/_vendor/pygments/filters/__init__.py +0 -940
  242. venv/Lib/site-packages/pip/_vendor/pygments/formatter.py +0 -129
  243. venv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py +0 -157
  244. venv/Lib/site-packages/pip/_vendor/pygments/formatters/_mapping.py +0 -23
  245. venv/Lib/site-packages/pip/_vendor/pygments/lexer.py +0 -963
  246. venv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py +0 -362
  247. venv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py +0 -602
  248. venv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py +0 -1201
  249. venv/Lib/site-packages/pip/_vendor/pygments/modeline.py +0 -43
  250. venv/Lib/site-packages/pip/_vendor/pygments/plugin.py +0 -72
  251. venv/Lib/site-packages/pip/_vendor/pygments/regexopt.py +0 -91
  252. venv/Lib/site-packages/pip/_vendor/pygments/scanner.py +0 -104
  253. venv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py +0 -247
  254. venv/Lib/site-packages/pip/_vendor/pygments/style.py +0 -203
  255. venv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py +0 -61
  256. venv/Lib/site-packages/pip/_vendor/pygments/styles/_mapping.py +0 -54
  257. venv/Lib/site-packages/pip/_vendor/pygments/token.py +0 -214
  258. venv/Lib/site-packages/pip/_vendor/pygments/unistring.py +0 -153
  259. venv/Lib/site-packages/pip/_vendor/pygments/util.py +0 -324
  260. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__init__.py +0 -31
  261. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_impl.py +0 -410
  262. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__init__.py +0 -21
  263. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py +0 -389
  264. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/py.typed +0 -0
  265. venv/Lib/site-packages/pip/_vendor/requests/__init__.py +0 -179
  266. venv/Lib/site-packages/pip/_vendor/requests/__version__.py +0 -14
  267. venv/Lib/site-packages/pip/_vendor/requests/_internal_utils.py +0 -50
  268. venv/Lib/site-packages/pip/_vendor/requests/adapters.py +0 -719
  269. venv/Lib/site-packages/pip/_vendor/requests/api.py +0 -157
  270. venv/Lib/site-packages/pip/_vendor/requests/auth.py +0 -314
  271. venv/Lib/site-packages/pip/_vendor/requests/certs.py +0 -17
  272. venv/Lib/site-packages/pip/_vendor/requests/compat.py +0 -90
  273. venv/Lib/site-packages/pip/_vendor/requests/cookies.py +0 -561
  274. venv/Lib/site-packages/pip/_vendor/requests/exceptions.py +0 -151
  275. venv/Lib/site-packages/pip/_vendor/requests/help.py +0 -127
  276. venv/Lib/site-packages/pip/_vendor/requests/hooks.py +0 -33
  277. venv/Lib/site-packages/pip/_vendor/requests/models.py +0 -1039
  278. venv/Lib/site-packages/pip/_vendor/requests/packages.py +0 -25
  279. venv/Lib/site-packages/pip/_vendor/requests/sessions.py +0 -831
  280. venv/Lib/site-packages/pip/_vendor/requests/status_codes.py +0 -128
  281. venv/Lib/site-packages/pip/_vendor/requests/structures.py +0 -99
  282. venv/Lib/site-packages/pip/_vendor/requests/utils.py +0 -1086
  283. venv/Lib/site-packages/pip/_vendor/resolvelib/__init__.py +0 -27
  284. venv/Lib/site-packages/pip/_vendor/resolvelib/providers.py +0 -196
  285. venv/Lib/site-packages/pip/_vendor/resolvelib/py.typed +0 -0
  286. venv/Lib/site-packages/pip/_vendor/resolvelib/reporters.py +0 -55
  287. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/__init__.py +0 -27
  288. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/abstract.py +0 -47
  289. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/criterion.py +0 -48
  290. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/exceptions.py +0 -57
  291. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/resolution.py +0 -622
  292. venv/Lib/site-packages/pip/_vendor/resolvelib/structs.py +0 -209
  293. venv/Lib/site-packages/pip/_vendor/rich/__init__.py +0 -177
  294. venv/Lib/site-packages/pip/_vendor/rich/__main__.py +0 -245
  295. venv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py +0 -454
  296. venv/Lib/site-packages/pip/_vendor/rich/_emoji_codes.py +0 -3610
  297. venv/Lib/site-packages/pip/_vendor/rich/_emoji_replace.py +0 -32
  298. venv/Lib/site-packages/pip/_vendor/rich/_export_format.py +0 -76
  299. venv/Lib/site-packages/pip/_vendor/rich/_extension.py +0 -10
  300. venv/Lib/site-packages/pip/_vendor/rich/_fileno.py +0 -24
  301. venv/Lib/site-packages/pip/_vendor/rich/_inspect.py +0 -268
  302. venv/Lib/site-packages/pip/_vendor/rich/_log_render.py +0 -94
  303. venv/Lib/site-packages/pip/_vendor/rich/_loop.py +0 -43
  304. venv/Lib/site-packages/pip/_vendor/rich/_null_file.py +0 -69
  305. venv/Lib/site-packages/pip/_vendor/rich/_palettes.py +0 -309
  306. venv/Lib/site-packages/pip/_vendor/rich/_pick.py +0 -17
  307. venv/Lib/site-packages/pip/_vendor/rich/_ratio.py +0 -153
  308. venv/Lib/site-packages/pip/_vendor/rich/_spinners.py +0 -482
  309. venv/Lib/site-packages/pip/_vendor/rich/_stack.py +0 -16
  310. venv/Lib/site-packages/pip/_vendor/rich/_timer.py +0 -19
  311. venv/Lib/site-packages/pip/_vendor/rich/_win32_console.py +0 -661
  312. venv/Lib/site-packages/pip/_vendor/rich/_windows.py +0 -71
  313. venv/Lib/site-packages/pip/_vendor/rich/_windows_renderer.py +0 -56
  314. venv/Lib/site-packages/pip/_vendor/rich/_wrap.py +0 -93
  315. venv/Lib/site-packages/pip/_vendor/rich/abc.py +0 -33
  316. venv/Lib/site-packages/pip/_vendor/rich/align.py +0 -306
  317. venv/Lib/site-packages/pip/_vendor/rich/ansi.py +0 -241
  318. venv/Lib/site-packages/pip/_vendor/rich/bar.py +0 -93
  319. venv/Lib/site-packages/pip/_vendor/rich/box.py +0 -474
  320. venv/Lib/site-packages/pip/_vendor/rich/cells.py +0 -174
  321. venv/Lib/site-packages/pip/_vendor/rich/color.py +0 -621
  322. venv/Lib/site-packages/pip/_vendor/rich/color_triplet.py +0 -38
  323. venv/Lib/site-packages/pip/_vendor/rich/columns.py +0 -187
  324. venv/Lib/site-packages/pip/_vendor/rich/console.py +0 -2680
  325. venv/Lib/site-packages/pip/_vendor/rich/constrain.py +0 -37
  326. venv/Lib/site-packages/pip/_vendor/rich/containers.py +0 -167
  327. venv/Lib/site-packages/pip/_vendor/rich/control.py +0 -219
  328. venv/Lib/site-packages/pip/_vendor/rich/default_styles.py +0 -193
  329. venv/Lib/site-packages/pip/_vendor/rich/diagnose.py +0 -39
  330. venv/Lib/site-packages/pip/_vendor/rich/emoji.py +0 -91
  331. venv/Lib/site-packages/pip/_vendor/rich/errors.py +0 -34
  332. venv/Lib/site-packages/pip/_vendor/rich/file_proxy.py +0 -57
  333. venv/Lib/site-packages/pip/_vendor/rich/filesize.py +0 -88
  334. venv/Lib/site-packages/pip/_vendor/rich/highlighter.py +0 -232
  335. venv/Lib/site-packages/pip/_vendor/rich/json.py +0 -139
  336. venv/Lib/site-packages/pip/_vendor/rich/jupyter.py +0 -101
  337. venv/Lib/site-packages/pip/_vendor/rich/layout.py +0 -442
  338. venv/Lib/site-packages/pip/_vendor/rich/live.py +0 -400
  339. venv/Lib/site-packages/pip/_vendor/rich/live_render.py +0 -106
  340. venv/Lib/site-packages/pip/_vendor/rich/logging.py +0 -297
  341. venv/Lib/site-packages/pip/_vendor/rich/markup.py +0 -251
  342. venv/Lib/site-packages/pip/_vendor/rich/measure.py +0 -151
  343. venv/Lib/site-packages/pip/_vendor/rich/padding.py +0 -141
  344. venv/Lib/site-packages/pip/_vendor/rich/pager.py +0 -34
  345. venv/Lib/site-packages/pip/_vendor/rich/palette.py +0 -100
  346. venv/Lib/site-packages/pip/_vendor/rich/panel.py +0 -317
  347. venv/Lib/site-packages/pip/_vendor/rich/pretty.py +0 -1016
  348. venv/Lib/site-packages/pip/_vendor/rich/progress.py +0 -1715
  349. venv/Lib/site-packages/pip/_vendor/rich/progress_bar.py +0 -223
  350. venv/Lib/site-packages/pip/_vendor/rich/prompt.py +0 -400
  351. venv/Lib/site-packages/pip/_vendor/rich/protocol.py +0 -42
  352. venv/Lib/site-packages/pip/_vendor/rich/py.typed +0 -0
  353. venv/Lib/site-packages/pip/_vendor/rich/region.py +0 -10
  354. venv/Lib/site-packages/pip/_vendor/rich/repr.py +0 -149
  355. venv/Lib/site-packages/pip/_vendor/rich/rule.py +0 -130
  356. venv/Lib/site-packages/pip/_vendor/rich/scope.py +0 -86
  357. venv/Lib/site-packages/pip/_vendor/rich/screen.py +0 -54
  358. venv/Lib/site-packages/pip/_vendor/rich/segment.py +0 -752
  359. venv/Lib/site-packages/pip/_vendor/rich/spinner.py +0 -132
  360. venv/Lib/site-packages/pip/_vendor/rich/status.py +0 -131
  361. venv/Lib/site-packages/pip/_vendor/rich/style.py +0 -796
  362. venv/Lib/site-packages/pip/_vendor/rich/styled.py +0 -42
  363. venv/Lib/site-packages/pip/_vendor/rich/syntax.py +0 -985
  364. venv/Lib/site-packages/pip/_vendor/rich/table.py +0 -1006
  365. venv/Lib/site-packages/pip/_vendor/rich/terminal_theme.py +0 -153
  366. venv/Lib/site-packages/pip/_vendor/rich/text.py +0 -1361
  367. venv/Lib/site-packages/pip/_vendor/rich/theme.py +0 -115
  368. venv/Lib/site-packages/pip/_vendor/rich/themes.py +0 -5
  369. venv/Lib/site-packages/pip/_vendor/rich/traceback.py +0 -899
  370. venv/Lib/site-packages/pip/_vendor/rich/tree.py +0 -257
  371. venv/Lib/site-packages/pip/_vendor/tomli/__init__.py +0 -8
  372. venv/Lib/site-packages/pip/_vendor/tomli/_parser.py +0 -770
  373. venv/Lib/site-packages/pip/_vendor/tomli/_re.py +0 -112
  374. venv/Lib/site-packages/pip/_vendor/tomli/_types.py +0 -10
  375. venv/Lib/site-packages/pip/_vendor/tomli/py.typed +0 -1
  376. venv/Lib/site-packages/pip/_vendor/tomli_w/__init__.py +0 -4
  377. venv/Lib/site-packages/pip/_vendor/tomli_w/_writer.py +0 -229
  378. venv/Lib/site-packages/pip/_vendor/tomli_w/py.typed +0 -1
  379. venv/Lib/site-packages/pip/_vendor/truststore/__init__.py +0 -36
  380. venv/Lib/site-packages/pip/_vendor/truststore/_api.py +0 -333
  381. venv/Lib/site-packages/pip/_vendor/truststore/_macos.py +0 -571
  382. venv/Lib/site-packages/pip/_vendor/truststore/_openssl.py +0 -66
  383. venv/Lib/site-packages/pip/_vendor/truststore/_ssl_constants.py +0 -31
  384. venv/Lib/site-packages/pip/_vendor/truststore/_windows.py +0 -567
  385. venv/Lib/site-packages/pip/_vendor/truststore/py.typed +0 -0
  386. venv/Lib/site-packages/pip/_vendor/urllib3/__init__.py +0 -102
  387. venv/Lib/site-packages/pip/_vendor/urllib3/_collections.py +0 -355
  388. venv/Lib/site-packages/pip/_vendor/urllib3/_version.py +0 -2
  389. venv/Lib/site-packages/pip/_vendor/urllib3/connection.py +0 -572
  390. venv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +0 -1140
  391. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__init__.py +0 -0
  392. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py +0 -36
  393. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py +0 -0
  394. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py +0 -519
  395. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py +0 -397
  396. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py +0 -314
  397. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py +0 -130
  398. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py +0 -518
  399. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +0 -920
  400. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py +0 -216
  401. venv/Lib/site-packages/pip/_vendor/urllib3/exceptions.py +0 -323
  402. venv/Lib/site-packages/pip/_vendor/urllib3/fields.py +0 -274
  403. venv/Lib/site-packages/pip/_vendor/urllib3/filepost.py +0 -98
  404. venv/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py +0 -0
  405. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py +0 -0
  406. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py +0 -51
  407. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/weakref_finalize.py +0 -155
  408. venv/Lib/site-packages/pip/_vendor/urllib3/packages/six.py +0 -1076
  409. venv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +0 -540
  410. venv/Lib/site-packages/pip/_vendor/urllib3/request.py +0 -191
  411. venv/Lib/site-packages/pip/_vendor/urllib3/response.py +0 -879
  412. venv/Lib/site-packages/pip/_vendor/urllib3/util/__init__.py +0 -49
  413. venv/Lib/site-packages/pip/_vendor/urllib3/util/connection.py +0 -149
  414. venv/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py +0 -57
  415. venv/Lib/site-packages/pip/_vendor/urllib3/util/queue.py +0 -22
  416. venv/Lib/site-packages/pip/_vendor/urllib3/util/request.py +0 -137
  417. venv/Lib/site-packages/pip/_vendor/urllib3/util/response.py +0 -107
  418. venv/Lib/site-packages/pip/_vendor/urllib3/util/retry.py +0 -622
  419. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py +0 -504
  420. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_match_hostname.py +0 -159
  421. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py +0 -221
  422. venv/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py +0 -271
  423. venv/Lib/site-packages/pip/_vendor/urllib3/util/url.py +0 -435
  424. venv/Lib/site-packages/pip/_vendor/urllib3/util/wait.py +0 -152
  425. venv/Lib/site-packages/pip/py.typed +0 -4
  426. {cli_ih-0.6.3.1.dist-info → cli_ih-0.7.0.dist-info}/WHEEL +0 -0
@@ -1,920 +0,0 @@
1
- """
2
- SecureTranport support for urllib3 via ctypes.
3
-
4
- This makes platform-native TLS available to urllib3 users on macOS without the
5
- use of a compiler. This is an important feature because the Python Package
6
- Index is moving to become a TLSv1.2-or-higher server, and the default OpenSSL
7
- that ships with macOS is not capable of doing TLSv1.2. The only way to resolve
8
- this is to give macOS users an alternative solution to the problem, and that
9
- solution is to use SecureTransport.
10
-
11
- We use ctypes here because this solution must not require a compiler. That's
12
- because pip is not allowed to require a compiler either.
13
-
14
- This is not intended to be a seriously long-term solution to this problem.
15
- The hope is that PEP 543 will eventually solve this issue for us, at which
16
- point we can retire this contrib module. But in the short term, we need to
17
- solve the impending tire fire that is Python on Mac without this kind of
18
- contrib module. So...here we are.
19
-
20
- To use this module, simply import and inject it::
21
-
22
- import pip._vendor.urllib3.contrib.securetransport as securetransport
23
- securetransport.inject_into_urllib3()
24
-
25
- Happy TLSing!
26
-
27
- This code is a bastardised version of the code found in Will Bond's oscrypto
28
- library. An enormous debt is owed to him for blazing this trail for us. For
29
- that reason, this code should be considered to be covered both by urllib3's
30
- license and by oscrypto's:
31
-
32
- .. code-block::
33
-
34
- Copyright (c) 2015-2016 Will Bond <will@wbond.net>
35
-
36
- Permission is hereby granted, free of charge, to any person obtaining a
37
- copy of this software and associated documentation files (the "Software"),
38
- to deal in the Software without restriction, including without limitation
39
- the rights to use, copy, modify, merge, publish, distribute, sublicense,
40
- and/or sell copies of the Software, and to permit persons to whom the
41
- Software is furnished to do so, subject to the following conditions:
42
-
43
- The above copyright notice and this permission notice shall be included in
44
- all copies or substantial portions of the Software.
45
-
46
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
47
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
48
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
49
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
50
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
51
- FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
52
- DEALINGS IN THE SOFTWARE.
53
- """
54
- from __future__ import absolute_import
55
-
56
- import contextlib
57
- import ctypes
58
- import errno
59
- import os.path
60
- import shutil
61
- import socket
62
- import ssl
63
- import struct
64
- import threading
65
- import weakref
66
-
67
- from .. import util
68
- from ..packages import six
69
- from ..util.ssl_ import PROTOCOL_TLS_CLIENT
70
- from ._securetransport.bindings import CoreFoundation, Security, SecurityConst
71
- from ._securetransport.low_level import (
72
- _assert_no_error,
73
- _build_tls_unknown_ca_alert,
74
- _cert_array_from_pem,
75
- _create_cfstring_array,
76
- _load_client_cert_chain,
77
- _temporary_keychain,
78
- )
79
-
80
- try: # Platform-specific: Python 2
81
- from socket import _fileobject
82
- except ImportError: # Platform-specific: Python 3
83
- _fileobject = None
84
- from ..packages.backports.makefile import backport_makefile
85
-
86
- __all__ = ["inject_into_urllib3", "extract_from_urllib3"]
87
-
88
- # SNI always works
89
- HAS_SNI = True
90
-
91
- orig_util_HAS_SNI = util.HAS_SNI
92
- orig_util_SSLContext = util.ssl_.SSLContext
93
-
94
- # This dictionary is used by the read callback to obtain a handle to the
95
- # calling wrapped socket. This is a pretty silly approach, but for now it'll
96
- # do. I feel like I should be able to smuggle a handle to the wrapped socket
97
- # directly in the SSLConnectionRef, but for now this approach will work I
98
- # guess.
99
- #
100
- # We need to lock around this structure for inserts, but we don't do it for
101
- # reads/writes in the callbacks. The reasoning here goes as follows:
102
- #
103
- # 1. It is not possible to call into the callbacks before the dictionary is
104
- # populated, so once in the callback the id must be in the dictionary.
105
- # 2. The callbacks don't mutate the dictionary, they only read from it, and
106
- # so cannot conflict with any of the insertions.
107
- #
108
- # This is good: if we had to lock in the callbacks we'd drastically slow down
109
- # the performance of this code.
110
- _connection_refs = weakref.WeakValueDictionary()
111
- _connection_ref_lock = threading.Lock()
112
-
113
- # Limit writes to 16kB. This is OpenSSL's limit, but we'll cargo-cult it over
114
- # for no better reason than we need *a* limit, and this one is right there.
115
- SSL_WRITE_BLOCKSIZE = 16384
116
-
117
- # This is our equivalent of util.ssl_.DEFAULT_CIPHERS, but expanded out to
118
- # individual cipher suites. We need to do this because this is how
119
- # SecureTransport wants them.
120
- CIPHER_SUITES = [
121
- SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
122
- SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
123
- SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
124
- SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
125
- SecurityConst.TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256,
126
- SecurityConst.TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256,
127
- SecurityConst.TLS_DHE_RSA_WITH_AES_256_GCM_SHA384,
128
- SecurityConst.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256,
129
- SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384,
130
- SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA,
131
- SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256,
132
- SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA,
133
- SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384,
134
- SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA,
135
- SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256,
136
- SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,
137
- SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA256,
138
- SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA,
139
- SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA256,
140
- SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA,
141
- SecurityConst.TLS_AES_256_GCM_SHA384,
142
- SecurityConst.TLS_AES_128_GCM_SHA256,
143
- SecurityConst.TLS_RSA_WITH_AES_256_GCM_SHA384,
144
- SecurityConst.TLS_RSA_WITH_AES_128_GCM_SHA256,
145
- SecurityConst.TLS_AES_128_CCM_8_SHA256,
146
- SecurityConst.TLS_AES_128_CCM_SHA256,
147
- SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA256,
148
- SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA256,
149
- SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA,
150
- SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA,
151
- ]
152
-
153
- # Basically this is simple: for PROTOCOL_SSLv23 we turn it into a low of
154
- # TLSv1 and a high of TLSv1.2. For everything else, we pin to that version.
155
- # TLSv1 to 1.2 are supported on macOS 10.8+
156
- _protocol_to_min_max = {
157
- util.PROTOCOL_TLS: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12),
158
- PROTOCOL_TLS_CLIENT: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12),
159
- }
160
-
161
- if hasattr(ssl, "PROTOCOL_SSLv2"):
162
- _protocol_to_min_max[ssl.PROTOCOL_SSLv2] = (
163
- SecurityConst.kSSLProtocol2,
164
- SecurityConst.kSSLProtocol2,
165
- )
166
- if hasattr(ssl, "PROTOCOL_SSLv3"):
167
- _protocol_to_min_max[ssl.PROTOCOL_SSLv3] = (
168
- SecurityConst.kSSLProtocol3,
169
- SecurityConst.kSSLProtocol3,
170
- )
171
- if hasattr(ssl, "PROTOCOL_TLSv1"):
172
- _protocol_to_min_max[ssl.PROTOCOL_TLSv1] = (
173
- SecurityConst.kTLSProtocol1,
174
- SecurityConst.kTLSProtocol1,
175
- )
176
- if hasattr(ssl, "PROTOCOL_TLSv1_1"):
177
- _protocol_to_min_max[ssl.PROTOCOL_TLSv1_1] = (
178
- SecurityConst.kTLSProtocol11,
179
- SecurityConst.kTLSProtocol11,
180
- )
181
- if hasattr(ssl, "PROTOCOL_TLSv1_2"):
182
- _protocol_to_min_max[ssl.PROTOCOL_TLSv1_2] = (
183
- SecurityConst.kTLSProtocol12,
184
- SecurityConst.kTLSProtocol12,
185
- )
186
-
187
-
188
- def inject_into_urllib3():
189
- """
190
- Monkey-patch urllib3 with SecureTransport-backed SSL-support.
191
- """
192
- util.SSLContext = SecureTransportContext
193
- util.ssl_.SSLContext = SecureTransportContext
194
- util.HAS_SNI = HAS_SNI
195
- util.ssl_.HAS_SNI = HAS_SNI
196
- util.IS_SECURETRANSPORT = True
197
- util.ssl_.IS_SECURETRANSPORT = True
198
-
199
-
200
- def extract_from_urllib3():
201
- """
202
- Undo monkey-patching by :func:`inject_into_urllib3`.
203
- """
204
- util.SSLContext = orig_util_SSLContext
205
- util.ssl_.SSLContext = orig_util_SSLContext
206
- util.HAS_SNI = orig_util_HAS_SNI
207
- util.ssl_.HAS_SNI = orig_util_HAS_SNI
208
- util.IS_SECURETRANSPORT = False
209
- util.ssl_.IS_SECURETRANSPORT = False
210
-
211
-
212
- def _read_callback(connection_id, data_buffer, data_length_pointer):
213
- """
214
- SecureTransport read callback. This is called by ST to request that data
215
- be returned from the socket.
216
- """
217
- wrapped_socket = None
218
- try:
219
- wrapped_socket = _connection_refs.get(connection_id)
220
- if wrapped_socket is None:
221
- return SecurityConst.errSSLInternal
222
- base_socket = wrapped_socket.socket
223
-
224
- requested_length = data_length_pointer[0]
225
-
226
- timeout = wrapped_socket.gettimeout()
227
- error = None
228
- read_count = 0
229
-
230
- try:
231
- while read_count < requested_length:
232
- if timeout is None or timeout >= 0:
233
- if not util.wait_for_read(base_socket, timeout):
234
- raise socket.error(errno.EAGAIN, "timed out")
235
-
236
- remaining = requested_length - read_count
237
- buffer = (ctypes.c_char * remaining).from_address(
238
- data_buffer + read_count
239
- )
240
- chunk_size = base_socket.recv_into(buffer, remaining)
241
- read_count += chunk_size
242
- if not chunk_size:
243
- if not read_count:
244
- return SecurityConst.errSSLClosedGraceful
245
- break
246
- except (socket.error) as e:
247
- error = e.errno
248
-
249
- if error is not None and error != errno.EAGAIN:
250
- data_length_pointer[0] = read_count
251
- if error == errno.ECONNRESET or error == errno.EPIPE:
252
- return SecurityConst.errSSLClosedAbort
253
- raise
254
-
255
- data_length_pointer[0] = read_count
256
-
257
- if read_count != requested_length:
258
- return SecurityConst.errSSLWouldBlock
259
-
260
- return 0
261
- except Exception as e:
262
- if wrapped_socket is not None:
263
- wrapped_socket._exception = e
264
- return SecurityConst.errSSLInternal
265
-
266
-
267
- def _write_callback(connection_id, data_buffer, data_length_pointer):
268
- """
269
- SecureTransport write callback. This is called by ST to request that data
270
- actually be sent on the network.
271
- """
272
- wrapped_socket = None
273
- try:
274
- wrapped_socket = _connection_refs.get(connection_id)
275
- if wrapped_socket is None:
276
- return SecurityConst.errSSLInternal
277
- base_socket = wrapped_socket.socket
278
-
279
- bytes_to_write = data_length_pointer[0]
280
- data = ctypes.string_at(data_buffer, bytes_to_write)
281
-
282
- timeout = wrapped_socket.gettimeout()
283
- error = None
284
- sent = 0
285
-
286
- try:
287
- while sent < bytes_to_write:
288
- if timeout is None or timeout >= 0:
289
- if not util.wait_for_write(base_socket, timeout):
290
- raise socket.error(errno.EAGAIN, "timed out")
291
- chunk_sent = base_socket.send(data)
292
- sent += chunk_sent
293
-
294
- # This has some needless copying here, but I'm not sure there's
295
- # much value in optimising this data path.
296
- data = data[chunk_sent:]
297
- except (socket.error) as e:
298
- error = e.errno
299
-
300
- if error is not None and error != errno.EAGAIN:
301
- data_length_pointer[0] = sent
302
- if error == errno.ECONNRESET or error == errno.EPIPE:
303
- return SecurityConst.errSSLClosedAbort
304
- raise
305
-
306
- data_length_pointer[0] = sent
307
-
308
- if sent != bytes_to_write:
309
- return SecurityConst.errSSLWouldBlock
310
-
311
- return 0
312
- except Exception as e:
313
- if wrapped_socket is not None:
314
- wrapped_socket._exception = e
315
- return SecurityConst.errSSLInternal
316
-
317
-
318
- # We need to keep these two objects references alive: if they get GC'd while
319
- # in use then SecureTransport could attempt to call a function that is in freed
320
- # memory. That would be...uh...bad. Yeah, that's the word. Bad.
321
- _read_callback_pointer = Security.SSLReadFunc(_read_callback)
322
- _write_callback_pointer = Security.SSLWriteFunc(_write_callback)
323
-
324
-
325
- class WrappedSocket(object):
326
- """
327
- API-compatibility wrapper for Python's OpenSSL wrapped socket object.
328
-
329
- Note: _makefile_refs, _drop(), and _reuse() are needed for the garbage
330
- collector of PyPy.
331
- """
332
-
333
- def __init__(self, socket):
334
- self.socket = socket
335
- self.context = None
336
- self._makefile_refs = 0
337
- self._closed = False
338
- self._exception = None
339
- self._keychain = None
340
- self._keychain_dir = None
341
- self._client_cert_chain = None
342
-
343
- # We save off the previously-configured timeout and then set it to
344
- # zero. This is done because we use select and friends to handle the
345
- # timeouts, but if we leave the timeout set on the lower socket then
346
- # Python will "kindly" call select on that socket again for us. Avoid
347
- # that by forcing the timeout to zero.
348
- self._timeout = self.socket.gettimeout()
349
- self.socket.settimeout(0)
350
-
351
- @contextlib.contextmanager
352
- def _raise_on_error(self):
353
- """
354
- A context manager that can be used to wrap calls that do I/O from
355
- SecureTransport. If any of the I/O callbacks hit an exception, this
356
- context manager will correctly propagate the exception after the fact.
357
- This avoids silently swallowing those exceptions.
358
-
359
- It also correctly forces the socket closed.
360
- """
361
- self._exception = None
362
-
363
- # We explicitly don't catch around this yield because in the unlikely
364
- # event that an exception was hit in the block we don't want to swallow
365
- # it.
366
- yield
367
- if self._exception is not None:
368
- exception, self._exception = self._exception, None
369
- self.close()
370
- raise exception
371
-
372
- def _set_ciphers(self):
373
- """
374
- Sets up the allowed ciphers. By default this matches the set in
375
- util.ssl_.DEFAULT_CIPHERS, at least as supported by macOS. This is done
376
- custom and doesn't allow changing at this time, mostly because parsing
377
- OpenSSL cipher strings is going to be a freaking nightmare.
378
- """
379
- ciphers = (Security.SSLCipherSuite * len(CIPHER_SUITES))(*CIPHER_SUITES)
380
- result = Security.SSLSetEnabledCiphers(
381
- self.context, ciphers, len(CIPHER_SUITES)
382
- )
383
- _assert_no_error(result)
384
-
385
- def _set_alpn_protocols(self, protocols):
386
- """
387
- Sets up the ALPN protocols on the context.
388
- """
389
- if not protocols:
390
- return
391
- protocols_arr = _create_cfstring_array(protocols)
392
- try:
393
- result = Security.SSLSetALPNProtocols(self.context, protocols_arr)
394
- _assert_no_error(result)
395
- finally:
396
- CoreFoundation.CFRelease(protocols_arr)
397
-
398
- def _custom_validate(self, verify, trust_bundle):
399
- """
400
- Called when we have set custom validation. We do this in two cases:
401
- first, when cert validation is entirely disabled; and second, when
402
- using a custom trust DB.
403
- Raises an SSLError if the connection is not trusted.
404
- """
405
- # If we disabled cert validation, just say: cool.
406
- if not verify:
407
- return
408
-
409
- successes = (
410
- SecurityConst.kSecTrustResultUnspecified,
411
- SecurityConst.kSecTrustResultProceed,
412
- )
413
- try:
414
- trust_result = self._evaluate_trust(trust_bundle)
415
- if trust_result in successes:
416
- return
417
- reason = "error code: %d" % (trust_result,)
418
- except Exception as e:
419
- # Do not trust on error
420
- reason = "exception: %r" % (e,)
421
-
422
- # SecureTransport does not send an alert nor shuts down the connection.
423
- rec = _build_tls_unknown_ca_alert(self.version())
424
- self.socket.sendall(rec)
425
- # close the connection immediately
426
- # l_onoff = 1, activate linger
427
- # l_linger = 0, linger for 0 seoncds
428
- opts = struct.pack("ii", 1, 0)
429
- self.socket.setsockopt(socket.SOL_SOCKET, socket.SO_LINGER, opts)
430
- self.close()
431
- raise ssl.SSLError("certificate verify failed, %s" % reason)
432
-
433
- def _evaluate_trust(self, trust_bundle):
434
- # We want data in memory, so load it up.
435
- if os.path.isfile(trust_bundle):
436
- with open(trust_bundle, "rb") as f:
437
- trust_bundle = f.read()
438
-
439
- cert_array = None
440
- trust = Security.SecTrustRef()
441
-
442
- try:
443
- # Get a CFArray that contains the certs we want.
444
- cert_array = _cert_array_from_pem(trust_bundle)
445
-
446
- # Ok, now the hard part. We want to get the SecTrustRef that ST has
447
- # created for this connection, shove our CAs into it, tell ST to
448
- # ignore everything else it knows, and then ask if it can build a
449
- # chain. This is a buuuunch of code.
450
- result = Security.SSLCopyPeerTrust(self.context, ctypes.byref(trust))
451
- _assert_no_error(result)
452
- if not trust:
453
- raise ssl.SSLError("Failed to copy trust reference")
454
-
455
- result = Security.SecTrustSetAnchorCertificates(trust, cert_array)
456
- _assert_no_error(result)
457
-
458
- result = Security.SecTrustSetAnchorCertificatesOnly(trust, True)
459
- _assert_no_error(result)
460
-
461
- trust_result = Security.SecTrustResultType()
462
- result = Security.SecTrustEvaluate(trust, ctypes.byref(trust_result))
463
- _assert_no_error(result)
464
- finally:
465
- if trust:
466
- CoreFoundation.CFRelease(trust)
467
-
468
- if cert_array is not None:
469
- CoreFoundation.CFRelease(cert_array)
470
-
471
- return trust_result.value
472
-
473
- def handshake(
474
- self,
475
- server_hostname,
476
- verify,
477
- trust_bundle,
478
- min_version,
479
- max_version,
480
- client_cert,
481
- client_key,
482
- client_key_passphrase,
483
- alpn_protocols,
484
- ):
485
- """
486
- Actually performs the TLS handshake. This is run automatically by
487
- wrapped socket, and shouldn't be needed in user code.
488
- """
489
- # First, we do the initial bits of connection setup. We need to create
490
- # a context, set its I/O funcs, and set the connection reference.
491
- self.context = Security.SSLCreateContext(
492
- None, SecurityConst.kSSLClientSide, SecurityConst.kSSLStreamType
493
- )
494
- result = Security.SSLSetIOFuncs(
495
- self.context, _read_callback_pointer, _write_callback_pointer
496
- )
497
- _assert_no_error(result)
498
-
499
- # Here we need to compute the handle to use. We do this by taking the
500
- # id of self modulo 2**31 - 1. If this is already in the dictionary, we
501
- # just keep incrementing by one until we find a free space.
502
- with _connection_ref_lock:
503
- handle = id(self) % 2147483647
504
- while handle in _connection_refs:
505
- handle = (handle + 1) % 2147483647
506
- _connection_refs[handle] = self
507
-
508
- result = Security.SSLSetConnection(self.context, handle)
509
- _assert_no_error(result)
510
-
511
- # If we have a server hostname, we should set that too.
512
- if server_hostname:
513
- if not isinstance(server_hostname, bytes):
514
- server_hostname = server_hostname.encode("utf-8")
515
-
516
- result = Security.SSLSetPeerDomainName(
517
- self.context, server_hostname, len(server_hostname)
518
- )
519
- _assert_no_error(result)
520
-
521
- # Setup the ciphers.
522
- self._set_ciphers()
523
-
524
- # Setup the ALPN protocols.
525
- self._set_alpn_protocols(alpn_protocols)
526
-
527
- # Set the minimum and maximum TLS versions.
528
- result = Security.SSLSetProtocolVersionMin(self.context, min_version)
529
- _assert_no_error(result)
530
-
531
- result = Security.SSLSetProtocolVersionMax(self.context, max_version)
532
- _assert_no_error(result)
533
-
534
- # If there's a trust DB, we need to use it. We do that by telling
535
- # SecureTransport to break on server auth. We also do that if we don't
536
- # want to validate the certs at all: we just won't actually do any
537
- # authing in that case.
538
- if not verify or trust_bundle is not None:
539
- result = Security.SSLSetSessionOption(
540
- self.context, SecurityConst.kSSLSessionOptionBreakOnServerAuth, True
541
- )
542
- _assert_no_error(result)
543
-
544
- # If there's a client cert, we need to use it.
545
- if client_cert:
546
- self._keychain, self._keychain_dir = _temporary_keychain()
547
- self._client_cert_chain = _load_client_cert_chain(
548
- self._keychain, client_cert, client_key
549
- )
550
- result = Security.SSLSetCertificate(self.context, self._client_cert_chain)
551
- _assert_no_error(result)
552
-
553
- while True:
554
- with self._raise_on_error():
555
- result = Security.SSLHandshake(self.context)
556
-
557
- if result == SecurityConst.errSSLWouldBlock:
558
- raise socket.timeout("handshake timed out")
559
- elif result == SecurityConst.errSSLServerAuthCompleted:
560
- self._custom_validate(verify, trust_bundle)
561
- continue
562
- else:
563
- _assert_no_error(result)
564
- break
565
-
566
- def fileno(self):
567
- return self.socket.fileno()
568
-
569
- # Copy-pasted from Python 3.5 source code
570
- def _decref_socketios(self):
571
- if self._makefile_refs > 0:
572
- self._makefile_refs -= 1
573
- if self._closed:
574
- self.close()
575
-
576
- def recv(self, bufsiz):
577
- buffer = ctypes.create_string_buffer(bufsiz)
578
- bytes_read = self.recv_into(buffer, bufsiz)
579
- data = buffer[:bytes_read]
580
- return data
581
-
582
- def recv_into(self, buffer, nbytes=None):
583
- # Read short on EOF.
584
- if self._closed:
585
- return 0
586
-
587
- if nbytes is None:
588
- nbytes = len(buffer)
589
-
590
- buffer = (ctypes.c_char * nbytes).from_buffer(buffer)
591
- processed_bytes = ctypes.c_size_t(0)
592
-
593
- with self._raise_on_error():
594
- result = Security.SSLRead(
595
- self.context, buffer, nbytes, ctypes.byref(processed_bytes)
596
- )
597
-
598
- # There are some result codes that we want to treat as "not always
599
- # errors". Specifically, those are errSSLWouldBlock,
600
- # errSSLClosedGraceful, and errSSLClosedNoNotify.
601
- if result == SecurityConst.errSSLWouldBlock:
602
- # If we didn't process any bytes, then this was just a time out.
603
- # However, we can get errSSLWouldBlock in situations when we *did*
604
- # read some data, and in those cases we should just read "short"
605
- # and return.
606
- if processed_bytes.value == 0:
607
- # Timed out, no data read.
608
- raise socket.timeout("recv timed out")
609
- elif result in (
610
- SecurityConst.errSSLClosedGraceful,
611
- SecurityConst.errSSLClosedNoNotify,
612
- ):
613
- # The remote peer has closed this connection. We should do so as
614
- # well. Note that we don't actually return here because in
615
- # principle this could actually be fired along with return data.
616
- # It's unlikely though.
617
- self.close()
618
- else:
619
- _assert_no_error(result)
620
-
621
- # Ok, we read and probably succeeded. We should return whatever data
622
- # was actually read.
623
- return processed_bytes.value
624
-
625
- def settimeout(self, timeout):
626
- self._timeout = timeout
627
-
628
- def gettimeout(self):
629
- return self._timeout
630
-
631
- def send(self, data):
632
- processed_bytes = ctypes.c_size_t(0)
633
-
634
- with self._raise_on_error():
635
- result = Security.SSLWrite(
636
- self.context, data, len(data), ctypes.byref(processed_bytes)
637
- )
638
-
639
- if result == SecurityConst.errSSLWouldBlock and processed_bytes.value == 0:
640
- # Timed out
641
- raise socket.timeout("send timed out")
642
- else:
643
- _assert_no_error(result)
644
-
645
- # We sent, and probably succeeded. Tell them how much we sent.
646
- return processed_bytes.value
647
-
648
- def sendall(self, data):
649
- total_sent = 0
650
- while total_sent < len(data):
651
- sent = self.send(data[total_sent : total_sent + SSL_WRITE_BLOCKSIZE])
652
- total_sent += sent
653
-
654
- def shutdown(self):
655
- with self._raise_on_error():
656
- Security.SSLClose(self.context)
657
-
658
- def close(self):
659
- # TODO: should I do clean shutdown here? Do I have to?
660
- if self._makefile_refs < 1:
661
- self._closed = True
662
- if self.context:
663
- CoreFoundation.CFRelease(self.context)
664
- self.context = None
665
- if self._client_cert_chain:
666
- CoreFoundation.CFRelease(self._client_cert_chain)
667
- self._client_cert_chain = None
668
- if self._keychain:
669
- Security.SecKeychainDelete(self._keychain)
670
- CoreFoundation.CFRelease(self._keychain)
671
- shutil.rmtree(self._keychain_dir)
672
- self._keychain = self._keychain_dir = None
673
- return self.socket.close()
674
- else:
675
- self._makefile_refs -= 1
676
-
677
- def getpeercert(self, binary_form=False):
678
- # Urgh, annoying.
679
- #
680
- # Here's how we do this:
681
- #
682
- # 1. Call SSLCopyPeerTrust to get hold of the trust object for this
683
- # connection.
684
- # 2. Call SecTrustGetCertificateAtIndex for index 0 to get the leaf.
685
- # 3. To get the CN, call SecCertificateCopyCommonName and process that
686
- # string so that it's of the appropriate type.
687
- # 4. To get the SAN, we need to do something a bit more complex:
688
- # a. Call SecCertificateCopyValues to get the data, requesting
689
- # kSecOIDSubjectAltName.
690
- # b. Mess about with this dictionary to try to get the SANs out.
691
- #
692
- # This is gross. Really gross. It's going to be a few hundred LoC extra
693
- # just to repeat something that SecureTransport can *already do*. So my
694
- # operating assumption at this time is that what we want to do is
695
- # instead to just flag to urllib3 that it shouldn't do its own hostname
696
- # validation when using SecureTransport.
697
- if not binary_form:
698
- raise ValueError("SecureTransport only supports dumping binary certs")
699
- trust = Security.SecTrustRef()
700
- certdata = None
701
- der_bytes = None
702
-
703
- try:
704
- # Grab the trust store.
705
- result = Security.SSLCopyPeerTrust(self.context, ctypes.byref(trust))
706
- _assert_no_error(result)
707
- if not trust:
708
- # Probably we haven't done the handshake yet. No biggie.
709
- return None
710
-
711
- cert_count = Security.SecTrustGetCertificateCount(trust)
712
- if not cert_count:
713
- # Also a case that might happen if we haven't handshaked.
714
- # Handshook? Handshaken?
715
- return None
716
-
717
- leaf = Security.SecTrustGetCertificateAtIndex(trust, 0)
718
- assert leaf
719
-
720
- # Ok, now we want the DER bytes.
721
- certdata = Security.SecCertificateCopyData(leaf)
722
- assert certdata
723
-
724
- data_length = CoreFoundation.CFDataGetLength(certdata)
725
- data_buffer = CoreFoundation.CFDataGetBytePtr(certdata)
726
- der_bytes = ctypes.string_at(data_buffer, data_length)
727
- finally:
728
- if certdata:
729
- CoreFoundation.CFRelease(certdata)
730
- if trust:
731
- CoreFoundation.CFRelease(trust)
732
-
733
- return der_bytes
734
-
735
- def version(self):
736
- protocol = Security.SSLProtocol()
737
- result = Security.SSLGetNegotiatedProtocolVersion(
738
- self.context, ctypes.byref(protocol)
739
- )
740
- _assert_no_error(result)
741
- if protocol.value == SecurityConst.kTLSProtocol13:
742
- raise ssl.SSLError("SecureTransport does not support TLS 1.3")
743
- elif protocol.value == SecurityConst.kTLSProtocol12:
744
- return "TLSv1.2"
745
- elif protocol.value == SecurityConst.kTLSProtocol11:
746
- return "TLSv1.1"
747
- elif protocol.value == SecurityConst.kTLSProtocol1:
748
- return "TLSv1"
749
- elif protocol.value == SecurityConst.kSSLProtocol3:
750
- return "SSLv3"
751
- elif protocol.value == SecurityConst.kSSLProtocol2:
752
- return "SSLv2"
753
- else:
754
- raise ssl.SSLError("Unknown TLS version: %r" % protocol)
755
-
756
- def _reuse(self):
757
- self._makefile_refs += 1
758
-
759
- def _drop(self):
760
- if self._makefile_refs < 1:
761
- self.close()
762
- else:
763
- self._makefile_refs -= 1
764
-
765
-
766
- if _fileobject: # Platform-specific: Python 2
767
-
768
- def makefile(self, mode, bufsize=-1):
769
- self._makefile_refs += 1
770
- return _fileobject(self, mode, bufsize, close=True)
771
-
772
- else: # Platform-specific: Python 3
773
-
774
- def makefile(self, mode="r", buffering=None, *args, **kwargs):
775
- # We disable buffering with SecureTransport because it conflicts with
776
- # the buffering that ST does internally (see issue #1153 for more).
777
- buffering = 0
778
- return backport_makefile(self, mode, buffering, *args, **kwargs)
779
-
780
-
781
- WrappedSocket.makefile = makefile
782
-
783
-
784
- class SecureTransportContext(object):
785
- """
786
- I am a wrapper class for the SecureTransport library, to translate the
787
- interface of the standard library ``SSLContext`` object to calls into
788
- SecureTransport.
789
- """
790
-
791
- def __init__(self, protocol):
792
- self._min_version, self._max_version = _protocol_to_min_max[protocol]
793
- self._options = 0
794
- self._verify = False
795
- self._trust_bundle = None
796
- self._client_cert = None
797
- self._client_key = None
798
- self._client_key_passphrase = None
799
- self._alpn_protocols = None
800
-
801
- @property
802
- def check_hostname(self):
803
- """
804
- SecureTransport cannot have its hostname checking disabled. For more,
805
- see the comment on getpeercert() in this file.
806
- """
807
- return True
808
-
809
- @check_hostname.setter
810
- def check_hostname(self, value):
811
- """
812
- SecureTransport cannot have its hostname checking disabled. For more,
813
- see the comment on getpeercert() in this file.
814
- """
815
- pass
816
-
817
- @property
818
- def options(self):
819
- # TODO: Well, crap.
820
- #
821
- # So this is the bit of the code that is the most likely to cause us
822
- # trouble. Essentially we need to enumerate all of the SSL options that
823
- # users might want to use and try to see if we can sensibly translate
824
- # them, or whether we should just ignore them.
825
- return self._options
826
-
827
- @options.setter
828
- def options(self, value):
829
- # TODO: Update in line with above.
830
- self._options = value
831
-
832
- @property
833
- def verify_mode(self):
834
- return ssl.CERT_REQUIRED if self._verify else ssl.CERT_NONE
835
-
836
- @verify_mode.setter
837
- def verify_mode(self, value):
838
- self._verify = True if value == ssl.CERT_REQUIRED else False
839
-
840
- def set_default_verify_paths(self):
841
- # So, this has to do something a bit weird. Specifically, what it does
842
- # is nothing.
843
- #
844
- # This means that, if we had previously had load_verify_locations
845
- # called, this does not undo that. We need to do that because it turns
846
- # out that the rest of the urllib3 code will attempt to load the
847
- # default verify paths if it hasn't been told about any paths, even if
848
- # the context itself was sometime earlier. We resolve that by just
849
- # ignoring it.
850
- pass
851
-
852
- def load_default_certs(self):
853
- return self.set_default_verify_paths()
854
-
855
- def set_ciphers(self, ciphers):
856
- # For now, we just require the default cipher string.
857
- if ciphers != util.ssl_.DEFAULT_CIPHERS:
858
- raise ValueError("SecureTransport doesn't support custom cipher strings")
859
-
860
- def load_verify_locations(self, cafile=None, capath=None, cadata=None):
861
- # OK, we only really support cadata and cafile.
862
- if capath is not None:
863
- raise ValueError("SecureTransport does not support cert directories")
864
-
865
- # Raise if cafile does not exist.
866
- if cafile is not None:
867
- with open(cafile):
868
- pass
869
-
870
- self._trust_bundle = cafile or cadata
871
-
872
- def load_cert_chain(self, certfile, keyfile=None, password=None):
873
- self._client_cert = certfile
874
- self._client_key = keyfile
875
- self._client_cert_passphrase = password
876
-
877
- def set_alpn_protocols(self, protocols):
878
- """
879
- Sets the ALPN protocols that will later be set on the context.
880
-
881
- Raises a NotImplementedError if ALPN is not supported.
882
- """
883
- if not hasattr(Security, "SSLSetALPNProtocols"):
884
- raise NotImplementedError(
885
- "SecureTransport supports ALPN only in macOS 10.12+"
886
- )
887
- self._alpn_protocols = [six.ensure_binary(p) for p in protocols]
888
-
889
- def wrap_socket(
890
- self,
891
- sock,
892
- server_side=False,
893
- do_handshake_on_connect=True,
894
- suppress_ragged_eofs=True,
895
- server_hostname=None,
896
- ):
897
- # So, what do we do here? Firstly, we assert some properties. This is a
898
- # stripped down shim, so there is some functionality we don't support.
899
- # See PEP 543 for the real deal.
900
- assert not server_side
901
- assert do_handshake_on_connect
902
- assert suppress_ragged_eofs
903
-
904
- # Ok, we're good to go. Now we want to create the wrapped socket object
905
- # and store it in the appropriate place.
906
- wrapped_socket = WrappedSocket(sock)
907
-
908
- # Now we can handshake
909
- wrapped_socket.handshake(
910
- server_hostname,
911
- self._verify,
912
- self._trust_bundle,
913
- self._min_version,
914
- self._max_version,
915
- self._client_cert,
916
- self._client_key,
917
- self._client_key_passphrase,
918
- self._alpn_protocols,
919
- )
920
- return wrapped_socket